MySQL建表的几个注意事项

    最近为公司项目建立数据库,这本来是很简单的工作,也很多方式去做,图形界面是最简单的方法了,但是作为一名有追求的程序员,还是选择命令行界面直接用SQl语句去建。期间发现一些问题,这些问题我想不管是用什么方式都可能遇到的,在此做个记录吧。

    其实,如果仅仅是建立一些表的话是非常简单的,问题在于表与表之间的关系,字段之间也有联系,字段本身还有着自己的属性,一旦这些结合在一起,往往会出现一些意想不到的结果。

    1.字段属性与外键。外键是什么就不解释了,设表2中的字段B要关联表1中的字段A,那么A就必须为主键或具有Unique属性,其实关键还是在于字段A必须具有唯一性。道理很简单,就好像登录名不能重复一样,假设登录名重复,那么登录时很明显系统会出错,因为不知道是哪个用户,同理,字段A必须要唯一。

    2.还是外键。一般设置外键时默认约束是Restrict,而这其实是不好的,尤其是当你想修改一个表中的数据却发现结果失败的时候。而约束有Delete和Update时需要注意其中的SET NULL,还是以表1、2为例,如果字段A是NOT NULL时,设置SET NULL是会失败的。道理很明显,不解释了。

  以上只是一些最基础的知识,学无止境……

  最后为了关闭的射手和清理内容的人人,(#‵′)凸,至于对象,你懂得……

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值