带有外键约束的SQL删除查询

我知道这个问题属于数据库理论的早期阶段,但几个月以来我没有遇到过这样的问题.如果某人有一个数据库,其中一些表关联在一起作为外键的“链”,并且他们想要从具有某些“依赖”表的表中删除记录,会出现什么障碍?特别是在带有表的数据库中:Person,Profile,Preference,Filter存在关联,因为Person.id是Profile中的外键,Profile.id是Preference中的外键,Filter.id是Preference中的外键,因此这里所有的associationsenter代码都是OneToMany.是否可以使用简单查询删除Person:

Delete from Person p where p.id= 34;

如果不是,为了成功执行删除,应该如何查询?
如果应用程序中的数据库是由hibernate管理的,那么我应该将哪些约束(注释)应用于每个实体的关联字段,以便能够使用上述简单查询来执行删除?

最佳答案 FOR SQL VERSION

看一下截图.您可以使用“插入更新规范”规则.因为它有删除和更新规则.您可以设置这些值中的任何一个.

可以通过引用主键或唯一键来创建外键约束.外键约束确保关联表中数据的关系完整性.外键值可以为NULL,表示特定记录没有父记录.但是,如果存在值,则它必须在父表中具有关联值.在父表上应用更新或删除操作时,对子表中关联值的影响可能有不同的要求. SQL Server 2005和2008中有四个可用选项,如下所示:

No Action
Cascade
SET NULL
SET Default

将本文用于Refrence.

http://www.mssqltips.com/sqlservertip/2365/sql-server-foreign-key-update-and-delete-rules/

ORACLE版本

你可以使用下面的一个.

alter table sample1
   添加外键(col1)
引用
   样本(col2)
删除没有动作;

alter table sample1
添加外键(col1)
引用
   样本(col2)
关于删除限制;

alter table sample1
添加外键(col1)
   参考样本(col2)
关于删除级联;

为了refrance.

http://docs.oracle.com/cd/B19306_01/server.102/b14200/clauses002.htm

点赞