Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: ссылки предыдущий и следующий

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: работа с mysql
LEONeso
Отправлено: 07 Ноября, 2010 - 13:14:45
Post Id



Посетитель


Покинул форум
Сообщений всего: 499
Дата рег-ции: Янв. 2010  
Откуда: Россия, Москва


Помог: 1 раз(а)




Здравствуйте, не могу понять как делают ссылки на записи в БД, если на данный момент открыта допустим запись с id 52, а рядом стоят 48 и 55.

графический пример:
48 < назад | я запись с id 52 |вперед > 55


id записи 52 уже известна (где 52 любая другая id)


-----
Для некоторых лучший способ написать что-нибудь осмысленное - это сесть _опой на клавиатуру.
 
 Top
OrmaJever Модератор
Отправлено: 07 Ноября, 2010 - 13:23:40
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)






-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
LEONeso
Отправлено: 07 Ноября, 2010 - 13:44:21
Post Id



Посетитель


Покинул форум
Сообщений всего: 499
Дата рег-ции: Янв. 2010  
Откуда: Россия, Москва


Помог: 1 раз(а)




а что если значение страницы принимает md5, а не id?
все равно работать с id и выводить и подставлять md5 в href?


-----
Для некоторых лучший способ написать что-нибудь осмысленное - это сесть _опой на клавиатуру.
 
 Top
OrmaJever Модератор
Отправлено: 07 Ноября, 2010 - 15:06:48
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




я не совсем понялзачем нужна такая схема
48 < назад | я запись с id 52 |вперед > 55


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
Uchkuma
Отправлено: 07 Ноября, 2010 - 15:19:10
Post Id



Участник


Покинул форум
Сообщений всего: 1539
Дата рег-ции: Март 2010  
Откуда: Киров


Помог: 6 раз(а)




 
 Top
LEONeso
Отправлено: 07 Ноября, 2010 - 17:35:40
Post Id



Посетитель


Покинул форум
Сообщений всего: 499
Дата рег-ции: Янв. 2010  
Откуда: Россия, Москва


Помог: 1 раз(а)




Uchkuma, спасибо, похоже - это то, что надо, осталось разобраться и попробовать.

OrmaJever,48 < назад | я запись с id 52 |вперед > 55
48 - id он в данном примере стоит перед 52, а меж ними больше нет id (допустим их удалили)
55 - id он в данном примере стоит после 52... т.д.
я запись с id 52 - это открытая страница (контент и т.п.)


-----
Для некоторых лучший способ написать что-нибудь осмысленное - это сесть _опой на клавиатуру.
 
 Top
Мелкий Супермодератор
Отправлено: 07 Ноября, 2010 - 17:47:21
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. SELECT `id` FROM `table` WHERE `id`>текущий_id ORDER BY `id` LIMIT 1 --следующая ближайшая запись
  2. UNION --дайте две!
  3. SELECT `id` FROM `table` WHERE `id`<текущий_id ORDER BY `id` DESC LIMIT 1 --предыдущая ближайшая запись

Предполагается, что id - обычное auto_increment поле, а не md5, что вверху мелькало.

(Отредактировано автором: 07 Ноября, 2010 - 17:49:22)



-----
PostgreSQL DBA
 
 Top
LEONeso
Отправлено: 07 Ноября, 2010 - 20:14:03
Post Id



Посетитель


Покинул форум
Сообщений всего: 499
Дата рег-ции: Янв. 2010  
Откуда: Россия, Москва


Помог: 1 раз(а)




Мелкий, да у каждой записи есть id auto_increment, но запись выводится с помощью md5, собственно если знать id, то вывести в ссылку md5 значение записи не составит труда.

Ваш пример тоже попробую. Спасибо.


-----
Для некоторых лучший способ написать что-нибудь осмысленное - это сесть _опой на клавиатуру.
 
 Top
LEONeso
Отправлено: 10 Ноября, 2010 - 12:33:54
Post Id



Посетитель


Покинул форум
Сообщений всего: 499
Дата рег-ции: Янв. 2010  
Откуда: Россия, Москва


Помог: 1 раз(а)




Мелкий, отлично работает, но есть одно НО при последней записи в БД по id он выводит первую запись в БД по id т.е. возвращает в начало, а не на запись перед действующей (активной).

Пример:
на странице запись с id 2 "далее >" запись с id3 "< назад" запись с id 1
клик на далее
на странице запись c id 3 "далее >" нет записи "< назад" запись с id 1 (должна быть id 2)

(Отредактировано автором: 10 Ноября, 2010 - 12:48:56)



-----
Для некоторых лучший способ написать что-нибудь осмысленное - это сесть _опой на клавиатуру.
 
 Top
Мелкий Супермодератор
Отправлено: 10 Ноября, 2010 - 13:47:27
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Воспроизвести ошибку не удалось. И в середине таблицы с пустым местом и на крайних значениях вернул запрос верный результат. Тестовый комплект такой:
CODE (SQL):
скопировать код в буфер обмена
  1. CREATE TABLE `test` (
  2.   `id` mediumint(9) NOT NULL AUTO_INCREMENT,
  3.   `name` varchar(255) collate utf8_unicode_ci NOT NULL,
  4.   PRIMARY KEY  (`id`)
  5. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=7 ;
  6.  
  7. INSERT INTO `test` (`id`, `name`) VALUES
  8. (1, 'fkf'),
  9. (2, 'hfdh'),
  10. (3, 'kjhljk'),
  11. (5, '769jhljh,kj'),
  12. (6, '765fgvbmj');
  13.  
  14. (SELECT `id` FROM `test` WHERE `id`>3 ORDER BY `id` LIMIT 1 )
  15. UNION
  16. (SELECT `id` FROM `test` WHERE `id`<3 ORDER BY `id` DESC LIMIT 1 )
  17. -- ответил как положено для этого набора данных: 2 и 5
  18. -- для 1 - одна строка 2, для 6 - вернул 5
  19. -- для отсутствующей записи с номером 4 ближайшие тоже нашли


Проверь сортировки в запросах, они должны обязательно смотреть в разные стороны и в соответствии с логикой условия: выбираем следующий раздел - найти минимальный id, предыдущий - максимальный. Но не равный текущему.

(Отредактировано автором: 10 Ноября, 2010 - 13:53:56)



-----
PostgreSQL DBA
 
 Top
Uchkuma
Отправлено: 10 Ноября, 2010 - 14:15:15
Post Id



Участник


Покинул форум
Сообщений всего: 1539
Дата рег-ции: Март 2010  
Откуда: Киров


Помог: 6 раз(а)




Мелкий, как в твоем варианте определить, относительно текущей записи (если она крайняя), предыдущей записи нет или следующей?
(Добавление)
Дотумкал. Можно же алиасы использовать:
CODE (SQL):
скопировать код в буфер обмена
  1. (SELECT id AS prev_id FROM test WHERE id<3 ORDER BY id DESC LIMIT 1 )
  2. UNION
  3. (SELECT id AS next_id FROM test WHERE id>3 ORDER BY id LIMIT 1 )
 
 Top
LEONeso
Отправлено: 13 Ноября, 2010 - 09:24:47
Post Id



Посетитель


Покинул форум
Сообщений всего: 499
Дата рег-ции: Янв. 2010  
Откуда: Россия, Москва


Помог: 1 раз(а)




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


-----
Для некоторых лучший способ написать что-нибудь осмысленное - это сесть _опой на клавиатуру.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB