这里的第一个问题:
目前我正在开发一个需要使用3个不同实体的项目。 这些实体是:用户,场地和设施。
每个实体都有其表格:
设施表:
CREATE TABLE `facility` (
`facility_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`venue_id` INT(10) UNSIGNED NOT NULL,
`name` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`surface` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`max_timeblock` INT(10) UNSIGNED NOT NULL,
`min_timeblock` INT(10) UNSIGNED NOT NULL,
`availability` INT(10) UNSIGNED NOT NULL,
PRIMARY KEY (`facility_id`),
UNIQUE INDEX `facility_id` (`facility_id`),
INDEX `facility-venue_id_key` (`venue_id`),
CONSTRAINT `facility-venue_id_key` FOREIGN KEY (`venue_id`) REFERENCES `venue` (`venue_id`) ON UPDATE CASCADE ON DELETE CASCADE)
地点表:
CREATE TABLE `venue` (
`venue_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`name` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`description` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`email` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`phone` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`opening_time` TIME NOT NULL,
`closing_time` TIME NOT NULL,
`booking_conditions` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`booking_method` INT(10) UNSIGNED NOT NULL,
`status` INT(10) UNSIGNED NULL DEFAULT NULL,
PRIMARY KEY (`venue_id`),
UNIQUE INDEX `venue_id` (`venue_id`)
)
用户表:
CREATE TABLE `user` (
`user_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'This field will hold the Unique ID for each user.',
`username` VARCHAR(50) NOT NULL COMMENT 'This field will be classed as a display name for the users so when searching they arent looking for the ID.' COLLATE 'utf8_unicode_ci',
`email` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`password` VARCHAR(128) NOT NULL COLLATE 'utf8_unicode_ci',
`first_name` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`last_name` VARCHAR(50) NOT NULL COLLATE 'utf8_unicode_ci',
`facebook_id` VARCHAR(50) NULL DEFAULT NULL COLLATE 'utf8_unicode_ci',
`user_type_id` INT(10) NULL DEFAULT NULL,
`postcode` INT(10) NULL DEFAULT NULL,
`status` INT(10) NULL DEFAULT NULL,
`date_created` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00',
`date_modified` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`user_id`),
UNIQUE INDEX `username` (`username`),
UNIQUE INDEX `email` (`email`),
UNIQUE INDEX `user_id` (`user_id`)
)
因此,我试图实现A媒体表。
此表的一个示例如下:
CREATE TABLE `media` (
`media_id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`album_id` INT(10) UNSIGNED NULL DEFAULT '0',
`alt_name` VARCHAR(50) NOT NULL DEFAULT '0' COLLATE 'utf8_unicode_ci',
`mine_type` VARCHAR(50) NOT NULL DEFAULT '0' COLLATE 'utf8_unicode_ci',
`url_link` VARCHAR(50) NOT NULL DEFAULT '0' COLLATE 'utf8_unicode_ci',
PRIMARY KEY (`media_id`),
INDEX `media-album_id_key` (`album_id`),
CONSTRAINT `media-album_id_key` FOREIGN KEY (`album_id`) REFERENCES `album` (`album_id`) ON UPDATE CASCADE ON DELETE CASCADE
)
我想要的是允许用户,工具将1张图像与之关联,并让Venue与其关联相册。
因此我不确定如何在这方面实现外键,因为如果我将一列媒体放入Users表并将外键设置为Media_ID,如果我删除媒体,它会删除用户作为级联影响这样做。
我想要的是,如果我删除用户/设施/场地,它将删除与其相关的所有图像。
任何帮助都将不胜感激。
此致
罗伯特
答案 0 :(得分:0)
你不能在不使用触发器的情况下直接做你想做的事情,所以我在这里列出了你的第一个选项,以及你真正应该避免的第二个选项,但会给你一个如何调查这个的线索模式问题进一步发展。
media
表,但使用ON DELETE SET NULL
而不是ON DELETE CASCADE
参照操作,然后实施相关媒体的删除您的应用程序代码(或触发器)