如何设置主键和外键,实现级联更新、级联删除
来源:互联网 发布:怎么改mac的用户名 编辑:程序博客网 时间:2024/06/08 10:00
设置索引
若要设置外键,在参照表(pc表) 和被参照表(parts表)中,相对应的两个字段必须都设置索引(index)。
对parts表:
ALTER TABLE parts ADD INDEX idx_model (model);
这句话的意思是,为parts表增加一个索引,索引建立在model字段上,给这个索引起个名字叫idx_model。
对pc表也类似:
ALTER TABLE pc ADD INDEX idx_cpumodel (cpumodel);
定义外键
下面为两张表之间建立前面所述的那种“约束”。因为pc的CPU型号必须参照parts表中的相应型号,所以我们将pc表的cpumodel字段设置为“外键”(FOREIGN KEY),即这个键的参照值来自于其他表。
ALTER TABLE pc ADD CONSTRAINT fk_cpu_model
FOREIGN KEY (cpumodel)
REFERENCES parts(model);
级联操作
级联更新:更新主键时,外键也随之更新。
可以在定义外键的时候,在最后加入这样的关键字:
ON UPDATE CASCADE;
即在主表更新时,子表(们)产生连锁更新动作,似乎有些人喜欢把这个叫“级联”操作。
如果把这语句完整的写出来,就是:
ALTER TABLE pc ADD CONSTRAINT fk_cpu_model
FOREIGN KEY (cpumodel)
REFERENCES parts(model)
ON UPDATE CASCADE;
级联删除:删除主键时,外键也随之删除。
ALTER TABLE pc ADD CONSTRAINT fk_cpu_model
FOREIGN KEY (cpumodel)
REFERENCES parts(model)
ON DELETE CASCADE;
级联更新、删除:
on update cascade on delete cascade
SQLServer2005设置级联删除、级联更新在使用LINQ时,数据库中有表外键关联时,删除操作有时会出错,尽管还可以用SQL语句,但有时将这种操作交给数据库,会节省很多开销。一、选择"关系"二、更改"INSERT和UPDATE规范"SQLServer2005中的"层叠"就是SQLServer2000中的"级联"按照上面的方法,将数据库中所有表都更改一遍,这样在LINQ中删除时,数据库便自动级联删除了
- 如何设置主键和外键,实现级联更新、级联删除
- mysql如何设置主键和外键,实现级联更新、级联删除
- 如何设置主键和外键,实现级联更新、级联删除
- 数据库__SQL的主键和外键约束_级联更新_级联删除
- Oracle外键级联删除和级联更新
- Oracle外键级联删除和级联更新
- Oracle外键级联删除和级联更新
- Oracle外键级联删除和级联更新
- Oracle外键级联删除和级联更新
- Oracle外键级联删除和级联更新
- Oracle外键级联删除和级联更新
- Oracle外键级联删除和级联更新
- SQL SERVER 主键和外键中的 级联删除(ON DELETE CASCADE)和级联更新(ON UPDATE CASCADE)
- SQL SERVER 主键和外键中的 级联删除(ON DELETE CASCADE)和级联更新(ON UPDATE CASCADE)
- 建立外键关系,实现级联更新和删除
- MySQL外键设置和级联删除
- 级联删除和更新
- 级联删除和更新
- 任意两点间的最短路问题(floyd算法)
- 596. Classes More Than 5 Students
- Zookeeper与Paxos
- rabbitmq(二)
- 查看oracle当前session
- 如何设置主键和外键,实现级联更新、级联删除
- Base64图片工具类-JAVA
- 动态手势识别--手势采集与手势匹配界面(四)
- E
- Codeforces Round #421 (Div. 2) | B. Mister B and Angle in Polygon
- SHELL编程
- 关于多线程的使用
- ECMAScript新功能介绍(es6 es2015)
- Windows下80端口被进程System&PID=4占用的解决方法