Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
89 / 60 / 2
Регистрация: 08.03.2011
Сообщений: 546

Запрос на выборку нужного поля

07.06.2012, 16:26. Показов 993. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, есть таблицы Кафедра Факультет Преподаватель Студент Задание
кафедра связана с факультетом по id
факультет связан с преподавателем по id
преподаватель связан с заданием по id
задание связано с студентом по id
требутся найти факультет на котором преподаватель иванов дал задание петрову из группы с наибольшим количеством студентов(в таблице студенты есть поле группа)
Делаю так
SQL
1
2
3
4
5
6
7
8
9
10
11
USE Sergey
SELECT top 1 gruppa, Fakultet.nazvanie AS 'Факультет', Prepodavatel.familiya_prepodavatelya AS 'Фамилия преподавателя', Student.familiya_studenta AS 'Фамилия студента'
FROM Kafedra, Fakultet, Prepodavatel, Student, Zadanie
WHERE Fakultet.fakultet_id=Kafedra.fakultet_id 
AND Kafedra.kafedra_id=Prepodavatel.kafedra_id
AND Prepodavatel.prepodavatel_id=Zadanie.prepodavatel_id
AND Zadanie.zadanie_id=student.zadanie_id
AND student.familiya_studenta='Petrov'
AND prepodavatel.familiya_prepodavatelya='Ivanov'
GROUP BY gruppa,Fakultet.nazvanie, Prepodavatel.familiya_prepodavatelya, Student.familiya_studenta
ORDER BY COUNT(gruppa) DESC;
но это не совсем то..
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.06.2012, 16:26
Ответы с готовыми решениями:

Запрос на выборку нужного поля
Здравствуйте, есть таблицы Покупатель Склад Соотрудник Велосипед Заказ покупатель связан с заказом по id заказ связан с соотрудником по...

Сгруппировать выборку по значению некоторого поля
Имеется следующая таблица: EmployeeID|Salary 1|10 2|10 3|15 4|20 5|20 Мне нужно сгруппировать выборку из этой таблицы по полю...

Запрос на выборку
По введенном названии языка показать количество стран с таким государственным языком! SELECT языки.название_языка FROM языки ...

8
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
07.06.2012, 19:14
SQL
1
2
3
4
5
6
7
8
9
10
SELECT top 1 Fakultet.nazvanie, Prepodavatel.familiya_prepodavatelya,Student.familiya_studenta,
    (SELECT COUNT(*) FROM Student S1 WHERE S1.gruppa=Student.gruppa) AS CountStud
  FROM Kafedra, Fakultet, Prepodavatel, Student, Zadanie
  WHERE Fakultet.fakultet_id=Kafedra.fakultet_id AND
        Kafedra.kafedra_id=Prepodavatel.kafedra_id AND
        Prepodavatel.prepodavatel_id=Zadanie.prepodavatel_id AND
        Zadanie.zadanie_id=student.zadanie_id AND
        student.familiya_studenta='Petrov' AND
        prepodavatel.familiya_prepodavatelya='Ivanov'
  ORDER BY 4 DESC
1
89 / 60 / 2
Регистрация: 08.03.2011
Сообщений: 546
07.06.2012, 22:36  [ТС]
Спасибо, проверю отпишусь

Добавлено через 2 часа 32 минуты
Спасибо, все работает.
Можешь объяснить строку FROM Student S1 WHERE S1.gruppa=Student.gruppa) AS CountStud ?
0
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
07.06.2012, 23:31
Во вложенном запросе считаю количество студентов в группе студента из основного запроса. Неважно что одна и таже таблица, SQL расценивает их как независимые таблицы
1
89 / 60 / 2
Регистрация: 08.03.2011
Сообщений: 546
13.06.2012, 21:37  [ТС]
спасибо, как я понял запрос сортирует по убыванию и берет 1 строку...а если таких студентов несколько?
чтоб не писать
SQL
1
SELECT top 2 gruppa
, как можно сделать?
0
 Аватар для Remmor
71 / 71 / 23
Регистрация: 02.02.2012
Сообщений: 309
14.06.2012, 11:19
Цитата Сообщение от fiphiker Посмотреть сообщение
а если таких студентов несколько?
Каких студентов несколько? Петровых из группы с максимальным количеством человек?
По вопросу: top 2 вернет две верхние записи из получившегося набора.
1
89 / 60 / 2
Регистрация: 08.03.2011
Сообщений: 546
14.06.2012, 13:47  [ТС]
Да, если студентов петровых из 2 групп с одинаковым количеством студентов..то он должен вывести 2 строки, а по умолчанию у нас одна строка.
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
14.06.2012, 13:54
T-SQL
1
TOP(1) WITH TIES
1
89 / 60 / 2
Регистрация: 08.03.2011
Сообщений: 546
14.06.2012, 14:01  [ТС]
Да, спасибо, то что нужно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.06.2012, 14:01
Помогаю со студенческими работами здесь

Запрос на выборку
Добрый день есть 3 таблицы. 1 таблица столбец Номер изделия, 2 Тип изделия и в 3 отдел в который это изделие идет. Так вот нужно...

Запрос на выборку
Здравствуйте. Подскажите пожалуйста как правильно сформировать запрос: select distinct name from table1 where name in...

Запрос на выборку
Есть 2 таблицы Окна(nazwa, osciez1,osciez2,osciez3,osciez4) и Рами(nr_art,opis) Окно складиваються из рам. Поле...

Запрос на выборку
База данных содержит таблицы: Сотрудник (код_сотрудника, фио, ....) Дети (код_сотрудника, фио_ребенка). Выдать список сотрудников,...

Запрос на выборку
Здравствуйте, подскажите - как сделать запрос: Найти производителей, которые выпускают более одной модели, при этом все выпускаемые...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru