
Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
15.09.2004, 13:58:19
|
|||
|---|---|---|---|
|
|||
Возвращение набора записей с GROUP данными |
|||
|
#18+
В добровольно-принудительном порядке был вынужден переезжать на СУБД PostgreSQL так что некоторых тонкостей пока еще не уловил. А вопрос следующий: Есть функция, возвращающая SETOF record . Внутри я возвращаю записи следующим образом for result in select DID, count(*) as VCount from visits group by DID loop return next result; end loop; При попытке извлечь данные из функции ругается: "Wrong record type supplied in RETURN NEXT" Если убираю группировку - все прекрасно работает. Кто-нить поделитесь соображениями, чего не так делаю? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
15.09.2004, 21:55:59
|
|||
|---|---|---|---|
Возвращение набора записей с GROUP данными |
|||
|
#18+
Попробуй так: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
16.09.2004, 10:07:20
|
|||
|---|---|---|---|
|
|||
Возвращение набора записей с GROUP данными |
|||
|
#18+
Спасибо, я уже нашел в чем проблема. Вся фишка в том, что я хочу обойтись без создания дополнительных типов. Все просто, при использовании агрегатных функций, возвращаемый тип данных у которых не определен (т.е. все кроме min и max ) нужно явно приводить полученное поле к одному из типов: for result in select DID, ( cast(count(*) as int4) ) as VCount from visits group by DID loop return next result; end loop; ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=53&mobile=1&tid=2007666]: |
0ms |
get settings: |
9ms |
get forum list: |
16ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
152ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
52ms |
get tp. blocked users: |
1ms |
| others: | 194ms |
| total: | 445ms |

| 0 / 0 |
