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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Сранение 1-ого поля с другим полем 
:(
    Опции темы
chief39
Дата 21.6.2005, 18:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

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



А ну-к ща попробуем сообразить:
У тебя есть студенты, предметы, и связка предмет-студент для которой есть оценка?
То есть у одного студента по одному предмету - только одна оценка?

Попробуй-ка вот так:

Нам надо "ID предмета", "оценка" по своему студенту. (это не значит что эти поля надо указывать после select - просто логику излагаю - по ним ты вяжешь).

Также надо по всем студентам - "ID студента", "ID предмета", "оценка". (то же самое)

Вяжешь их по "ID предмета", "оценка". Теперь у нас есть данные что у такого-то студента есть совпадение по предмету и оценке с эталоном.
всё это группируешь по "ID студента" и делаешь count.
потом с помощью having скажи что count должен совпадать с count'ом у которого "ID студента" = @ТвойСтудент.
Итого, если у студента 13 предметов с конкретными оценками - то у его аналогов должно быть 13 совпадений.

P.S. Не помню, поддерживает ли having такие конструкции. Проверь.
Будет время - попробую сам селект наштопать и проверить smile



--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
SergKO
Дата 24.6.2005, 07:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


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

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



С использованием алгоритма chief39 получилось следующее (12 - ID студента)

Код

SELECT STUD_ID FROM
(
 SELECT STUD_ID, COUNT(SUBJ_ID) AS SUBJ_ID_COUNT FROM
    (
     SELECT t2.STUD_ID, t2.SUBJ_ID
     FROM    (
         SELECT stud_id, mark, subj_id FROM _exam_mark
                               WHERE STUD_ID = 12
        ) t1 INNER JOIN 
                _exam_mark t2 ON (t1.SUBJ_ID = t2.SUBJ_ID AND t1.MARK = t2.MARK)
    ) t3 GROUP BY STUD_ID
) t4
WHERE SUBJ_ID_COUNT IN (SELECT COUNT(MARK) FROM _exam_mark
                GROUP BY STUD_ID HAVING STUD_ID = 12)



Я думаю, если немного посидеть, то можно написать получше.
_exam_mark - таблица с оценками от Delphist

PM MAIL   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




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


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

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