|
Как работает having?
|
|||
---|---|---|---|
#18+
Доброго времени суток. есть такой запрос: Код: sql 1. 2. 3. 4. 5.
он возвращает что-то такое: Name1 Name2 JEFFERSON JEFFERSON JEFFERSON Джефферсон Но в having же указано, что интересуют записи где count("Name1") = 1, а в ответе явно две записи с "Name1" = 'JEFFERSON' .. что не так? ... |
|||
:
Нравится:
Не нравится:
|
|||
24.03.2017, 13:16 |
|
Как работает having?
|
|||
---|---|---|---|
#18+
Во-первых, исходные строки по группам вы разбиваете условием group by "Name1", "Name2". То есть, по уникальной комбинации двух полей. Таким образом две приведенные вами строки принадлежат двум разным группам. Причем в каждой группе оказывается по единственной строке. Во-вторых, агрегатная функция агрегирует строки в каждой группе по отдельности. В-третьих, можно указывать аргумент функции count отличный от *. Но нужно понимать, что это стоит делать лишь для того, чтобы подсчитать количество (общее, не уникальных) значений аргумента, не являющихся NULL. ... |
|||
:
Нравится:
Не нравится:
|
|||
24.03.2017, 14:01 |
|
Как работает having?
|
|||
---|---|---|---|
#18+
для 10 лет стажа странный вопрос having -- есть синтаксический сахар, и просто "уберегает" от "лишнего" селекта, в котором он обычное where примерно так : Код: sql 1. 2. 3. 4. 5.
Код: sql 1. 2. 3. 4. 5.
вам нужно что--то типа Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9.
... |
|||
:
Нравится:
Не нравится:
|
|||
24.03.2017, 14:25 |
|
Как работает having?
|
|||
---|---|---|---|
#18+
Код: sql 1. 2. 3. 4. 5.
... |
|||
:
Нравится:
Не нравится:
|
|||
24.03.2017, 14:47 |
|
Как работает having?
|
|||
---|---|---|---|
#18+
LeXa NalBat, я исходил из того, что список вывода может быть шире листа группировки, приведённого в примере ТС. а формально -- всё так, но вопроса бы и не было. ... |
|||
:
Нравится:
Не нравится:
|
|||
24.03.2017, 15:13 |
|
|
start [/forum/topic.php?fid=53&fpage=76&tid=1996625]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
35ms |
get topic data: |
14ms |
get forum data: |
3ms |
get page messages: |
47ms |
get tp. blocked users: |
2ms |
others: | 342ms |
total: | 473ms |
0 / 0 |