С Новым годом! Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
392 / 191 / 48
Регистрация: 11.07.2013
Сообщений: 1,193
1

Как проверить наличие такой же записи в таблице PostgreSQL?

21.08.2024, 09:30. Показов 575. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть таблица (Products), которая содержит столбцы: код товара (sTkod) и наименование товара (sTName). При дополнении таблицы новым товаром необходимо убедиться, что ранее введённый товар не имеет такой же код и такое же наименование (наименование может начинаться с заглавной или прописной буквы).
Хочу сделать вот так:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// Добавить товар.
procedure TForm2.Button4Click(Sender: TObject);
begin
  if not PQConnection1.Connected then begin
    MessageDlg('cwAdmin', 'Нет связи с сервером.', mtWarning,[mbOK], 0);
    exit;
  end;
  SQLQuery1.Active:=false;
  SQLQuery1.SQL.Clear;
  SQLQuery1.SQL.Add('SELECT * FROM Products WHERE '+
  'sTkod LIKE '+LabeledEdit1.Text+' OR sTName ILIKE '+LabeledEdit1.Text+';');
  SQLQuery1.Open;
 
  // Что-то проверяю и если FALSE то добавляю новый товар, если TRUE, то вывожу сообщение, что такой товар уже имеется.
end;
В документации сказано, что если такой записи нет, то будет возвращено FALSE. А где это FALSE проверять? И как вообще правильно делать такую проверку?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.08.2024, 09:30
Ответы с готовыми решениями:

Как проверить наличие записи в таблице БД MySql(по ID)
Всем доброго времени суток. Уважаемые программисты, у меня возник такой вопрос: Есть таблица в...

Проверить наличие записи в таблице и добавить его при отсутствии
Дано две таблицы: Если в таблице 1 нет такого же id как в таблице 2, то необходимо этот id...

Как проверить на ошибки в таблице, а именно наличие пробелов
Добрый день, подскажите пожалуйста как в Эксель 2013 , проверить таблицу на ошибки , а именно...

Как проверить наличие записи в бд?
бд firebird 2.5 FbCommand SelTabNo = new FbCommand("SELECT Count(TAB_NO) FROM UCHASTKOVUI...

5
560 / 347 / 174
Регистрация: 21.02.2011
Сообщений: 5,035
21.08.2024, 10:37 2
такой вариант подойдет ?
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
procedure TForm2.Button4Click(Sender: TObject);
var
  ProductCode, ProductName: string;
begin
  if not PQConnection1.Connected then begin
    MessageDlg('cwAdmin', 'Нет связи с сервером.', mtWarning, [mbOK], 0);
    exit;
  end;
 
  // Получаем значения из LabeledEdit для проверки
  ProductCode := LabeledEdit1.Text;
  ProductName := LabeledEdit2.Text; // Предположим, что наименование в LabeledEdit2
 
  SQLQuery1.Active := false;
  SQLQuery1.SQL.Clear;
  // Используем параметры для предотвращения SQL-инъекций
  SQLQuery1.SQL.Add('SELECT * FROM Products WHERE sTkod = :code OR LOWER(sTName) = LOWER(:name);');
  SQLQuery1.ParamByName('code').AsString := ProductCode;
  SQLQuery1.ParamByName('name').AsString := ProductName;
  
  SQLQuery1.Open;
 
  // Проверяем, есть ли результаты
  if SQLQuery1.IsEmpty then
  begin
    // Если нет, добавляем новый товар
    SQLQuery1.Active := false;
    SQLQuery1.SQL.Clear;
    SQLQuery1.SQL.Add('INSERT INTO Products (sTkod, sTName) VALUES (:code, :name);');
    SQLQuery1.ParamByName('code').AsString := ProductCode;
    SQLQuery1.ParamByName('name').AsString := ProductName;
    SQLQuery1.ExecSQL; // Выполняем вставку
    
    MessageDlg('Товар успешно добавлен.', mtInformation, [mbOK], 0);
  end
  else
  begin
    // Если есть, выводим сообщение об ошибке
    MessageDlg('Товар с таким кодом или наименованием уже существует.', mtWarning, [mbOK], 0);
  end;
end;
Пояснения:
1
3711 / 1368 / 484
Регистрация: 31.05.2012
Сообщений: 4,814
21.08.2024, 13:27 3
А unique использовать ни как не подходит?
0
392 / 191 / 48
Регистрация: 11.07.2013
Сообщений: 1,193
21.08.2024, 13:58  [ТС] 4
Сделал, как вы рекомендуете:
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
28
  // Получаем значения из LabeledEdit для проверки
  ProductCode:=LabeledEdit1.Text;
  ProductName:=LabeledEdit2.Text;
  // Используем параметры для предотвращения SQL-инъекций
  SQLQuery1.SQL.Add('SELECT * FROM Products '+
  'WHERE sTkod = :code OR LOWER(sTName) = LOWER(:name);');
  SQLQuery1.ParamByName('code').AsString:=ProductCode;
  SQLQuery1.ParamByName('name').AsString:=ProductName;
  SQLQuery1.Open;
  // Проверяем, есть ли результаты
  if SQLQuery1.IsEmpty then begin
    // Если нет, добавляем новый товар
    SQLQuery1.Active := false;
    SQLQuery1.SQL.Clear;
    SQLQuery1.SQL.Add('INSERT INTO Products (sTkod, sTName) '+
    'VALUES (:code, :name);');
    SQLQuery1.ParamByName('code').AsString := ProductCode;
    SQLQuery1.ParamByName('name').AsString := ProductName;
    SQLQuery1.ExecSQL; // Выполняем вставку
    SQLTransaction1.Commit;
    SQLTransaction1.Options:=[]; // Очистить опции.
    SQLQuery1.Close;
    MessageDlg('cwAdmin', 'Товар успешно добавлен.', mtInformation, [mbOK], 0);
  end else begin
    // Если есть, выводим сообщение об ошибке
    MessageDlg('cwAdmin', 'Товар с таким кодом или (и) наименованием '+
    'уже существует.', mtWarning, [mbOK], 0);
  end;
При попытке повторно ввести то же самое возникает исключение.
Как проверить наличие такой же записи в таблице PostgreSQL?

Немного изменил код, работает правильно:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
  SQLQuery1.Active:=false;
  SQLQuery1.SQL.Clear;
  SQLQuery1.SQL.Add('SELECT * FROM Products WHERE '+
  'sTkod = '''+LabeledEdit1.Text+''' OR '+
  'LOWER(sTName)=LOWER('''+LabeledEdit2.Text+''');');
  SQLQuery1.Open;
  if SQLQuery1.IsEmpty then begin
    SQLQuery1.Active:=false;
    SQLQuery1.SQL.Clear;
    SQLQuery1.SQL.Add('INSERT INTO Products(sTkod, sTName) '+
    'VALUES('''+LabeledEdit1.Text+''', '''+LabeledEdit2.Text+''')');
    SQLQuery1.ExecSQL;
    SQLTransaction1.Commit;
    SQLTransaction1.Options:=[]; // Очистить опции.
    SQLQuery1.Close;
    ShowData(); // Показать данные.
    MessageDlg('cwAdmin', 'Товар успешно добавлен.', mtInformation, [mbOK], 0);
  end else
    MessageDlg('cwAdmin', 'Товар с таким кодом или (и) наименованием '+
    'уже существует.', mtWarning, [mbOK], 0);
Как проверить наличие такой же записи в таблице PostgreSQL?

Почему-то с параметрами SQLQuery1 работать корректно не хочет... (у меня Lazarus).
0
392 / 191 / 48
Регистрация: 11.07.2013
Сообщений: 1,193
21.08.2024, 14:04  [ТС] 5
Цитата Сообщение от Аватар Посмотреть сообщение
А unique использовать ни как не подходит?
Вариант хороший, но как сообщить оператору, что такая запись уже есть (он будет "долбить" по кнопкам, а потом скажет, что программа не работает)...
0
3711 / 1368 / 484
Регистрация: 31.05.2012
Сообщений: 4,814
21.08.2024, 14:48 6
Сервер же подымет определенное исключение. Отловить его на клиенте и если юзеру не понятно то заменить понятным сообщением
1
21.08.2024, 14:48
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.08.2024, 14:48
Помогаю со студенческими работами здесь

Как проверить на наличие записи в БД
Нужно перед добавления пользователя в базу данных проверить на уникальность логин пользователя. Код...

Как проверить таблицу на наличие записи
Делаю отдельную регистрацию, подскажите как проверять не занят ли логин другим человеком с учетом...

Как проверить таблицу на наличие записи
Делаю отдельную регистрацию, подскажите как проверять не занят ли логин другим человеком с учетом...

Как проверить наличие записи В ПОДЧИНЕННОЙ ФОРМЕ
привет всем ... Мне нужно по нажатию на кнопку "новая запись" , в форме "F_Работник" ...

Как проверить наличие записи В ПОДЧИНЕННОЙ ФОРМЕ
привет всем ... Как проверить наличие записи В ПОДЧИНЕННОЙ ФОРМЕ с помощью Recordset.EOF ...

Как проверить наличие записи в MongoDb по полю
Как проверить условие если в коллекции есть запись с данным полем(login)то обновить данные...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Что такое 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. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru