数据库外键的注意事项

阻止执行

  • 从表插入新行,其外键值不是主表的主键值便阻止插入;
  • 从表修改外键值,新值不是主表的主键值便阻止修改;
  • 主表删除行,其主键值在从表里存在便阻止删除(要想删除,必须先删除从表的相关行);
  • 主表修改主键值,旧值在从表里存在便阻止修改(要想修改,必须先删除从表的相关行)。

级联执行

  • 主表删除行,连带从表的相关行一起删除;
  • 主表修改主键值,连带从表相关行的外键值一起修改。两种方法提供给用户选择。无论选取哪种方法,从表里都* 不会有多余行。从另一个角度理解,用拒绝同一事物在从表中的标志与主表不一致来实现与主表中的标志一致。

两种实现方法,通过下面方式选择:

  • 界面:设级联更新、级联删除两个选择方框,选取则级联执行、不选取则阻止执行;
  • 命令:设E)kSCM)E、RESTRICT两个可选项,CASCADE为级联执行、RESTRICT为阻止执行。
MySQL 和 MongoDB 两者都是免费开源的数据库。在建表时,需要注意以下几点: 1. 遵循面向对象原则,保证每列与主键相关。 2. 遵循表职能单一性原则,如果一张表负责了两个或两个以上的职责,那么该表应进行拆分。 3. 遵循表字段与表直接关联原则,如果一个字段与当前表是间接关联的,那么就该创建一张新的表来保存该字段。 4. 遵循字段最小原子化原则,一个字段如果包含了多个信息或含义,则该字段就应该拆成多个字段。 5. 遵循字段名唯一原则,所有字段不允许单个单词形式存在,应该使用有意义的名称。 6. 不创建外键关联,只是外键关系,设计中的外键仅是为了让大家知道其对应的表才写进去的,实际并不需要数据库中创建外键。 7. 尽量少使用存储过程,除非某个功能对性能要求非常高,且没办法通过存储过程以外的方式来提升性能时,才考虑使用存储过程。 8. 应针对所有表的主键和外键建立索引,有针对性的建立组合属性的索引,提高检索效率。 9. 必须建立业务主键,除自增id之外,需要使用业务主键,常使用”业务前缀+时间戳+随机数”组成,实现简单,与数据库无关,移植性较好。 10. 所有字段不允许空值,varchar类型默认统一设置为”Empty String”,此处不使用NULL。区别:NULL,默认存为(Null),指的是对象;Empty String默认存为空串””,在java中进行非空判断存在区别userId==null/userId.equals(“”);数值类型默认为0。 11. 表中字段根据数据类型统一,数值类:bigint,金额:decimal,状态:tinyint,时间:datetime。 12. 每张表需要建立索引,建立索引方式:选取使用频率最高的字段作为索引字段。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值