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

Сравнить две записи в программе

12.05.2016, 19:40. Показов 1385. Ответов 25
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть вот такой незамысловатый код:

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
procedure TForm4.Button1Click(Sender: TObject);
var s1:string;
    n:integer;
begin
    s1:=DBEdit4.text;
    Query1.Close;
    Query1.SQL.Clear;
    Query1.SQL.Add('SELECT * FROM KURIER K WHERE K.PASPORT = "'+s1+'" ');
    Query1.Open;
    n:=Query1.RecordCount;
 
    if n=0 then begin
       Form1.Table3_kurieri.Edit;
       Form1.Table3_kurieri.Post;
       Close;
       MessageDlg('Сдал', mtError, [mbOK], 0);
    end else MessageDlg('Такой курьер уже есть в базе!', mtError, [mbOK], 0);
 
end;
Суть его в том, что он стоит на кнопке редактирования данных, проще говоря сравнение на повторение данных в базе, напрмер, если есть уже человек с фамилией: Иванов, то его не должно добавить.
Однако, столкнулся с проблемой, при добавлении новой строки проблем нет, но если открыть редактирование то значение из базы всегда равно 1, так как запись же есть уже, поэтому у меня всегда пишет, что такая фамилия есть, каким образом можно обработать этот нюанс, а именно, например, если я просто нажал редактирование, но не редактировал поля или они остались теми же то просто оставить запить такой же как и есть, не выдавая ошибку?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.05.2016, 19:40
Ответы с готовыми решениями:

Как сравнить две даты?
А ніхто не догадався просто порівняти ці дати? A, B : TDateTime; if A>=B then .... else ....

Как сравнить две таблицы dbe на предмет одинаковых записей по определенным полям
Подскажите как сравнить две таблицы dbe на предмет одинаковых записей по определенным полям. Конкретней: на форме два грида, каждый...

Связать две формы по записи из DBGrid
Здравствуйте! Такой вопрос, есть БД в access, она подключена к Delphi. В Delphi имеются 2 формы, первая содержит таблицу DBGrid с полями -...

25
0 / 0 / 2
Регистрация: 01.10.2013
Сообщений: 344
13.05.2016, 17:43  [ТС]
Студворк — интернет-сервис помощи студентам
Ааа, вы все равно не просекли, не поможет разбить, всё равно тоже самое будет, нужно как-то сравнить исходное и изменённое ...
0
 Аватар для krapotkin
6847 / 4674 / 1463
Регистрация: 14.04.2014
Сообщений: 20,656
Записей в блоге: 21
13.05.2016, 18:35
с этого текста нужно было начинать

проверку нужно делать в событии OnBeforePost
ваш датасет находится в одном из двух состояний - либо dsEdit либо dsInsert
в любом случае вы берете значения полей, составляете запрос и делаете вывод
если нужно отменить, поднимаете исключение
raise Exception.Create('Такая запись уже есть');
и все...
0
0 / 0 / 2
Регистрация: 01.10.2013
Сообщений: 344
13.05.2016, 21:55  [ТС]
Охох, что-то ничего не понял, я немного слоупок, или много
0
 Аватар для krapotkin
6847 / 4674 / 1463
Регистрация: 14.04.2014
Сообщений: 20,656
Записей в блоге: 21
13.05.2016, 22:10
есть датасет, пусть q1, в который надо что-то вставить или изменить
у него есть событие OnBeforePost
в этом событии пишем что-то типа (поля и условие в SQL я беру от фонаря)

Delphi
1
2
3
4
5
6
7
8
9
s1:=q1.fieldByName('aaa').asString;
s2:=q1.fieldByName('bbb').asString
q2.sql.text:= 'select count(*) as C from та_же_таблица where aaa='''+s1+''' and bbb='''+s2+'''';
q2.open;
Found := q2.FieldByName('C').asInteger <> 0;
q2.close;
 
if Found then
  raise Exception.Create('Такая запись есть уже');
0
0 / 0 / 2
Регистрация: 01.10.2013
Сообщений: 344
15.05.2016, 11:12  [ТС]
А в чём суть OnBeforePost?
Если смотреть на твой код, он мне всегда должен возвращать ошибку.
Выглядит как, я записал Фамилию и Имя в переменные, нашел их в базе и вернул ошибку на то что они есть.
0
 Аватар для krapotkin
6847 / 4674 / 1463
Регистрация: 14.04.2014
Сообщений: 20,656
Записей в блоге: 21
15.05.2016, 12:08
On BEFORE post
переведите, это недолго, но полезно
значения полей датасета еще не записаны в базу
поэтому можно слазить туда и посмотреть, есть там эти значения или нет
если есть, выдать Exception и запись не произойдет
а узнал я это, прочитав документацию по OnBeforePost
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.05.2016, 12:08
Помогаю со студенческими работами здесь

Поменять две записи местами в Paradox
База данных Paradox. Имеются различные поля типа string, smallint. Также графическое поле и formatedmemo Необходимо по нажатию на...

Добавление записи в программе
В общем, ребята проблема....:wall: Препод дал баговою программу, сказал исправить, либо попрут с учебного заведения, а как бы не очень...

Почему программный код повторяет две последние записи?
Var ExcelApp,Sheet,Colum:Variant; index,i:Integer; begin ExcelApp:= CreateOleObject('Excel.Application'); ...

Добавление записи в таблицу Бд в программе Delphi
На сервере есть хранимая процедура ALTER PROCEDURE . ( @Name varchar(30), -- Наименование товара @Firm varchar(30), -- Фирма...

сравнить две таблицы
Есть две таблицы Иванов Иван Иванович 89606785533 Петров Петр Петрович 89606785534 Петров...


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

Или воспользуйтесь поиском по форуму:
26
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru