Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: SELECT по двум таблицам сразу
 
 автор: Udachix   (28.04.2013 в 17:53)   письмо автору
 
 

Таблица table1:
id | table2_id | name

Таблица table2:
id | limit

mysql_query ( ' SELECT * FROM `table1` WHERE `id` = "'.$id.'" AND `limit` >= "'.$limit.'" ' );

Нужно перестроить этот запрос так, чтобы limit брался не из table1, а из table2.
Покажите как это сделать, пожалуйста.

  Ответить  
 
 автор: Sfinks   (29.04.2013 в 10:40)   письмо автору
 
   для: Udachix   (28.04.2013 в 17:53)
 

SELECT *
FROM table1
JOIN table2 ON table2_id=table2.id
WHERE table1.id=1232938 AND `limit` >= 12

  Ответить  
 
 автор: Udachix   (30.04.2013 в 14:44)   письмо автору
 
   для: Sfinks   (29.04.2013 в 10:40)
 

То есть после JOIN все поля становятся по умолчанию от таблицы 2, а от первой нужно уже наоборот указывать, что они от первой?

  Ответить  
 
 автор: Valick   (30.04.2013 в 15:43)   письмо автору
 
   для: Udachix   (30.04.2013 в 14:44)
 

нет, везде надо указывать кто чья таблица, тем более если имена полей в них идентичны, но лучше всегда явно указывать, так нагляднее и сильно сократит время поиска ошибки.

  Ответить  
 
 автор: Udachix   (03.05.2013 в 12:40)   письмо автору
 
   для: Valick   (30.04.2013 в 15:43)
 

Так, согласно Вашему учению делаю практический вывод:
mysql_query ( ' SELECT * FROM `table1` JOIN `table2` ON `table1.table2_id` = `table2.id` WHERE `table1.id` = "'.$id.'" AND `table2.limit` >= "'.$limit.'" ' );
Всё правильно по синтаксису и принципу?

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования