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

Ошибка violation of primary key

18.10.2014, 21:04. Показов 2946. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
на форме есть dbgrid в нём таблица InterBase, создал другую форму для изменения записей в таблице...
вот собственно код изменения данных

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  
  DM.Pacienti.Edit;
  DM.Pacienti.FieldByName('Kod_pacienta').Text:=dd.Edit1.Text; //Kod_pacienta ключ в IB
  DM.Pacienti.FieldByName('FIO').Value:= dd.Edit2.Text;
  DM.Pacienti.FieldByName('Data_rojdeni9').Value:= dd.DateTimePicker1.Date;
  DM.Pacienti.FieldByName('Adres').Value:= dd.Edit3.Text;
  DM.Pacienti.FieldByName('Tel').Value:= dd.Edit4.Text;
  DM.Pacienti.Post;
  ShowMessage('Äàííûå óñïåøíî èçìåíåíû');
  begin
  dd.Edit1.Text:='';
  dd.Edit2.Text:='';
  dd.Edit3.Text:='';
  dd.Edit4.Text:='';
  dd.DateTimePicker2.Date:=Date;
end;
после того как нажимаю на кнопку для изменения данных выскакивает ошибка

violation of primary key or unique key constraint "Integer-3"

как я понял ругается на ключевое поле: "Kod_pacienta"
с чем это связано? не верный код или это надо что-то в InterBase менять?
интересно то, что если ввести код пациента=1 то данные изменяются!
остальные значения-нет.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.10.2014, 21:04
Ответы с готовыми решениями:

Ошибка violation of PRIMARY or UNIQUE KEY при работе с базой Firebird (DataSnap)
Здравствуйте, уважаемые форумчане! Помогите,пожалуйста, если кто может подсказать, помочь советом.. Есть сервер DataSnap, который...

Ошибка violation of foreign key constraint (Delphi+InterBase)
добавляю на кнопку событие DM.Karto4ka.Insert; DM.Karto4ka.FieldByName('Kod_osmotra').Value:=DIKarto4ka.KO.Text ; ...

DBLookUpCombobox delphi xe7 primary key
Есть простая таблица, например students ID_name - serial Name - varchar БД PostgreSQL ListSourse - datasource от FDQuery к таблице ...

15
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,505
18.10.2014, 21:14
я бы советовал для присвоения значения первичному ключу использовать генераторы. а так похоже, что вы присваиваете не уникальное значение ключевому полю или оно пустое.
1
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
19.10.2014, 00:02  [ТС]
спасибо буду пробовать.
0
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
20.10.2014, 01:55  [ТС]
Цитата Сообщение от Алекcей Посмотреть сообщение
я бы советовал для присвоения значения первичному ключу использовать генераторы. а так похоже, что вы присваиваете не уникальное значение ключевому полю или оно пустое.
создал генератор на ключевое поле, который присваивает новое значение при создании нового поля, ошибка та же.
принцип работы такой... рядом с таблицой есть кнопка изменить данные при переходе открывается другая форма, в нём Edit-ы, далее заполняем их и наживаем кнопку изменить ииии ошибка.
почему первая строка с ключевым полем=1 изменяются остальные нет?


Delphi
1
2
3
4
5
6
7
8
9
10
DM.Klienti.Edit;
  DM.Klienti.FieldByName('Kod_Klienta').Value:=Three.KK.Text ;
  DM.Klienti.FieldByName('F_Klienta').Value:= Three.F.Text;
  DM.Klienti.FieldByName('I_Klienta').Value:= Three.I.Text;
  DM.Klienti.FieldByName('O_Klienta').Value:= Three.O.Text;
  DM.Klienti.FieldByName('STRANA').Value:= Three.S.Text;
  DM.Klienti.FieldByName('GOROD').Value:= Three.G.Text;
  DM.Klienti.FieldByName('ADRES').Value:= Three.A.Text;
  DM.Klienti.Post;
  ShowMessage('Äàííûå óñïåøíî èçìåíåíû');
Добавлено через 30 минут
мб проблема в этом?
у меня есть 2 индекса с одинаковым именем но в разных таблицах, может быть данные не меняются потому что поле во второй таблице с вторичным ключом не даёт изменить данные первичному ключу в первой таблице?
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,505
20.10.2014, 12:16
создать генератор мало, еще нужно создать триггер на добавление записи, который будет вызывать генератор. если проект не секретный, то пришлите мне я посмотрю.
0
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
26.10.2014, 14:56  [ТС]
Цитата Сообщение от Алекcей Посмотреть сообщение
создать генератор мало, еще нужно создать триггер на добавление записи, который будет вызывать генератор. если проект не секретный, то пришлите мне я посмотрю.
триггер как раз таки создан тоже, но проблема остаётся. Надеюсь Ваше предложение о помощи ещё в силе)
Вложения
Тип файла: rar Курсовой Проект.rar (1.55 Мб, 7 просмотров)
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,505
27.10.2014, 11:00
какой interbase(версия) у Вас установлен?
0
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
28.10.2014, 23:51  [ТС]
Цитата Сообщение от Алекcей Посмотреть сообщение
какой interbase(версия) у Вас установлен?
WI-V7.0.1.1
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,505
29.10.2014, 00:31
можете выслать БД, а лучше backup ее? Дело в том, что я не могу открыть Вашу базу.
0
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
29.10.2014, 11:14  [ТС]
Цитата Сообщение от Алекcей Посмотреть сообщение
можете выслать БД, а лучше backup ее? Дело в том, что я не могу открыть Вашу базу.
файл потом переименовать нужно в gbk... если не сможете сделать restore то, что Вы понимаете под "можете выслать БД" скрин или ещё как?
Вложения
Тип файла: doc BackUpKP.doc (22.5 Кб, 2 просмотров)
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,505
29.10.2014, 11:48
пробовал добавить клиента, сначала программа ругалась что не может внести изменения в закрытый DataSet. подправил и добавление клиента заработало
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
  DM.Klienti.Open;
  DM.Klienti.Insert;
  DM.Klienti.FieldByName('Kod_Klienta').Value:=Three.KK.Text ;
  DM.Klienti.FieldByName('F_Klienta').Value:= Three.F.Text;
  DM.Klienti.FieldByName('I_Klienta').Value:= Three.I.Text;
  DM.Klienti.FieldByName('O_Klienta').Value:= Three.O.Text;
  DM.Klienti.FieldByName('STRANA').Value:= Three.S.Text;
  DM.Klienti.FieldByName('GOROD').Value:= Three.G.Text;
  DM.Klienti.FieldByName('ADRES').Value:= Three.A.Text;
  DM.Klienti.Post;
  DM.Klienti.Close;
  ShowMessage('Данные успешно добавлены');
0
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
29.10.2014, 21:35  [ТС]
у меня добавление работает и так, кстати если добавить
Цитата Сообщение от Алекcей Посмотреть сообщение
DM.Klienti.Open;
и
Цитата Сообщение от Алекcей Посмотреть сообщение
DM.Klienti.Close;
ошибка при нажатии на кнопку добавить, у меня проблема в изменение данных... посмотрите если можно, спасибо)
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,505
30.10.2014, 00:19
попробуйте так
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
  DM.Klienti.Open;
 
  if DM.Klienti.Locate('KOD_KLIENTA', StrToInt(Three.KK.Text), []) then begin
 
  DM.Klienti.Edit;
 
  DM.Klienti.FieldByName('F_Klienta').Value:= Three.F.Text;
  DM.Klienti.FieldByName('I_Klienta').Value:= Three.I.Text;
  DM.Klienti.FieldByName('O_Klienta').Value:= Three.O.Text;
  DM.Klienti.FieldByName('STRANA').Value:= Three.S.Text;
  DM.Klienti.FieldByName('GOROD').Value:= Three.G.Text;
  DM.Klienti.FieldByName('ADRES').Value:= Three.A.Text;
  DM.Klienti.Post;
  ShowMessage('Данные успешно изменены');
  DM.Klienti.Close;
  DM.PredZakaz.Open;
  DM.PredZakaz.Edit;
 
  DM.PredZakaz.FieldByName('Kod_PZ').Value:=0;
  DM.PredZakaz.FieldByName('Kod_Klienta2').Value:=Three.KK.Text ;
  DM.PredZakaz.Post;
 
  DM.PredZakaz.Close;
  end;
  begin
  Three.KK.Text:='';
  Three.F.Text:='';
  Three.I.Text:='';
  Three.O.Text:='';
  Three.S.Text:='';
  Three.G.Text:='';
  Three.A.Text:='';
end;
1
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
30.10.2014, 21:10  [ТС]
Спасибо) немного подправил, ну а так в принципе работает.
0
0 / 0 / 0
Регистрация: 06.10.2013
Сообщений: 61
02.11.2014, 13:18  [ТС]
Может быть Вы знаете как отфильтровать записи в DBLookupComboBox1?
в общем добавил DBLookupComboBox1 задал ему list, key и прочее, а как при выборе одного из значений в DBLookupComboBox1 сделать так, что бы таблица фильтровалась?
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,505
05.11.2014, 09:38
Можно в тексте запроса в WHERE задать условие на равенство какого-то поля key из DBLookupComboBox. Или если используется компонент TADOTable использовать св-во Filter.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.11.2014, 09:38
Помогаю со студенческими работами здесь

Отследить исключение Primary Или Unique key
Есть таблица. В ней первичный ключ и уникальный ключ. Когда я в делфи добавляю запись, в которой уникальный ключ повторяет значение,...

Ошибка Key Violation при добавлении записи в БД
Подскажите, пожалуйста, кто знает. В БД при добавлении записи появляется ошибка Key Violation. Не могу установить причину её появления, ну...

Ошибка в запросе на добавление строки: Violation of PRIMARY KEY constraint
private void button1_Click(object sender, EventArgs e) { SqlConnection con = new SqlConnection(@"Data...

Ошибка при заполнении пустой таблицы: Violation of Primary Key constraint
Всем привет. С базами данных я на Вы. Установил SQL_EXPRESS_2014. В менеджмент студио запустил SQL-скрипт для создающий пять таблиц. ...

Violation of Primary key constraint 'PK_otdel'. Cannot insert dupllicate key in object 'dbo.otdel'.
void __fastcall TAddOtdForm::AddOtdButton1Click(TObject *Sender) { int kodotd; MainForm->OtdelADOQuery1->Last(); kodotd =...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru