Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
1 / 1 / 0
Регистрация: 08.01.2013
Сообщений: 63

Запрос по двум таблицам и составление ссылки

16.08.2013, 11:06. Показов 1323. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
ребят, помогите с запросом к двум таблицам на mysql
есть две таблицы news и sovet, необходимо произвести по ним поиск и вывести ссылки
поиск на полю text, в обеих таблицах оно есть

Добавлено через 10 часов 36 минут
таблица news (id, zagolovok, text), voset (id, refid, zagolovok, text)
refid - это номер категории, к которой принадлежит статья, в таблице news этого нет
по одной таблице так ищу
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
$total = mysql_result(mysql_query("SELECT COUNT(*) FROM `sovet`
WHERE MATCH (`text`) AGAINST ('" . mysql_real_escape_string($search) . "')"), 0);
if ($total) {
$req = mysql_query("SELECT * FROM `sovet` WHERE MATCH (`text`) AGAINST ('" . mysql_real_escape_string($search) . "') LIMIT $start, $num");
while ($res = mysql_fetch_assoc($req)) {
echo is_integer($i / 2) ? '<div class="list1">' : '<div class="list2">';
echo '<a href="https://www.cyberforum.ru/sovet/index.php?id=' . $res['id'] . '">' . $res['zagolovok'] . '</a> ';
echo date("d.m.Y в H:i", $res['time']) . '<br/>';
$text = $res['text'];
$text = checkout(mb_substr($text, 0, 400), 1, 1);
echo '<div class="article">'.$text.'</div>';
if (mb_strlen($res['text']) > 400)
echo '<a href="https://www.cyberforum.ru/sovet/index.php?id=' . $res['id'] . '">Подробнее &rArr;</a>';
echo '<br /><a href="https://www.cyberforum.ru/sovet/index.php?id=' . $res['refid'] . '">В тему</a> | <a href="https://www.cyberforum.ru/sovet/index.php?id=' . $res['id'] . '">К совету</a>';
echo '</div>';
++$i;
}
}
надо так же сформировать ссылку
PHP
1
echo '<a href="https://www.cyberforum.ru/sovet/index.php?id=' . $res['id'] . '">Подробнее &rArr;</a>';
для news
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.08.2013, 11:06
Ответы с готовыми решениями:

Составление сложного запроса, выборка по двум таблицам
в общем есть 2 таблицы, `template` и `template_design`, поля такие `template` = id,name. `template_design` = id, id_template,...

Запрос к двум таблицам
Такая проблемка, есть 2 таблицы: t1: c столбцами id,n2,n3,n4,n5 t2: c столбцами n0,id,d1 нужно вывести id,n2,n3,n4,n5 с й табл и d1...

Запрос к двум таблицам
Помогите исправить запрос: SELECT Sotrudnik.id_sotr, Sotrudnik.familia, Sotrudnik.imea,; Sotrudnik.otchestvo, Sotrudnik.s_pasporta,...

7
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
16.08.2013, 11:37
Навскидку (фрагмент)
MySQL
1
2
3
4
5
6
SELECT * 
FROM (
  select 0 `is_news`,`id`,`zagolovok`,`text`,`time` from `sovet` WHERE MATCH ...
  union all
  select 1 `is_news`,`id`,`zagolovok`,`text`,`time` from `news`  WHERE MATCH ...
) as u
Но смущает двукратный длительный поиск по таблицам, удваивающий время выполнения (при подсчете количества строк и при получении результата)...

Возможно, лучше применить временную таблицу:
MySQL
1
2
3
4
5
6
7
8
9
create temporary table temp_match
SELECT `is_news`,`id`,`zagolovok`,`text`,`time` 
FROM (
  select 0 `is_news`,`id`,`zagolovok`,`text`,`time` from `sovet` WHERE MATCH ...
  union all
  select 1 `is_news`,`id`,`zagolovok`,`text`,`time` from `news`  WHERE MATCH ...
) as u;
select count(*) into @qty from temp_match;
select @qty `total_lines`,`is_news`,`id`,`zagolovok`,`text`,`time` from temp_match;
1
1 / 1 / 0
Регистрация: 08.01.2013
Сообщений: 63
16.08.2013, 11:40  [ТС]
cygapb-007, спасибо попробую, а как ссылку потом вывести
такую для voset
echo '<a href="http://www.site.ru/sovet/index.php?id=' . $res['id'] . '">Подробнее &rArr;</a>';
и такую для news
echo '<a href="http://www.site.ru/article/index.php?id=' . $res['id'] . '">Подробнее &rArr;</a>';
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
16.08.2013, 11:43
Цитата Сообщение от jDeuterium Посмотреть сообщение
cygapb-007, спасибо попробую, а как ссылку потом вывести
такую для voset
echo '<a href="http://www.site.ru/sovet/index.php?id=' . $res['id'] . '">Подробнее &rArr;</a>';
и такую для news
echo '<a href="http://www.site.ru/article/index.php?id=' . $res['id'] . '">Подробнее &rArr;</a>';
Проанализировать значение (сгенерированного) поля IS_NEWS
0
1 / 1 / 0
Регистрация: 08.01.2013
Сообщений: 63
16.08.2013, 12:03  [ТС]
cygapb-007, условие if($total) не выполняется, сразу выходит на
PHP
1
2
3
else {
        echo '<p>По Вашему запросу ничего не найдено</p>';
    }
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
16.08.2013, 12:12
jDeuterium, так естественно, во временной таблице в первом поле любой строки общее количество строк в таблице, за счет этого и сокращается почти в два раза время обработки

Добавлено через 6 минут
то есть строки 2,3,4 не нужны, вместо этого сразу получаем все строки итога с подсчитанным уже количеством строк.

Пожалуй, используйте первый вариант, не изменяя ничего в PHP. Дольше, зато проще
0
1 / 1 / 0
Регистрация: 08.01.2013
Сообщений: 63
16.08.2013, 12:20  [ТС]
cygapb-007, первый это который мой?
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
16.08.2013, 13:22
не, который
MySQL
1
2
3
4
5
6
SELECT * 
FROM (
  select 0 `is_news`,`id`,`zagolovok`,`text`,`time` from `sovet` WHERE MATCH ...
  union all
  select 1 `is_news`,`id`,`zagolovok`,`text`,`time` from `news`  WHERE MATCH ...
) as u
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.08.2013, 13:22
Помогаю со студенческими работами здесь

Запрос по двум таблицам
Здравствуйте, помогите пожалуйста составить запрос по двум таблицам, у них одинаковые (Id,name,number) и вычесть одинаковые name и...

SQL-запрос к двум таблицам
Коллеги, подскажите как правильно написать запрос к БД Access, чтобы из двух таблиц получить третью. Пример в прикрепленном файле. ...

Запрос по двум таблицам, подскажите!
Доброй ночи! Нуждаюсь в помощи по созданию запроса! Запрос: По каждом типу товара выдать самый дорогой товар. БД содержит две...

SQL запрос по двум таблицам
Помогите пжлста... есть две таблицы: Tabl1 ID| Point1 1| 5 1| 5 2| 3 2| 4 2| 7 и Tabl2

Select запрос к двум таблицам
Есть две таблицы table1, table2. В table1 есть три колонки: user_key, columns1, columns2. Во второй таблице есть только user_key и...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru