Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Помогите составить SQL запрос  (Прочитано 8362 раз)
0 Пользователей и 1 Гость смотрят эту тему.
Razor
Помогающий

ru
Offline Offline
Пол: Мужской

« : 11-02-2009 19:16 » 

Или хотяб скажите, в какую сторону копать?
В SQL совсем не селен( Конктретно MySQL БД синонимов.
Имеется - две табилцы по две колонки:

1. words с колонками id , word
id - от 1 до n
word - слова (на каждый id по 1 слову)
и 2. synonyms с колонками w_id и s_id
w_id - айди слова для которого ищем синоним
s_id - айди синонима

.
Нужно имея слово заданное найти его айдишник, затем просмотреть какие синонимы соотвествуют этому айдишнику, и выбрать синонимы.
Примерно так. К БД пометка была:
Пару слов о том, как использовать. Для начала получаете id слова запросом SELECT id FROM words WHERE word='Профит'. После этого получаем список синонимов SELECT w_id, s_id FROM synonyms WHERE w_id='1234' or s_id='1234'. Сортируем повторяющиеся значения и забираем слова-синонимы SELECT word FROM words WHERE id IN (1,2,3,4,5 ...). Умные дядьки объединят все запросы в один большой и будут счастливы.

Вот, но мне это не по силам( может посдкажете что использовать или как объединить?
Спасибо заранее
Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 11-02-2009 19:54 » 

Цитата
Нужно имея слово заданное найти его айдишник, затем просмотреть какие синонимы соотвествуют этому айдишнику, и выбрать синонимы.

Ну так все ж уже описал - просто пиши, как пишешь.

Код: (SQL)
SELECT w.id, ws.id, ws.word
FROM words w, syninyms s, words ws
WHERE w.word = '.......'
  AND (
    s.w_id = w.id
    OR s.s_id = w.id
  )
  AND ws.id IN (s.w_id, s.s_id);

К недостаткам этой базы отнесу то, что поиск идет по всем столбцам обеих таблиц, а значит и индексы нужно делать на все столбцы (как и какие - лучше проверить экспериментально).

Но кое что мне не понятно тут. Ведь у синонима может быть еще один синоним и т.д...
Вопрос такой: в таблице synonyms к каждому слову (естественно, только те, что имеют синонимы) имеется полный набор синонимов (каждый с каждым) или как?
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Finch
Спокойный
Администратор

il
Offline Offline
Пол: Мужской
Пролетал мимо


« Ответ #2 : 11-02-2009 20:39 » 

Можно такой запрос
Код: (SQL)
SELECT word FROM words w JOIN (SELECT s.s_id AS sid FROM synonyms s JOIN words w ON s.w_id = w.id WHERE w.word='Профит') s ON s.sid = w.id ;
Записан

Не будите спашяго дракона.
             Джаффар (Коша)
Razor
Помогающий

ru
Offline Offline
Пол: Мужской

« Ответ #3 : 11-02-2009 20:59 » 

RXL, да БД просто не я составлял.
В таблице синонимов идет (если допустим на солво 1 есть синонимы с индексами 15,17)
1 15
1 17

 и т.д. но это думается мне не очень правильное решение. А перепроектировать как-нибудь можно чтоб была быстрей? Но тогда мне кажется это избыточность информации будет, видится только такой вариант...

Кстати запрос почему-то не работает, или работает но выполнения я его не дождался.
Finch, а твой работает)

Спасибо за помощь в составлении запроса)
Записан
RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #4 : 12-02-2009 09:30 » 

Razor, быстрее была бы работа каждый с каждым.
При существующем принципе произвольных цепочечных связей между синонимами можно объединить таблицы в одну: id, word, synonym_id. Также, для выборки всех синонимов потребуется рекурсия.
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Razor
Помогающий

ru
Offline Offline
Пол: Мужской

« Ответ #5 : 12-02-2009 14:50 » 

RXL, спасибо, попробую
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines