mysql数据库建表分类字段--尽量少用字符串--原因探索

3 篇文章 0 订阅
2 篇文章 0 订阅
  • 虽然一直都知道,类型 之类的字段 直接用字符窜会很方便,不过最好还是不要用字符串;但是也不是特别清楚为什么不要用,时间久了 就忍不住用一下字符窜试试,这一试 还挺好用的,吓得我 感觉探究了一下 为什么最好不要用字符窜。

  • 一是从空间上考虑,对于类型 分类的字段来说,用int代表不同的类型,比varchar 更节省空间。 数据量少的时候 不明显,但是 数据量特别大,或者数据常加载到内存里 差别就比较明显了。

  • 二是 从 安全性考虑,varchar 容错性高,会导致 程序的bug 不能那么及时的体现出来 进而留下隐患,如果用 int 代表类型,则安全性会有不小的提升。

  • 三,为何不用 枚举: 破坏了范式要求; 不易拓展 更改代价昂贵,会重构整个数据表; 获取全部可能值麻烦;其他表中不可直接复用,移植性不佳; 优化提升有限!

  • 四,bool 最好也要少用,其原因 一是拓展不好,二是 在mysql里 创建bool 会被转为tinyint(1),写入大的数值会被截断,有警告 但是也可以执行。所以,布尔类型BOOL/BOOLEAN的功能等同于微整型TINYTINT; 不如直接用 int 更有助于理解。

  • 如果有不严谨的地方,欢迎指正。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值