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

Форум MySQL

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

 

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

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

тема: как выбрать последние строки из базы данных
 
 автор: ren   (17.07.2008 в 02:21)   письмо автору
 
 

Здравствуйте, какие запросом можно выбрать произвольное число строк из нужного места в бд, к примеру, 50 последних записей???

   
 
 автор: cheops   (17.07.2008 в 02:49)   письмо автору
 
   для: ren   (17.07.2008 в 02:21)
 

По какому критерию записи считаются последними? Имеется ли поле с атрибутом AUTO_INCREMENT или поле с датой и временем, куда заносится дата создания записи?

   
 
 автор: ren   (17.07.2008 в 09:17)   письмо автору
 
   для: cheops   (17.07.2008 в 02:49)
 

есть таблица поля: id - auto_increment, field1 - integer, field2 - varchar поле field1 может принимать произвольные целочисленные значения, нужно выбрать 1 запрос: 50 последних записей( т. е . 50 последних по id), и 2 запрос: 50 наибольших по полю field1.

   
 
 автор: GeorgeIV   (17.07.2008 в 10:01)   письмо автору
 
   для: ren   (17.07.2008 в 09:17)
 

order by поле desc - отсортирует по нужному полю с убыванием (максимальные записи будут первыми),
limit 50 - отсечет 50 записей

   
 
 автор: ren   (17.07.2008 в 11:37)   письмо автору
 
   для: GeorgeIV   (17.07.2008 в 10:01)
 

Спасибо, а можно как нибудь по другому??

   
 
 автор: GeorgeIV   (17.07.2008 в 11:48)   письмо автору
 
   для: ren   (17.07.2008 в 11:37)
 

а куда проще? что не устаривает?

   
 
 автор: ren   (18.07.2008 в 12:26)   письмо автору
 
   для: GeorgeIV   (17.07.2008 в 11:48)
 

просто к полученному запросу я добавляю LIMIT $start,$end для постраничной навигации...

   
 
 автор: GeorgeIV   (18.07.2008 в 13:00)   письмо автору
 
   для: ren   (18.07.2008 в 12:26)
 

а что мешает ограничить end до 50?

   
 
 автор: ren   (18.07.2008 в 13:17)   письмо автору
 
   для: GeorgeIV   (18.07.2008 в 13:00)
 

запрос выбирает 50 записей к примеру
SELECT * FROM table ORDER BY field1 DESC LIMIT 50

а на страницу я вывожу по 10 записей, то есть нужно добавить
LIMIT 0,10 для 1й страницы, LIMIT 10, 20 для 2й и т. д.
а так ведь нельзя:
(SELECT * FROM table ORDER BY field1 DESC LIMIT 50)  LIMIT 0, 10

не получается =(

   
 
 автор: GeorgeIV   (18.07.2008 в 13:35)   письмо автору
 
   для: ren   (18.07.2008 в 13:17)
 

а зачем?
как дойдешь до
SELECT * FROM table ORDER BY field1 DESC LIMIT 40, 50

так и останавливайся

используй переменные в запросе и анализируй их

   
 
 автор: Trianon   (18.07.2008 в 13:46)   письмо автору
 
   для: GeorgeIV   (18.07.2008 в 13:35)
 

LIMIT 40, 50 - это строки с 40-й по 89-ю.

   
 
 автор: GeorgeIV   (18.07.2008 в 13:57)   письмо автору
 
   для: Trianon   (18.07.2008 в 13:46)
 

виноват-с, уже год с мускуло не работаю, забываю :-)
тогда LIMIT 40, 10 и на этом конец

   
 
 автор: ren   (18.07.2008 в 14:49)   письмо автору
 
   для: GeorgeIV   (18.07.2008 в 13:57)
 

спасибо, разобрался

   
Rambler's Top100
вверх

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