很高兴回答你的问题:
bit和tinyint类型肯定用的多。
从数字类型概述:
1、BIT [(M)]
位字段类型。M表示每个值的位数,从1到64.如果省略M,则缺省值为1。
此数据类型已添加到MyISAM的MySQL 5.0.3中,并已在5.0.5中扩展到MEMORY,InnoDB,BDB和NDBCLUSTER。在5.0.3之前,BIT是TINYINT(1)的同义词。
是数字类型,存储小数, 一般对应编辑语言里的小字典或枚举类型. 节省空间的同时, 避免存入超范围的值
2、TINYINT [(M)] [UNSIGNED] [ZEROFILL]
一个非常小的整数。有符号范围是-128到127.无符号范围是0到255。
多用于存储状态. 如bit(1) 直接对应Java语言的布尔类型true和false. 用做状态保存时一个字段可以保存多至64个状态。
另外考虑这一点:
1、BOOL,BOOLEAN
这些类型是TINYINT(1)的同义词。零值被认为是错误的。非零值被认为是真实的。
综上所述,在我的项目中我一般用bit(1)存布尔型,因为它只占一个字节,当然也可以用int,但是会造成资源浪费。
枚举类推荐用tinyint,当然也可以用enum ,但是移植性不太好。
Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有