Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: sql cвязи
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » sql cвязи

Страниц (2): [1] 2 »
 

1. xTODx - 23 Февраля, 2014 - 00:08:01 - перейти к сообщению
Всем привет! вот пришло время обеспечить целостность базы данных, но связи не хотят создаваться. Ни каких сообщений о ошибки. работаю через дизайнера в phpmyadmin Выбираю ключ, выбираю второе поле, нажимаю окей, реакции 0, связи не рисует. и в общем её вообще нету. что делать не знаю.
2. caballero - 23 Февраля, 2014 - 00:18:39 - перейти к сообщению
таблицы innodb?
3. xTODx - 23 Февраля, 2014 - 00:33:58 - перейти к сообщению
caballero пишет:
таблицы innodb?

угу.. InnoDB все таблицы.

может делаю что не так??? как вообще нужно их создавать?

изначально цель такова, если у меня с таблицы category удалят одну категорию $id, то в таблице theme удалятся все темы у которых соответственно поле category = $id
(Этапы)
1) нажимаю "создать связь " в дизайнере
2) выбираю ключевое поле в таблице категорий
3) выбираю поле категорий в таблице с темами.
4. caballero - 23 Февраля, 2014 - 01:10:24 - перейти к сообщению
для этого надо задать каскадное удаление а не некую связь в дизайнере
5. xTODx - 23 Февраля, 2014 - 01:39:29 - перейти к сообщению
caballero пишет:
для этого надо задать каскадное удаление а не некую связь в дизайнере
хм, спасибо. и как это сделать? связь ведь "один к многим"
6. xTODx - 23 Февраля, 2014 - 09:17:42 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. FOREIGN KEY category (`id`) REFERENCES  theme(`category`)
  3.  

Пока нашёл вот такое вот. Но на сколько я понимаю, оно просто не даёт создавать в таблице тема строки, параметра category которых нету в таблице категорий(столбце id);
и так же запрещает удалять категорию, если в ней есть темы.
Но мне нужно что бы при удалении категорий, удалялись все темы.
неужели запросами всё?
Либо так?
CODE (SQL):
скопировать код в буфер обмена
  1. CREATE TRIGGER auto_del BEFORE DELETE ON forum_categ
  2. FOR EACH ROW BEGIN
  3. DELETE FROM forum_theme WHERE categ = OLD.id;
  4. END;

но тут где то ошибочка
Спойлер (Отобразить)
7. Мелкий - 23 Февраля, 2014 - 09:35:14 - перейти к сообщению
http://dev[dot]mysql[dot]com/doc/refman/[dot][dot][dot]constraints[dot]html
По-умолчанию restrict, только проверка данных.
Вы, так понял, хотите ON DELETE CASCADE
8. xTODx - 23 Февраля, 2014 - 10:08:01 - перейти к сообщению
Мелкий пишет:
http://dev[dot]mysql[dot]com/doc/refman/[dot][dot][dot]constraints[dot]html
По-умолчанию restrict, только проверка данных.
Вы, так понял, хотите ON DELETE CASCADE

угу, по ссылочке перешёл, посмотрел. Как быть, у меня уже есть база данных,
а там создют везде
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. CREATE TABLE doc (
  3. docID INTEGER NOT NULL AUTO_INCREMENT,
  4. langCode CHAR(2) NOT NULL,
  5. title VARCHAR(32),
  6. PRIMARY KEY (docID, langCode)
  7. ) Type=InnoDB;
  8.  
  9. CREATE TABLE author (
  10. authorID INTEGER NOT NULL AUTO_INCREMENT,
  11. docID CHAR(2) NOT NULL,
  12. name VARCHAR(32),
  13. PRIMARY KEY (authorID),
  14. FOREIGN KEY (docID) REFERENCES doc(docID) ON DELETE CASCADE ON UPDATE CASCADE
  15. ) Type=InnoDB;
  16.  

help.
9. Мелкий - 23 Февраля, 2014 - 11:01:15 - перейти к сообщению
Обычным alter table http://dev[dot]mysql[dot]com/doc/refman/[dot][dot][dot]alter-table[dot]html
Ищите по FOREIGN KEY
10. xTODx - 23 Февраля, 2014 - 11:17:20 - перейти к сообщению
Мелкий пишет:
Обычным alter table http://dev[dot]mysql[dot]com/doc/refman/[dot][dot][dot]alter-table[dot]html
Ищите по FOREIGN KEY

не поймуНедовольство, огорчение просто с английским у меня проблемы
11. xTODx - 23 Февраля, 2014 - 22:33:36 - перейти к сообщению
Дорогие форумчане HELP MEУлыбка напишите, пожалуйста.. я нуждаюсь в помощи
12. caballero - 23 Февраля, 2014 - 23:31:49 - перейти к сообщению
не нуждаешся.
Нафига тебе эти связи? чего такого решить ими хочешь?
13. retvizan - 24 Февраля, 2014 - 13:37:07 - перейти к сообщению
http://webew[dot]ru/posts/219[dot]webew
Понятное объяснение на руссском с примером как задавать связи на уже созданных таблицах.
14. xTODx - 24 Февраля, 2014 - 14:46:21 - перейти к сообщению
retvizan пишет:
http://webew[dot]ru/posts/219[dot]webew
Понятное объяснение на руссском с примером как задавать связи на уже созданных таблицах.

Спасибо, почитал, понял "это то что мне нужно". Даже возрадовался...
но..
CODE (SQL):
скопировать код в буфер обмена
  1. ALTER TABLE forum_theme
  2. ADD FOREIGN KEY (categ)
  3. REFERENCES forum_categ(id)
  4. ON UPDATE CASCADE
  5. ON DELETE CASCADE ;


CODE (text):
скопировать код в буфер обмена
  1.  
  2. #1005 - Can't create table 'maindb2.#sql-19b8_20e' (errno: 150) (Детали...)
  3.  

Нажал детали. получил

CODE (text):
скопировать код в буфер обмена
  1. Supports transactions, row-level locking, and foreign keys
15. Мелкий - 24 Февраля, 2014 - 14:54:57 - перейти к сообщению
errno 150 - проверьте типы данных в обеих таблицах. unsigned int и int, не говоря уже о int и tinyint не могут быть связаны ключом, только идентичный тип данных.

 

Powered by ExBB FM 1.0 RC1