Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> не до бавляется фореин кей, ПОЧЕМУ ?? 
V
    Опции темы
Samotnik
Дата 11.12.2007, 13:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Super star !
****


Профиль
Группа: Awaiting Authorisation
Сообщений: 7192
Регистрация: 4.11.2006
Где: Минск City

Репутация: нет
Всего: 191



САБЖ!
Есть следущая не хитрая база
Код

create table KRD
(
id_KRD integer default autoincrement not null,
OP integer not null,
OOPR integer not null,
primary key(OP)
);
create table KPP
(
id_KPP integer default autoincrement not null,
ZPP integer not null,
ZPOP integer not null,
primary key(ZPP)
);

create table AllValues
(
id_All integer default autoincrement not null,
OP integer not null,
ZPP integer not null,
primary key (id_All)
);

где AllValues является главной.
Далее я делаю следущее
Код

ALTER TABLE AllValues ADD FK_OOPR_KIOPP
FOREIGN KEY(OP) REFERENCES KRD(OP)
ON UPDATE CASCADE ON DELETE CASCADE;

ALTER TABLE AllValues ADD FK_OOPR_KSB
FOREIGN KEY(ZPP) REFERENCES KPP(ZPP)
ON UPDATE CASCADE ON DELETE CASCADE;

НО почему то данные новые не добавляются, хотя если удалить либо отредактировать эти параметры то в фореин кеях они тоже удаляются и редактируются. А как сделать, чтоб они добавлялись??  Вроде  правильно написанно..
PM MAIL   Вверх
LSD
Дата 11.12.2007, 14:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15717
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 537



1. Очень оригинальный метод изготовления первичных ключей, автоинкрементное поле одно, а первичный ключ - другое smile
2. Что значит данные новые не добавляются?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Anark1
Дата 11.12.2007, 22:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 622
Регистрация: 15.12.2006
Где: RF -> Moscow

Репутация: 2
Всего: 11



Цитата

НО почему то данные новые не добавляются, хотя если удалить либо отредактировать эти параметры то в фореин кеях они тоже удаляются и редактируются. А как сделать, чтоб они добавлялись??  Вроде  правильно написанно..

Вообще непонятно, что хотел этим сказать. Если имеется ввиду, что не происходит добавление записей в зависимые таблицы, то это можно объяснить тем, что при выполнении оператора INSERT, ты пытаешься добавить запись в зависимую таблицу и заносишь в поле внешнего ключа некоторое значение, которое отсутствует в главной таблице. То есть делаешь, то что по сути и должны предотвращать внешние ключи.


--------------------
Enjoy yourself, still you can...;)

user posted image

user posted image
PM MAIL ICQ   Вверх
Samotnik
Дата 12.12.2007, 00:33 (ссылка)    | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Super star !
****


Профиль
Группа: Awaiting Authorisation
Сообщений: 7192
Регистрация: 4.11.2006
Где: Минск City

Репутация: нет
Всего: 191



LSD,  Anark1,  Блин, вы  меня не поняли, я вас не понял, пойду  еще раз прочитай про foreign key
Меня ток интересует одно, почему, когда я из таблицы KRD удаляю значение  поля OP то это значение  удаляется из таблицы AllValues тоже, когда я редактирую значение  поля OP то это же  значение редактируется и в таблице AllValues  НО!  когда я добавляю значение  поля OP  в таблице KRD то это значение почему то не добавляется в таблицу AllValues ?
PM MAIL   Вверх
LSD
Дата 12.12.2007, 12:32 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15717
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 537



Samotnik, ты не понимаешь, что такое FK и зачем он нужен.
FK это просто способ гарантировать, что у дочерней записи есть корректный родитель. Вот и все. А никакого добавления записей в дочернюю таблицу нет и не будет. Да и смысла нет в этом, все равно все эти данные есть в родительской таблице.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0894 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.