Re: What is the difference between these queries

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: What is the difference between these queries
Дата
Msg-id 9830.1302619571@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: What is the difference between these queries  (tv@fuzzy.cz)
Ответы Re: What is the difference between these queries  (tv@fuzzy.cz)
Список pgsql-general
tv@fuzzy.cz writes:
>> Query1
>> -- the first select return 10 rows
>> SELECT a, b
>> FROM table1 LEFT JOIN table2 on (table1_id = tabl2_id)
>> Where table1_id NOT IN (SELECT DISTINCT table1_id FROM table3)
>> EXCEPT
>> -- this select return 5 rows
>> SELECT a, b
>> FROM table1 LEFT JOIN table2 on (table1_id = tabl2_id)
>> Where table1_id NOT IN (SELECT DISTINCT table1_id FROM table3)
>> and  b ~* 'pattern'
>> -- the result is 5 rows
>>
>> Query2
>> --this select return 3 rows
>> SELECT a, b
>> FROM table1 LEFT JOIN table2 on (table1_id = tabl2_id)
>> Where table1_id NOT IN (SELECT DISTINCT table1_id FROM table3)
>> and  b !~* 'pattern'
>>
>> Why query1 and query2  return different set. note that query two return a
>> subset
>> of query1

> Those queries obviously are not equivalent - the regular expression is
> applied to different parts of the query.

Not sure I buy that ... personally I was wondering whether there were
some null values of b.

            regards, tom lane

В списке pgsql-general по дате отправления:

Предыдущее
От: tomas@tuxteam.de
Дата:
Сообщение: Re: Different cast behavior of TEXT and VARCHAR
Следующее
От: tv@fuzzy.cz
Дата:
Сообщение: Re: What is the difference between these queries