Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Сообщения за день
 

Вернуться   Форум Flasher.ru > Архив Flasher.ru > Программирование > Базы данных

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему  
Старый 17.06.2002, 16:13
Несс вне форума Посмотреть профиль Отправить личное сообщение для Несс Посетить домашнюю страницу Несс Найти все сообщения от Несс
  № 1  
Несс

Регистрация: Jun 2002
Адрес: Тель-Авив
Сообщений: 27
Отправить сообщение для Несс с помощью ICQ
Question Правильное написание

Как правильно написать SQL код для того что бы достать из базы данных 5 последних записей?

Код:
Select TOP 5 from Table ORDER BY id DESC
выдаёт ошибку:

The SELECT statement includes a reserved word or an argument name that is misspelled or missing, or the punctuation is incorrect.

Старый 17.06.2002, 17:56
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 2  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Для MySQL (если понимать под "последними" тк, что стоят в конце списка при указанной тобой сортировке):

Код:
Select * from Table ORDER BY id DESC LIMIT 5
Только учти -- они придут к тебе в обратном порядке.
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++


Последний раз редактировалось Crazy; 17.06.2002 в 17:57.
Старый 17.06.2002, 18:22
Несс вне форума Посмотреть профиль Отправить личное сообщение для Несс Посетить домашнюю страницу Несс Найти все сообщения от Несс
  № 3  
Несс

Регистрация: Jun 2002
Адрес: Тель-Авив
Сообщений: 27
Отправить сообщение для Несс с помощью ICQ
А он вот что отвечает

Код:
Syntax error in ORDER BY clause

Старый 17.06.2002, 18:26
Несс вне форума Посмотреть профиль Отправить личное сообщение для Несс Посетить домашнюю страницу Несс Найти все сообщения от Несс
  № 4  
Несс

Регистрация: Jun 2002
Адрес: Тель-Авив
Сообщений: 27
Отправить сообщение для Несс с помощью ICQ
А вот если так написать:

Код:
Select LIMIT 5 from Table ORDER BY id DESC
то говорит:
Syntax error (missing operator) in query expression 'LIMIT 5'.

Старый 17.06.2002, 19:04
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 5  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
БД у тебя какая? Мой пример -- только для MySQL, Привожу полный тест:

Код:
mysql> create table qqq (id int);
Query OK, 0 rows affected (0.05 sec)

mysql> insert into qqq(id) values(1),(2),(3),(4),(5),(6),(7),(8),(9);
Query OK, 9 rows affected (0.03 sec)
Records: 9  Duplicates: 0  Warnings: 0

mysql> select * from qqq order by id desc limit 5;
+------+
| id   |
+------+
|    9 |
|    8 |
|    7 |
|    6 |
|    5 |
+------+
5 rows in set (0.01 sec)
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 17.06.2002, 19:39
Несс вне форума Посмотреть профиль Отправить личное сообщение для Несс Посетить домашнюю страницу Несс Найти все сообщения от Несс
  № 6  
Несс

Регистрация: Jun 2002
Адрес: Тель-Авив
Сообщений: 27
Отправить сообщение для Несс с помощью ICQ
Не обратила внимания вначале. У меня экселевская, простенькая.

Старый 17.06.2002, 19:55
Crazy вне форума Посмотреть профиль Отправить личное сообщение для Crazy Посетить домашнюю страницу Crazy Найти все сообщения от Crazy
  № 7  
Crazy
[+1 23.05.11]
 
Аватар для Crazy

Регистрация: Dec 2001
Сообщений: 4,159
Увы, требуемая тебе операция относится к нестандартным расширениям SQL. В каждом случае это делается по-своему. Увы, с excel я таким способом никогда не общался.

Таблица очень велика? Полная выборка очень обременительна?
__________________
GIT d++ s++:++ a C++$ UB++ P++ L+ E+ W+++ N++ w++ O+ M V- t-- 5-- X+ R+++ tv- b+++ D++

Старый 17.06.2002, 20:17
Несс вне форума Посмотреть профиль Отправить личное сообщение для Несс Посетить домашнюю страницу Несс Найти все сообщения от Несс
  № 8  
Несс

Регистрация: Jun 2002
Адрес: Тель-Авив
Сообщений: 27
Отправить сообщение для Несс с помощью ICQ
Пока что невелика, но постоянно пополняется.
Есть такая штука - TOP, а после него число, но нигде не могу найти конкретного примера написания...

Старый 17.06.2002, 22:55
sapenov вне форума Посмотреть профиль Отправить личное сообщение для sapenov Посетить домашнюю страницу sapenov Найти все сообщения от sapenov
  № 9  
sapenov

Регистрация: Feb 2001
Адрес: Canada, Toronto
Сообщений: 167
TOP это из MSSQL (T-SQL - не самая лучшая разновидность языка). Именно этот оператор и есть слабое место у MS.

Насколько я понял у тебя есть файловая база данных в таблице Excel.
При чем же здесь MySQL ?

Сохрани таблицу как CSV или TDT (excel.txt), затем заполни таблицу MySQL данными из этого файла.

mysql> LOAD DATA LOCAL INFILE "excel.txt" INTO TABLE hecc;

ps.
по умолчанию используются разделители tab и linefeed
__________________
Кто смел - тот цел.

http://www.php.kz/


Последний раз редактировалось sapenov; 17.06.2002 в 22:57.
Старый 18.06.2002, 11:31
Несс вне форума Посмотреть профиль Отправить личное сообщение для Несс Посетить домашнюю страницу Несс Найти все сообщения от Несс
  № 10  
Несс

Регистрация: Jun 2002
Адрес: Тель-Авив
Сообщений: 27
Отправить сообщение для Несс с помощью ICQ
Спасибо за совет, но программер из меня никудышный и переделывать таблицу я не буду. Всего-то навсего имеется маленькая база данных. Сделана она не в Exelе (как я написала ранее), а в Accessе. Она постоянно пополняется и нужно выводить из неё 5 последних записей. Год назад я написала этот код, но добрые люди его стёрли, а сама из-за отсутствия опыта забыла и восстановить не могу. Вот.

Создать новую тему   Часовой пояс GMT +4, время: 17:56.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 17:56.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.