如何修改mysql中key

如何修改mysql中key,第1张

PRI primary key 表示主键,唯一写法: id bigint(20) unsigned primary key not null ,

uni UNIQUE 表示唯一 写法 id bigint(20) unsigned UNIQUE default NULL

mul 添加了索引 写法: alter table test add index suoyin (col_name1)

如果有同时存在,

显示顺序 PRI>UNI>MUL

你这样设置之后,是不能插入的空(NULL),而是能插入空串(\\'\\')。

如果不让插入空串,应该使用check,例如:

CREATE TABLE table2 (

title varchar(50) NOT NULL,

message varchar(200) NOT NULL DEFAULT \\'内容\\',

msname varchar(50) NOT NULL DEFAULT \\'发布人\\',

date date NOT NULL,

PRIMARY KEY (`title`) ,

CHECK (title!=\\'\\')

)

为已经添加好的数据表添加外键:

语法:alter table 表名 add constraint FK_ID foreign key(你的外键字段名) REFERENCES 外表表名(对应的表的主键字段名)

例: alter table tb_active add constraint FK_ID foreign key(user_id) REFERENCES tb_user(id)

//FK_ID是外键的名称

/*

CREATE TABLE `tb_active` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`title` varchar(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,

`content` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,

`user_id` int(11) NOT NULL,

PRIMARY KEY (`id`),

KEY `user_id` (`user_id`),

KEY `user_id_2` (`user_id`),

CONSTRAINT `FK_ID` FOREIGN KEY (`user_id`) REFERENCES `tb_user` (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=latin1

*/

删除外键

语法: ALTER TABLE table-name DROP FOREIGN KEY key-id

例: ALTER TABLE `tb_active` DROP FOREIGN KEY 'FK_ID'

自动键更新和删除:

外键可以保证新插入的记录的完整性,但是,如果在REFERENCES从句中已命名的表删除记录会怎么样?在使用同样的值作为外键的辅助表中会发生什么?

很明显,那些记录也应该被删除,否则在数据库中就会有很多无意义的孤立记录,MYSQL可以通过向FOREIGN KEY...REFERENCES修饰符添加一个ON DELETE 或ON UPDATE子句简化任务,它告诉了数据库在这种情况如何处理孤立任务。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/8600310.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-18
下一篇 2023-04-18

发表评论

登录后才能评论

评论列表(0条)

保存