29 / 23 / 2
Регистрация: 14.04.2009
Сообщений: 448
|
||||||
1 | ||||||
Нужно SQL-запросом вернуть самую последнюю добавленную запись24.09.2009, 11:35. Показов 14772. Ответов 13
Метки нет (Все метки)
Нужно SQL-запросом вернуть самую последнюю добавленную запись. Такой вариант нормальный?
0
|
24.09.2009, 11:35 | |
Ответы с готовыми решениями:
13
SQL Server Compact Framework. Как получить из базы данных последнюю добавленную запись в таблицу Получить самую последнюю запись (по дате) Как вывести самую последнюю запись при реляции HasMany Как вывести самую последнюю запись при реляции HasMany |
Айхрень...
306 / 176 / 7
Регистрация: 02.06.2009
Сообщений: 1,077
|
|
24.09.2009, 11:47 | 2 |
rar14, Если вы используете пхп, то там есть уже встроенная функция получения последнего вставленного идентификатора, если мне не изменяет память, в общем вам сюда http://www.php.net/
0
|
Почетный модератор
11531 / 4325 / 449
Регистрация: 12.06.2008
Сообщений: 12,428
|
||||||
24.09.2009, 17:18 | 3 | |||||
#Мессир, mysql_insert_id() В качестве параметра передаётся ресурс подключения к серверу (но не ресурс запроса)... в общем, то, что возвращается функцией mysql_connect
Либо можно воспользоваться SQL запросом
rar14, твой вариант можно использовать только если с таблицей в один момент времени работает только одно приложение. Иначе может получиться ситуация, что пока ты SELECT'ом узнаёшь максимальный id, за это время уже может добавиться ещё одна запись... и тогда SELECT вернёт уже второй id.
2
|
29 / 23 / 2
Регистрация: 14.04.2009
Сообщений: 448
|
|
24.09.2009, 19:23 [ТС] | 4 |
Humanoid, дело в том, что для каждого сеанса чата у меня будет создаваться своя таблица, куда будут записываться все сообщения этого чата, допустим в таблицу типа MEMORY. Она потом должна сохраняться в БД как история чата. Чатов может быть инициировано одновременно много. По сути, каждый чат с ботом или с консультантом (консультант может подменить бота), это отдельная таблица, по этому, самой последней записью (клиент пишет -> ajax'ом его сообщение записывается в таблицу типа MEMORY -> сообщение возвращается в окно чата с ответом от бота или консультанта (может быть чуть-позже)) будет и самое последнее сообщение, никто же с этой таблице больше не работает, у каждого своя таблица. Потом, после сеанса, таблицу MEMORY нужно записать в таблицу, допустим типа MyISAM на диск в БД, для истории.
0
|
Почетный модератор
11531 / 4325 / 449
Регистрация: 12.06.2008
Сообщений: 12,428
|
|
24.09.2009, 19:41 | 5 |
Всё равно лучше использовать mysql_insert_id(), т.к. человек может очень быстро два раза энтер нажать и два сообщения могут записаться примерно в одно время. Конечно вряд ли получиться отправить одному человеку два сообщения так быстро, что они будут заноситься в таблицу друг за другом без задержки... ну лучше не рисковать.
0
|
Paulie
|
24.09.2009, 20:10
#6
|
Не по теме: Humanoid, риск - благородное дело 8-)
0
|
Humanoid
|
24.09.2009, 20:15
#7
|
Не по теме: #Мессир, но не в программировании :) От таких рисков все глюки и тянутся. Потом замучаешься искать ошибку.
0
|
29 / 23 / 2
Регистрация: 14.04.2009
Сообщений: 448
|
|
24.09.2009, 20:56 [ТС] | 8 |
Но это последний ID из подключения? А если он отправит запрос, запрос сохранится, а до команды выбора последнего ID кто-то в другую таблицу вставит. И получится, что не тот ID вернется...
0
|
Почетный модератор
11531 / 4325 / 449
Регистрация: 12.06.2008
Сообщений: 12,428
|
|
24.09.2009, 21:10 | 9 |
Сообщение от rar14
Сообщение от rar14
1
|
6 / 5 / 2
Регистрация: 08.11.2010
Сообщений: 192
|
|
23.11.2010, 12:41 | 10 |
думается лучше завести отдельную таблицу из одной строки и в нее писать каждый раз новое значение в одно и тоже поле, а потом вытаскивать когда нужно будет.
0
|
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 8
|
|
19.08.2014, 00:03 | 11 |
SELECT LAST_INSERT_ID(); - робит, но не прокатывает при нескольких юзерах (исходя из этого топика).
select mysql_insert_id(); - не робит по причине: Lookup Error - MySQL Database Error: FUNCTION ХХХ.mysql_insert_id does not exist А вот и правильный ответ, на сколько я понял (сори за ссылку на другой форум): [ссылка на форум] Перечитал тред, понял, что я что-то недопонял возможно, но все равно, там несколько понятнее описано, ИМХО.
0
|
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 8
|
|
19.08.2014, 17:31 | 13 |
И чем она отличается от SELECT LAST_INSERT_ID(); ??? Есть у меня чуйка, что именно этот запрос и реализован внутри этой функции.
0
|
Почетный модератор
11531 / 4325 / 449
Регистрация: 12.06.2008
Сообщений: 12,428
|
|
20.08.2014, 08:16 | 14 |
Не знаю... но похоже, ничем. Вначале переживал, что вдруг при много пользовательском режиме будут проблемы... но когда попробовал, оказалось, что работает правильно. Т.е. открыл два подключения, добавил строку из одного подключения, потом из второго, а потом из первого запросил SELECT LAST_INSERT_ID() и получил "1", а из второго получил "2".
Единственное, mysql_insert_id() удобнее, т.к. не надо делать query, а потом fetch... тут просто одна функция, которая сразу возвращает число. Но LAST_INSERT_ID() можно использовать прямо в запросах (например, для изменения строки после её добавления). Так же, в документации сказано, что mysql_insert_id() возвращает значение только после INSERT или UPDATE, в то время как LAST_INSERT_ID() может после некоторых SELECT вернуть значение... но примера не нашёл.
0
|
20.08.2014, 08:16 | |
20.08.2014, 08:16 | |
Помогаю со студенческими работами здесь
14
Есть ли какой-то способ определить самую последнюю по времени создания, запись в реестр? Как с помощью запроса вернуть последнюю запись таблицы Как выделить строку в БД добавленную запросом? Удалить у числа две цифры - самую первую и самую последнюю Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи | |||||
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке
В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
|
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
|
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins
В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
|
Как написать микросервис на Go/Golang с Kafka и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang
Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
|
Как написать микросервис с нуля на C# с RabbitMQ, CQRS и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
|
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
|
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
|
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
|
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента!
4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве).
Первое вводное занятие. . .
|
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
|
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений
Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
|
Это работает. Скорость асинхронной логики велика. Вопрос видимо останется в стабильности. Плата - огонь!
Hrethgir 13.01.2025
По прошлому проекту в Logisim Evolution https:/ / www. cyberforum. ru/ blogs/ 223907/ blog8781. html прилагаю файл архива проекта в Gowin Eda. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
|