Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Заполнить рейтинг за один запрос 
:(
    Опции темы
wapp
Дата 25.2.2010, 14:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 19.2.2010

Репутация: нет
Всего: нет



В таблице есть колонка с числами и колонка с рейтингом.
Можно ли за один запрос заполнить рейтинг по колонке чисел?
Например, есть

count|    rate
8|
2|
6|
7|

А нужно получить

count|    rate
8|    4
2|    1
6|    2
7|    3
PM MAIL   Вверх
Zloxa
Дата 25.2.2010, 15:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 3
Всего: 161



Код

update таблица t set rate = (select count(*)+1 from таблица s where s.count < t.count);



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
wapp
Дата 25.2.2010, 18:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 19.2.2010

Репутация: нет
Всего: нет



Zloxa, а одной таблицей обойтись не получится?
PM MAIL   Вверх
LSD
Дата 25.2.2010, 19:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 3
Всего: 538



Цитата(wapp @  25.2.2010,  18:18 Найти цитируемый пост)
Zloxa, а одной таблицей обойтись не получится? 

А где ты увидел вторую таблицу?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
wapp
Дата 25.2.2010, 23:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 19.2.2010

Репутация: нет
Всего: нет



Извини, не сразу понял что "таблица t" и "таблица s" это алиасы. 
Но этот вариант всё равно не работает. 

ERROR:  aggregates not allowed in WHERE clause

Есть предположения как исправить?
PM MAIL   Вверх
Zloxa
Дата 26.2.2010, 00:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 3
Всего: 161



Цитата(wapp @  25.2.2010,  23:11 Найти цитируемый пост)
предположения 

он считает что count- аггрегатная функция.
те кто не хочет проблем обычно так поля не именуют.
я не знаю как точно в PG выделяются идентификаторы.
Попробуй взять count в кавычки.
Если есть возможность - переименуй поле.


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Gluttton
Дата 26.2.2010, 15:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Начинающий
***


Профиль
Группа: Завсегдатай
Сообщений: 1170
Регистрация: 28.8.2008
Где: Феодосия

Репутация: нет
Всего: 54



Цитата(Zloxa @  26.2.2010,  00:14 Найти цитируемый пост)
Попробуй взять count в кавычки.

 smile ...
В PG защита идентификаторов осуществляется взатием в двойные кавычки...


--------------------
Слава Україні!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PostgreSQL | Следующая тема »


 




[ Время генерации скрипта: 0.0917 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.