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

Форум MySQL

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

 

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

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

тема: Получение минимального и максимального значений за один запрос
 
 автор: alek_chita   (18.02.2007 в 19:40)   письмо автору
 
 

Есть таблица в которой есть поля pos, image_id и hide. Нужно выяснить image_id с максимальным и минимальным pos у которого hide = 'show';

Я сделал так:


<?php
   $query 
"SELECT image_id as 'min', pos FROM images WHERE  hide = 'show' ORDER BY pos LIMIT 1";
    
$min_q mysql_query($query);
    if(
$min_q)    $min mysql_result($min_q0,  'min'); else exit(mysql_error());
    
$query "SELECT image_id as 'max', pos FROM images WHERE hide = 'show' ORDER BY pos DESC LIMIT 1";
    
$max_q mysql_query($query);
    if(
$max_q$max mysql_result($max_q0'max'); else exit(mysql_error());
        echo 
"min-".$min;
        echo 
"<br>max-".$max;
?>


Тут два обращения к бд. Можно ли получить те же результаты более изящным способом?

   
 
 автор: alek_chita   (20.02.2007 в 14:13)   письмо автору
 
   для: alek_chita   (18.02.2007 в 19:40)
 

Может и нельзя сделать лучше??

   
 
 автор: cheops   (20.02.2007 в 16:14)   письмо автору
 
   для: alek_chita   (18.02.2007 в 19:40)
 

Можно поступить следующим образом
SELECT MIN(image_id) as 'min', MAX(image_id) as 'max' FROM images WHERE  hide = 'show'

Это если вам никакие больше поля не нужны, если поле pos обязательно, лучше остановиться на вашем варианте.

   
Rambler's Top100
вверх

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