Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
2 / 2 / 0
Регистрация: 11.09.2023
Сообщений: 193

Id последней записи MYSQL

30.11.2023, 09:18. Показов 741. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Id последней записи MYSQL.
Я ознакомелся с функцией LAST_INSERT_ID тут https://oracleplsql.ru/mysql-f... g160486184

Написал то что написано ниже и оно работает. Как видно я сначало вставляю запись через CommandText а потом юзаю
SQL.

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
function AddToolInZayavka(IdZayavka: Integer): Integer;
begin
  if IdZayavka = 0 then begin
    with DM1.FDC1 do begin
      CommandText.Clear;
      CommandText.Add('INSERT INTO zayavka_spisok (Status)');
      CommandText.Add('VALUES (:pStatus)');
      ParamByName('pStatus').AsInteger := 1;
      Execute;
    end;
 
    with DM1.FDQ1 do begin
      Close;
      SQL.Clear;
      SQL.Add('SELECT LAST_INSERT_ID() AS LastId');
      Open;
      if RecordCount > 0 then begin
        IdZayavka := FieldByName('LastId').AsInteger;
 
      end;
    end;
 
  end else begin
 
  end;
  Result := IdZayavka;
end;
Несмотря на то что все вроде бы работает, причем на удивление даже без указания таблицы для которой производилась вставка и не смотря на то, что это два разных запроса посланы через разные компоненты, полагаю, что лучше эти два запроса выполнить в одном. Здесь:

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
     with DM1.FDQ1 do begin
      Close;
      SQL.Clear;
      SQL.Add('INSERT INTO zayavka_spisok (Status)');
      SQL.Add('VALUES (:pStatus);');
      ParamByName('pStatus').AsInteger := 1;
      SQL.Add('SELECT LAST_INSERT_ID() AS LastId;');
      Open;
      if RecordCount > 0 then begin
        IdZayavka := FieldByName('LastId').AsInteger;
 
      end;
    end;
Что могли бы сказать из опыта?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.11.2023, 09:18
Ответы с готовыми решениями:

Задача с поиском последней записи
Добрый день! Скажите пожалуйста как решить задачку: 3 Таблицы с полем Data и Box, таблица - Access, компоненты Delphi -...

Редактирование последней записи в ADOtable
Здравствуйте, подключила из Access таблицу Журнал посещения.Прописала код добавления этого посещения. При входе в приложение все нормально...

Запрос по последней записи в MSSql
Еще раз здравствуйте, Такая проблема у меня: Нужен запрос - есть Три поля (marka_avto,datvid,sdan_litr), нужно чтобы выводилось значения...

3
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,405
Записей в блоге: 3
30.11.2023, 10:27
Цитата Сообщение от S0563506 Посмотреть сообщение
полагаю, что лучше эти два запроса выполнить в одном
и получить ошибку. У компонента TFDQuery запросы, возвращающие набор данных, и запросы, выполняющие действия, выполняются разными методами, Open() и ExecSQL() соответственно.
0
2 / 2 / 0
Регистрация: 11.09.2023
Сообщений: 193
30.11.2023, 12:57  [ТС]
Цитата Сообщение от D1973 Посмотреть сообщение
Open() и ExecSQL() соответственно.
Ошибки нет. Можно только Open(). Уже сделал работает.
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
  if IdZayavka = 0 then begin
    try
      with DM1.FDQ1 do begin
        Close;
        SQL.Clear;
        SQL.Add('INSERT INTO zayavka_spisok (Status)');
        SQL.Add('VALUES (:pStatus);');
        ParamByName('pStatus').AsInteger := 1;
        SQL.Add('SELECT LAST_INSERT_ID() AS LastId;');
        Open;
        if RecordCount < 1 then begin
          ShowMessage('{FDD7725B-99A4-4017-9F18-8BDA4F6899D6}');
          Exit;
        end;
 
        IdZayavka := FieldByName('LastId').AsInteger;
      end;
    except
      ShowMessage('{59A085C3-AF87-4601-8FC9-366443BB475C}');
    end;
  end;
0
 Аватар для cyberGlod
13 / 11 / 2
Регистрация: 11.10.2023
Сообщений: 138
03.12.2023, 07:57
Exec используется только тогда, когда нечего возвращать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.12.2023, 07:57
Помогаю со студенческими работами здесь

Получить номер последней записи в RichEdit
Есть текст Ролики Коньки Лыжи В нем нужно узнать и записать номер строки, в которой записано слово &quot;лыжи&quot;...

Вывод последней записи из таблицы mysql
Приветсвую. У меня вот такая ситуация. есть таблица, в ней определенное количество столбцов и первый из них ключ 'id' с параметром...

Как в MySQL запросе сравнить значение id из таблицы A со значением a_id из таблицы B из последней добавленной записи
Очень тяжело объяснить, вот пример (работаю в phpmyadmin): У меня есть 2 таблицы: articles categories У articles есть...

Проверка на совпадение последней и следующей записи при записи в файл
Доброго времени суток) У меня в файл записывается произошло соединение с сервером или нет, но проверка с соединением происходит каждые...

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru