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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Как сохранить целостность в бд

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Описание: mysql
petr
Отправлено: 10 Февраля, 2013 - 22:26:46
Post Id


Новичок


Покинул форум
Сообщений всего: 44
Дата рег-ции: Нояб. 2012  


Помог: 0 раз(а)




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

Есть пользовательский интерфейс, где можно добавлять/удалять/изменять категории.
И интерфейс с добавлением статьи, где можно выбрать категорию.

Но допустим такая ситуация, если пользователь захочет удалить категорию, к которой привязаны существующие статьи.

Как сохранить целостность и реализовать это?

Заранее спасибо
 
 Top
etoYA
Отправлено: 10 Февраля, 2013 - 22:30:24
Post Id



Участник


Покинул форум
Сообщений всего: 1859
Дата рег-ции: Июль 2011  
Откуда: Крым


Помог: 21 раз(а)




Как понять привязаны? Как понять целостность?

Я понимаю так

categories (К примеру)
id, name

articles (К примеру)
id,cat_id,name, text

Вариант 1:
При удалении категории, удалять статьи которые входят в эту категорию.

Вариант 2:
При удалении категории, переносить статьи в другую категорию

В чем вопрос то?

(Отредактировано автором: 10 Февраля, 2013 - 22:34:39)

 
 Top
DelphinPRO
Отправлено: 10 Февраля, 2013 - 22:37:58
Post Id



Активный участник


Покинул форум
Сообщений всего: 7187
Дата рег-ции: Февр. 2012  


Помог: 353 раз(а)




можно в БД использовать внешние ключи (foreign keys) с "ON DELETE CASCADE"

можно скриптом проверять наличие вложенных категорий\дочерних статей и
1)удалять их тоже
2)сообщать пользователю что низя удалить
3)переносить их в самую верхнюю категорию (вне категорий)


-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB