С Новым годом! Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/82: Рейтинг темы: голосов - 82, средняя оценка - 4.71
29 / 23 / 2
Регистрация: 14.04.2009
Сообщений: 448

Нужно SQL-запросом вернуть самую последнюю добавленную запись

24.09.2009, 11:35. Показов 15170. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно SQL-запросом вернуть самую последнюю добавленную запись. Такой вариант нормальный?
SQL
1
SELECT `message`, `reply` FROM `chat` WHERE `id` = (SELECT MAX(`id`) FROM `chat`);
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.09.2009, 11:35
Ответы с готовыми решениями:

SQL Server Compact Framework. Как получить из базы данных последнюю добавленную запись в таблицу
Так не работает. Вообще исключение появляется, что не знает SQL такой функции internal мщшв GetLastEventNumber() { ...

Получить самую последнюю запись (по дате)
Здравствуйте. Подскажите, как получить из таблицы SomeSnapshot записи, которые были добавлены в таблицу за самую последнюю дату? ...

Как вывести самую последнюю запись при реляции HasMany
в таблице Таскс хранятся Задачи, в таблице Таймс хранятся время их выполнения. Ранее для одной Задачи хранилось только одно время...

13
Айхрень...
 Аватар для Paulie
306 / 176 / 7
Регистрация: 02.06.2009
Сообщений: 1,077
24.09.2009, 11:47
rar14, Если вы используете пхп, то там есть уже встроенная функция получения последнего вставленного идентификатора, если мне не изменяет память, в общем вам сюда http://www.php.net/
0
Почетный модератор
 Аватар для Humanoid
11554 / 4349 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
24.09.2009, 17:18
#Мессир, mysql_insert_id() В качестве параметра передаётся ресурс подключения к серверу (но не ресурс запроса)... в общем, то, что возвращается функцией mysql_connect
Либо можно воспользоваться SQL запросом
SQL
1
SELECT LAST_INSERT_ID();
(запрос нужно делать без отключения от сервера... сразу после добавления строки). Но лично я предпочитаю mysql_insert_id()

rar14, твой вариант можно использовать только если с таблицей в один момент времени работает только одно приложение. Иначе может получиться ситуация, что пока ты SELECT'ом узнаёшь максимальный id, за это время уже может добавиться ещё одна запись... и тогда SELECT вернёт уже второй id.
2
29 / 23 / 2
Регистрация: 14.04.2009
Сообщений: 448
24.09.2009, 19:23  [ТС]
Humanoid, дело в том, что для каждого сеанса чата у меня будет создаваться своя таблица, куда будут записываться все сообщения этого чата, допустим в таблицу типа MEMORY. Она потом должна сохраняться в БД как история чата. Чатов может быть инициировано одновременно много. По сути, каждый чат с ботом или с консультантом (консультант может подменить бота), это отдельная таблица, по этому, самой последней записью (клиент пишет -> ajax'ом его сообщение записывается в таблицу типа MEMORY -> сообщение возвращается в окно чата с ответом от бота или консультанта (может быть чуть-позже)) будет и самое последнее сообщение, никто же с этой таблице больше не работает, у каждого своя таблица. Потом, после сеанса, таблицу MEMORY нужно записать в таблицу, допустим типа MyISAM на диск в БД, для истории.
0
Почетный модератор
 Аватар для Humanoid
11554 / 4349 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
24.09.2009, 19:41
Всё равно лучше использовать mysql_insert_id(), т.к. человек может очень быстро два раза энтер нажать и два сообщения могут записаться примерно в одно время. Конечно вряд ли получиться отправить одному человеку два сообщения так быстро, что они будут заноситься в таблицу друг за другом без задержки... ну лучше не рисковать.
0
24.09.2009, 20:10

Не по теме:

Humanoid, риск - благородное дело 8-)

0
24.09.2009, 20:15

Не по теме:

#Мессир, но не в программировании :) От таких рисков все глюки и тянутся. Потом замучаешься искать ошибку.

0
29 / 23 / 2
Регистрация: 14.04.2009
Сообщений: 448
24.09.2009, 20:56  [ТС]
Цитата Сообщение от Humanoid Посмотреть сообщение
Всё равно лучше использовать mysql_insert_id(), т.к. человек может очень быстро два раза энтер нажать и два сообщения могут записаться примерно в одно время. Конечно вряд ли получиться отправить одному человеку два сообщения так быстро, что они будут заноситься в таблицу друг за другом без задержки... ну лучше не рисковать.
Но это последний ID из подключения? А если он отправит запрос, запрос сохранится, а до команды выбора последнего ID кто-то в другую таблицу вставит. И получится, что не тот ID вернется...
0
Почетный модератор
 Аватар для Humanoid
11554 / 4349 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
24.09.2009, 21:10
Цитата Сообщение от rar14
Но это последний ID из подключения?
Да
Цитата Сообщение от rar14
А если он отправит запрос, запрос сохранится, а до команды выбора последнего ID кто-то в другую таблицу вставит.
Это будет в другом подключении. Пока выполняется твой PHP скрипт, то это подключение к мусклу никто тронуть не сможет. Для другого обращения к скрипту будет открыто новое подключение к мусклу.
1
 Аватар для javasc
6 / 5 / 2
Регистрация: 08.11.2010
Сообщений: 192
23.11.2010, 12:41
думается лучше завести отдельную таблицу из одной строки и в нее писать каждый раз новое значение в одно и тоже поле, а потом вытаскивать когда нужно будет.
0
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 8
19.08.2014, 00:03
SELECT LAST_INSERT_ID(); - робит, но не прокатывает при нескольких юзерах (исходя из этого топика).
select mysql_insert_id(); - не робит по причине:
Lookup Error - MySQL Database Error: FUNCTION ХХХ.mysql_insert_id does not exist

А вот и правильный ответ, на сколько я понял (сори за ссылку на другой форум):
[ссылка на форум]

Перечитал тред, понял, что я что-то недопонял возможно, но все равно, там несколько понятнее описано, ИМХО.
0
Почетный модератор
 Аватар для Humanoid
11554 / 4349 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
19.08.2014, 08:19
Цитата Сообщение от podkashey Посмотреть сообщение
select mysql_insert_id(); - не робит по причине:
Lookup Error - MySQL Database Error: FUNCTION ХХХ.mysql_insert_id does not exist
mysql_insert_id() - это функция PHP или C. Её не надо в качестве запроса передавать.
0
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 8
19.08.2014, 17:31
И чем она отличается от SELECT LAST_INSERT_ID(); ??? Есть у меня чуйка, что именно этот запрос и реализован внутри этой функции.
0
Почетный модератор
 Аватар для Humanoid
11554 / 4349 / 452
Регистрация: 12.06.2008
Сообщений: 12,453
20.08.2014, 08:16
Цитата Сообщение от podkashey Посмотреть сообщение
И чем она отличается от SELECT LAST_INSERT_ID(); ???
Не знаю... но похоже, ничем. Вначале переживал, что вдруг при много пользовательском режиме будут проблемы... но когда попробовал, оказалось, что работает правильно. Т.е. открыл два подключения, добавил строку из одного подключения, потом из второго, а потом из первого запросил SELECT LAST_INSERT_ID() и получил "1", а из второго получил "2".
Единственное, mysql_insert_id() удобнее, т.к. не надо делать query, а потом fetch... тут просто одна функция, которая сразу возвращает число. Но LAST_INSERT_ID() можно использовать прямо в запросах (например, для изменения строки после её добавления).
Так же, в документации сказано, что mysql_insert_id() возвращает значение только после INSERT или UPDATE, в то время как LAST_INSERT_ID() может после некоторых SELECT вернуть значение... но примера не нашёл.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.08.2014, 08:16
Помогаю со студенческими работами здесь

Как вывести самую последнюю запись при реляции HasMany
в таблице Таскс хранятся Задачи, в таблице Таймс хранятся время их выполнения. Ранее для одной Задачи хранилось только одно время...

Есть ли какой-то способ определить самую последнюю по времени создания, запись в реестр?
Понимаю, что в реестр пишется постоянно. Но мне не нужна точность до секунд и минут. Так-же понимаю, что у "добросовестных"...

Как с помощью запроса вернуть последнюю запись таблицы
Добрый день всем! Расскажите, плиз, как с помощью SELECT вернуть последнюю запись в таблице? Только её одну

Как выделить строку в БД добавленную запросом?
Здравствуйте, у меня есть код ADOQuery1->Close(); ADOQuery1->SQL->Clear(); ADOQuery1->SQL->Text = "INSERT INTO...

Удалить у числа две цифры - самую первую и самую последнюю
здравствуйте! почти сделал программу, позволяющая убирать у числа две цифры-самую первую и самую последнюю. но никак не могу сделать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru