172 похожих чатов

Добрый день, я хочу отсортировать абитуриентов по убыванию в зависимости

от их оценки
Таблица с абитуриентами
CREATE TABLE enrollee(
id SERIAL NOT NULL UNIQUE,
code TEXT NOT NULL UNIQUE,
password TEXT NOT NULL,
"Фамилия Имя" TEXT NOT NULL,
"Украинский" INTEGER,
"Математика" INTEGER,
"Аттестация" FLOAT NOT NULL,
"Курсы(Украинский)" INTEGER,
"Курсы(Математика)" INTEGER,
score FLOAT
);
INSERT INTO enrollee(code, password, "Фамилия Имя", "Украинский", "Математика", "Аттестация", "Курсы(Украинский)", "Курсы(Математика)")
VALUES ('0000', 'JQkAcQ64FWZD', 'Иванов Артем', 143, 170, 9.1, 0, 0),
('0001', 'M4A0iCEydl8b', 'Смирнов Александр', 131, 164, 8.7, 12, 8),
('0002', 'aZYSRF2Orsy9', 'Кузнецов Михаил', 142, 153, 7.3, 0, 0);
И сам запрос
do $$
declare
i integer;
j float;
begin
for i in SELECT id FROM enrollee
loop
SELECT INTO j "Украинский" + "Математика" + "Аттестация" + "Курсы(Украинский)" + "Курсы(Математика)"
FROM enrollee
WHERE id = i;

UPDATE enrollee SET score = j
WHERE id = i;
end loop;
end; $$;

SELECT "Фамилия Имя", "Украинский", "Математика", "Аттестация", "Курсы(Украинский)", "Курсы(Математика)"
FROM enrollee
ORDER BY score DESC;
Вопрос можно ли сделать проще ?

8 ответов

42 просмотра

Ах, да, ответ на вопрос: Можно.

assert- Автор вопроса
assert- Автор вопроса
Ilya Anfimov
Да.

Спасибо это всё что я хотел знать значит нужно действительно ещё подучить основы

assert
Даже не применяя циклы ?

Вряд ли у вас больше нескольких тысяч абитуриентов, что мешает прям в запросе то подсчитать score?

Konstantin Zaitsev
Вряд ли у вас больше нескольких тысяч абитуриентов...

Вероятно, знание SQL на уровне "миддл показал одну форму с CRUD".

assert- Автор вопроса

SELECT "Фамилия Имя", "Украинский", "Математика", "Аттестация", "Курсы(Украинский)", "Курсы(Математика)" FROM enrollee ORDER BY ( SELECT "Украинский" + "Математика" + "Аттестация" + "Курсы(Украинский)" + "Курсы(Математика)" FROM enrollee ) DESC; Но это работать не будет

Похожие вопросы

Обсуждают сегодня

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Я вот подумал. SSE выполняет операции максимум с 64-битной точностью. А FPU - всегда с 80-битной. Разве не должно быть FPU точнее тогда?
The Bird of Hermes
13
как быть с принтером? такой подход прокатит?
zamtmn
12
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Я не понимаю, это троллинг или что? Швабрика поддерживают, который буквально пишет на ассемблере взаимодействия с винапи. Я это ещё написал загрузчик и хоть что-то изучаю в о...
Shadow Akira
6
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Привет. Подскажите, как правильно сматчить лист фиксированного размера, чтобы компилятор не говорил мне о неполном паттерне? Допустим что-то такое [x', y'] = sort [x, y]?
Arseny
8
Карта сайта