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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Проверка целостности, MySQL v5.5 
:(
    Опции темы
tishaishii
Дата 18.2.2012, 18:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Создатель
***


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

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



Есть таблицы T1(ID, DOCTYPE, DOCID, DOCITEM) и T2(ID, ID_T1, DOCTYPE, DOCID, DOCITEM).
T1.ID <=>> T2.ID_T1
То есть, в T2 ведётся история T1.
Нужно составить запрос, который бы возвращал список T1.ID, в которых {T1.DOCTYPE, T1.DOCID,  T1.DOCITEM} не соответствуют последним записям в T2.

Это сообщение отредактировал(а) tishaishii - 18.2.2012, 18:03
PM MAIL ICQ Skype   Вверх
Akina
Дата 18.2.2012, 20:00 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


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

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



Цитата(tishaishii @  18.2.2012,  19:02 Найти цитируемый пост)
последним записям в T2.

В таблице остутствует штамп времени, соответственно неясно, что означает "последние"...


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
nellyk
Дата 20.2.2012, 00:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(tishaishii @ 18.2.2012,  18:02)
Есть таблицы T1(ID, DOCTYPE, DOCID, DOCITEM) и T2(ID, ID_T1, DOCTYPE, DOCID, DOCITEM).
T1.ID <=>> T2.ID_T1
То есть, в T2 ведётся история T1.
Нужно составить запрос, который бы возвращал список T1.ID, в которых {T1.DOCTYPE, T1.DOCID,  T1.DOCITEM} не соответствуют последним записям в T2.

SELECT T1.ID FROM T1,T2 WHERE T1.ID NOT IN (SELECT DISTINCT ID_T1 FROM T2) 
UNION
SELECT T1.ID FROM T1, T2, (SELECT ID_T1, MAx(ID) AS ID_T2 FROM T2 GROUP BY ID_T1) T3 WHERE T1.ID=T3.ID_T1 AND T2.ID=T3.ID_T2 AND (T1.DOCTYPE <> T2.DOCTYPE OR T1.DOCID <> T2.DOCID OR T1.DOCITEM <> T2.DOCITEM) 

Сверху идентификаторы, отсутствующие в истории, снизу - те, у которых есть различия с последними "историческими" записями.
PM MAIL   Вверх
tishaishii
Дата 23.2.2012, 10:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Создатель
***


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

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



"Последнее" - это последняя запись.
Время - неоднозначный критерий.
PM MAIL ICQ Skype   Вверх
Akina
Дата 23.2.2012, 20:06 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


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

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



Цитата(tishaishii @  23.2.2012,  11:33 Найти цитируемый пост)
"Последнее" - это последняя запись.

Последняя при какой сортировке? потому как без сортировки такого понятия как "первая-последняя-прочее" не существует.
Цитата(tishaishii @  23.2.2012,  11:33 Найти цитируемый пост)
Время - неоднозначный критерий. 

Только если поле не уникально.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
tishaishii
Дата 26.2.2012, 17:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Создатель
***


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

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



Обычно, по-умолчанию, упорядочивание выполняется по первичному ключу. PK, предполагаю как T1.ID и T2.ID, FK предполагаю как T2.ID_T1.
PM MAIL ICQ Skype   Вверх
Zloxa
Дата 27.2.2012, 10:40 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(tishaishii @  26.2.2012,  17:48 Найти цитируемый пост)
Обычно

smile

Цитата(tishaishii @  18.2.2012,  18:02 Найти цитируемый пост)
Нужно составить запрос, который бы возвращал список T1.ID, в которых {T1.DOCTYPE, T1.DOCID,  T1.DOCITEM} не соответствуют последним записям в T2.

Цитата(tishaishii @  26.2.2012,  17:48 Найти цитируемый пост)
 по первичному ключу


Код

select T1.ID
  from T1
  where not exists (select null from t2 
                     where T2.ID_T1 = T1.ID
                       and T1.DOCTYPE = t2.doctype 
                       and T1.DOCID = t2.docid 
                       and T1.DOCITEM = t2.DOCITEM
                       and not exists (select null 
                                         from t2 t2_ 
                                         where t2_.ID_T1 = t2.ID_T1
                                           and t2.ID > t2_.ID
                                       )
                       )

Это решение в лоб.
Задача сводится к нахождению последней записи в логе и сравнению с исходной таблицей.
Подзадача "выбрать последнюю запись" имеет несколько вариантов http://www.sql.ru/forum/actualthread.aspx?tid=687908
Пожалуй, самый эффективный тут будет "бабушкин метод"

Это сообщение отредактировал(а) Zloxa - 27.2.2012, 10:40


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


Создатель
***


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

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



Ссылка на "бабушкин метод" пуста.smile
Вобщем-то я задачу решил, может быть не самым эффективным способом, и закрыл возможность появления "нехороших" записей.

Это сообщение отредактировал(а) tishaishii - 29.2.2012, 06:53
PM MAIL ICQ Skype   Вверх
Zloxa
Дата 29.2.2012, 08:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


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

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



Цитата(tishaishii @  29.2.2012,  06:39 Найти цитируемый пост)
Ссылка на "бабушкин метод" пуста

Можете и сами выполнить поиск на форуме по этому ключевому слову.  smile 


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




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


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

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