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

Форум MySQL

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

 

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

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

тема: постраничный вывод в MSSQL'е
 
 автор: V1a8xerss87   (13.07.2009 в 11:13)   письмо автору
 
 

Собственно имеется следующий код:

$query_Goods=mssql_query("SELECT DISTINCT id_city,id_firm,id_subgroup,publish FROM Price WHERE id_subgroup=".$id_subgroup." AND publish=1 AND id_city=48") or die("error in goods query");
$num_goods=mssql_num_rows($query_Goods);
if(mssql_num_rows($query_Goods)>0)
{
while($Goods=mssql_fetch_row($query_Goods))
{
//выводим содержимое таблички
}
}

Вот как бы к нему прикрутить постраничную навигацию. Было бы в MySQL все через Limit сделал бы, а вот с MSSQL плоховато дружу.
Заранее большое спасибо за ответы.

  Ответить  
 
 автор: Trianon   (13.07.2009 в 18:57)   письмо автору
 
   для: V1a8xerss87   (13.07.2009 в 11:13)
 

mssql_data_seek()

  Ответить  
 
 автор: V1a8xerss87   (14.07.2009 в 14:54)   письмо автору
 
   для: Trianon   (13.07.2009 в 18:57)
 

А можно поподробней?

  Ответить  
 
 автор: Trianon   (14.07.2009 в 14:58)   письмо автору
 
   для: V1a8xerss87   (14.07.2009 в 14:54)
 

В мануале какие-то непонятные места?
спрашивайте.

  Ответить  
 
 автор: V1a8xerss87   (14.07.2009 в 15:36)   письмо автору
 
   для: Trianon   (14.07.2009 в 14:58)
 


mssql_data_seek() перемещает внутренний указатель ряда MS SQL-результата, ассоциированного со специфицированным идентификатором результата, указывающего на специфицированный номер ряда. Последующий вызов mssql_fetch_row() должен возвратить этот ряд.

Не очень ясен смысл этой фразы :) Расшифруйте пожалуйста

  Ответить  
 
 автор: Trianon   (14.07.2009 в 15:46)   письмо автору
 
   для: V1a8xerss87   (14.07.2009 в 15:36)
 

Вы указываете, начиная с какой строки читать результат.

[horisontal scrolling ЛАП on]

  Ответить  
 
 автор: ols   (14.07.2009 в 17:47)   письмо автору
 
   для: Trianon   (14.07.2009 в 15:46)
 

В MS SQL нет оператора limit? MySQL рулит))))

  Ответить  
 
 автор: Root   (14.07.2009 в 17:56)   письмо автору
 
   для: ols   (14.07.2009 в 17:47)
 

В MSSQL есть оператор SET ROWCOUNT, который "заменяет" LIMIT, а вот с OFFSET приходится играться, хотя и там по большому счёту проблем нет.

  Ответить  
 
 автор: Trianon   (14.07.2009 в 18:24)   письмо автору
 
   для: ols   (14.07.2009 в 17:47)
 

Ничего, что в ORACLE тоже этого оператора нет?

  Ответить  
 
 автор: Евгений Петров   (15.07.2009 в 00:51)   письмо автору
 
   для: Trianon   (14.07.2009 в 18:24)
 

В MySQL offset реализован таким же образом. Выбираются все записи, а потом внутренний указатель перемещается в нужное место. К сожалению большинство об этом даже не догадывается. Наверное поэтому в MSSQL и Oracle этого нет.

  Ответить  
 
 автор: Trianon   (15.07.2009 в 00:59)   письмо автору
 
   для: Евгений Петров   (15.07.2009 в 00:51)
 

Таким да не таким...

Запрос mysql_query полностью буферизируется изначально.
Это значит, как минимум, что все выбранные записи будут переданы через клиент-серверное соединение. В MSSQL и Oracle это не так.

Впрочем, unbuffered query тоже существует. И тогда эти подробности становятся несущественными.

  Ответить  
 
 автор: Евгений Петров   (15.07.2009 в 01:43)   письмо автору
 
   для: Trianon   (15.07.2009 в 00:59)
 

Насколько я понимаю buffered и unbuffered query это особенности PHP а не MySQL. Либо он тянет данные с сервера либо не тянет, а количество данных остается одинаковым.

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

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