Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 11.02.2011, 03:14
exy exy вне форума
Прохожий
 
Регистрация: 13.01.2010
Сообщения: 27
Репутация: 10
По умолчанию Ошибка Добавления в БД

Проблемы с записью В БД. Есть 3 таблицы БД : Игрок(Player), позиция на поле(OnGroundPosition), позиция игрока на поле(PlayerPosition).
Таблицы Player и OnGroundPosition связаны отношением многие-ко-многим, которое разруливается с помощью введения дополнительной таблицы PlayerPosition(Атрибуты таблиц во вложенном файле ).
Пытаюсь добавить Новую запись в таблицу PlayerPosition и он жалуется на то что "violation of foreign key constraint Integ_117 on table PlayerPosition. foreign key reference target does not exist"
Параметры процедуры передаются правильно, но при этом создается ощущение что не хочет записываться потому что пытается записать Null значение в ключевое поле.
код добавления
Код:
procedure TPlayerEditForm.PlayerPositionsKoeff(PosID,PlayerN,Coeff: integer);
begin
     DataMForecast.dsPlayerPosition.Insert;
     DataMForecast.dsPlayerPosition.FieldByName('PositionID').AsInteger := PosID;
     DataMForecast.dsPlayerPosition.FieldByName('PlayerID').AsInteger := PlayerN;
     DataMForecast.dsPlayerPosition.FieldByName('Koeff').AsInteger := Coeff;
     DataMForecast.dsPlayerPosition.Post;
end;
Вложения
Тип файла: 7z Рабочий стол.7z (7.2 Кбайт, 8 просмотров)

Последний раз редактировалось exy, 11.02.2011 в 14:48.
Ответить с цитированием
  #2  
Старый 11.02.2011, 05:15
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,096
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Попробуй через AppendRecord.
Ответить с цитированием
  #3  
Старый 11.02.2011, 10:46
exy exy вне форума
Прохожий
 
Регистрация: 13.01.2010
Сообщения: 27
Репутация: 10
По умолчанию

Никакой разницы нет, пробовал append post, insert post, insertrecord, appendrecord...
У меня такое ощущение что неправильно работает запрос на вставку.....
Ну помогите Плиз!!!!!!!!

Последний раз редактировалось exy, 12.02.2011 в 01:06.
Ответить с цитированием
  #4  
Старый 15.02.2011, 10:30
Black Raider Black Raider вне форума
Местный
 
Регистрация: 31.05.2010
Адрес: Москва
Сообщения: 466
Версия Delphi: 7
Репутация: 40
По умолчанию

Цитата:
Сообщение от exy
не хочет записываться потому что пытается записать Null значение в ключевое поле.
ощущение правильное.

Пс. вот не люблю я foreign key из за этого
__________________
Новый вирус - "БОМЖ"! Он просто роется в Корзине...и спит под ярлычком "Сетевое окружение"
Ответить с цитированием
  #5  
Старый 16.02.2011, 01:00
exy exy вне форума
Прохожий
 
Регистрация: 13.01.2010
Сообщения: 27
Репутация: 10
По умолчанию

И как же мне решить эту проблему???? подскажите, пожалуйста!!!
Ответить с цитированием
  #6  
Старый 16.02.2011, 02:36
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,096
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Выкладывай код запроса и структуру БД, посмотрим.

ЗЫ. Твой код целиком смотреть просто лень. Выложи именно значимые для проблемы куски в теле сообщения.
Ответить с цитированием
  #7  
Старый 16.02.2011, 10:19
exy exy вне форума
Прохожий
 
Регистрация: 13.01.2010
Сообщения: 27
Репутация: 10
По умолчанию

Запрос на вставку таков:
Код:
insert into PLAYERPOSITION
  (POSITIONID, PLAYERID, KOEFF)
values
  (:POSITIONID, :PLAYERID, :KOEFF)
Структура базы данных - в файле Безымянный.jpg
Изображения
Тип файла: jpg Безымянный.jpg (43.2 Кбайт, 10 просмотров)
Ответить с цитированием
  #8  
Старый 16.02.2011, 11:35
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Т.е. получается, что в таблице PlayerPosition поля PositionID,PlayerID являются одновременно FK и PK? PK там вообще нафик не нужен. Если вы хотите избежать повтора данных в PlayerPosition на уровне ядра БД, то просто сделайте уникальный индекс по этим полям.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.

Последний раз редактировалось Страдалецъ, 16.02.2011 в 11:37.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра
Комбинированный вид Комбинированный вид

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 03:43.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025