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

Форум MySQL

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

 

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

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

тема: В чем разница двух запросов
 
 автор: Roma   (24.07.2007 в 17:17)   письмо автору
 
 

Привет всем!!!
Имеюся две таблицы object и hidden_object с одинаковыми полями id и id_author
Мне надо выбрать минимальный id с обеих таблиц
Подскажите пожалуйста в чем разница этих двух запросов:

$query="SELECT id FROM object WHERE id_author='".$_SESSION['author']."' LIMIT 0,1 UNION 
SELECT id FROM hidden_object WHERE id_author='".$_SESSION['author']."' ORDER BY id ASC LIMIT 0,1";

и

$query="SELECT src.id FROM ".
                     "(SELECT id FROM object WHERE id_realtor='".$_SESSION['realtor']."' LIMIT 0,1 ".
                    "UNION SELECT id FROM hidden_object WHERE id_realtor='".$_SESSION['realtor']."' ". 
                    "ORDER BY id ASC LIMIT 0,1) as src    ORDER BY id ASC LIMIT 0,1";

Заранее спасибо

   
 
 автор: Vertex   (24.07.2007 в 17:37)   письмо автору
 
   для: Roma   (24.07.2007 в 17:17)
 

во втором запросе у тебя используется алиас, то есть запрос к нескольким таблицам с помощью ключевого слова AS объединяется в один выведется результат в одно поле src. Вобщем я понимаю в чё разница, но объяснить только так могу=)

   
 
 автор: Trianon   (24.07.2007 в 18:56)   письмо автору
 
   для: Roma   (24.07.2007 в 17:17)
 

Могу написать, что в них общего. В обоих ошибки.
В частности инструкция LIMIT действует не на SELECT а на результат. И пишется ОДИН раз на вызов.

   
 
 автор: Roma   (24.07.2007 в 19:09)   письмо автору
 
   для: Trianon   (24.07.2007 в 18:56)
 

А так тоже не правильно:

$query="SELECT id FROM object WHERE id_author='".$_SESSION['author']."' UNION 
SELECT id FROM hidden_object WHERE id_author='".$_SESSION['author']."' ORDER BY id ASC LIMIT 0,1";

//и

$query="SELECT src.id FROM  (SELECT id FROM object WHERE id_author='".$_SESSION['author']."' UNION 
SELECT id FROM hidden_object WHERE id_author='".$_SESSION['author']."' ) as src    ORDER BY id ASC 
LIMIT 0,1"; 

   
 
 автор: Trianon   (24.07.2007 в 19:10)   письмо автору
 
   для: Roma   (24.07.2007 в 19:09)
 

Конечно.

Для извлечения минимального значения существует агрегатная функция MIN()

   
 
 автор: Roma   (24.07.2007 в 20:46)   письмо автору
 
   для: Trianon   (24.07.2007 в 19:10)
 

а не могли бы вы показать как сделать правильно?

   
 
 автор: Trianon   (24.07.2007 в 21:00)   письмо автору
 
   для: Roma   (24.07.2007 в 20:46)
 

Правильно независимые минимумы разных таблиц получать двумя независимыми запросами.

   
 
 автор: oradev   (24.07.2007 в 20:44)   письмо автору
 
   для: Roma   (24.07.2007 в 19:09)
 


SELECT id FROM object 
WHERE id = 
                    (  SELECT MIN(id) 
                        FROM object );

   
 
 автор: Roma   (24.07.2007 в 20:54)   письмо автору
 
   для: oradev   (24.07.2007 в 20:44)
 

А в случае с двумя таблицами?
Это тоже не верно

$query="SELECT MIN(src.id) FROM  (SELECT MIN(id) FROM object WHERE id_author='".$_SESSION['author']."' UNION 
SELECT MIN(id) FROM hidden_object WHERE id_author='".$_SESSION['author']."' ) as src "; 

   
 
 автор: oradev   (24.07.2007 в 21:14)   письмо автору
 
   для: Roma   (24.07.2007 в 20:54)
 

Ну на ваш стиль:


SELECT o.min_value FROM (SELECT MIN(id) as min_value FROM object) o;



А вообще все проще:


SELECT MIN(id) as min_value FROM object


Также сделаете 2-ой запрос и UNION между ними

   
 
 автор: Trianon   (24.07.2007 в 20:58)   письмо автору
 
   для: oradev   (24.07.2007 в 20:44)
 

о да... ))


SELECT MIN(id)  
  FROM object 

   
Rambler's Top100
вверх

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