|
|
|
Порядок выборки DISTINCT ON() случаен?
|
|||
|---|---|---|---|
|
#18+
Пусть есть таблица t(a INT, b INT, c BOOLEAN) и две записи (х.з. в каком порядке они расположены) 1, 1, FALSE 1, 2, TRUE Я делаю Код: sql 1. 2. Какой будет результат? с = TRUE или FALSE ??????? Я рассуждаю так: В таблице r идет упорядочивание, и первой строкой будет с FALSE, затем TRUE (т.к. b =1, а где с=TRUE, там b = 2). далее идет выбор с DISTINCT ON(), и я так полагаю, что все повторяющиеся значения кроме первого будут .... короче их не будет. Значит останется FALSE. Если кто-то думает также, то он как и я ошибается. Вопросы: 1)где я ошибся, 2)как переделать запрос, чтобы мне выбирало так как я хочу (с FALSE где есть FALSE, и с TRUE только если c FALSE нет похожей записи) Ваши мысли, коллеги? Спасибо заранее)) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.02.2014, 18:58:17 |
|
||
|
Порядок выборки DISTINCT ON() случаен?
|
|||
|---|---|---|---|
|
#18+
PCContra, Доку почитайте ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.02.2014, 20:40:39 |
|
||
|
Порядок выборки DISTINCT ON() случаен?
|
|||
|---|---|---|---|
|
#18+
Спасибо, Михаил! Как же я мог забыть про доку? ;-) DISTINCT ON ( expression [, ...] ) keeps only the first row of each set of rows where the given expressions evaluate to equal. The DISTINCT ON expressions are interpreted using the same rules as for ORDER BY (see above). Note that the "first row" of each set is unpredictable unless ORDER BY is used to ensure that the desired row appears first. For example: SELECT DISTINCT ON (location) location, time, report FROM weather_reports ORDER BY location, time DESC; retrieves the most recent weather report for each location. But if we had not used ORDER BY to force descending order of time values for each location, we'd have gotten a report from an unpredictable time for each location . Спасибо, Миша! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.02.2014, 21:17:20 |
|
||
|
|

start [/forum/topic.php?fid=53&fpage=131&tid=1998825]: |
0ms |
get settings: |
9ms |
get forum list: |
18ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
89ms |
get topic data: |
15ms |
get forum data: |
4ms |
get page messages: |
53ms |
get tp. blocked users: |
2ms |
| others: | 228ms |
| total: | 426ms |

| 0 / 0 |
