For investors
股价:
5.36 美元 %For investors
股价:
5.36 美元 %认真做教育 专心促就业
数据类型是程序员在学习软件编程开发技术的时候需要重点掌握的一个编程知识点,今天我们就通过案例分析来简单了解一下,常见数据类型都有哪些。
1.整数类型
tinyint(8位)、smallint(16位)、mediumint(24位)、int(32位)、bigint(64位)
整形类型有可选择的unsigned的属性,如果不需要负数,则使用unsigned会使得存储正数的范围提高到一倍,比如tinyint存储范围为-128---127,使用tinyintunsigned存储的范围变为0---255。
MySQL可以为整数类型指定宽度例如:int(11),但是对于大多数应用这是没有意义的:因为它不会限制值得合法范围,只是规定了MySQL的一些交互工具用来显示字符的个数,对于存储和计算来说,int(11)跟int(20)没有任何的区别。
2.实数类型
可以使用decimal存储比bigint还大的整数,decimal用来存储精确的小数,在MySQL5.0以上的版本中decimal还支持高精度的计算。decimal可以指定小数点前后所允许的大位数,MySQL会将数字打包存储在一个二进制的字符串中。浮点类型在存储同样范围的值时,通常比decimal使用更少的空间。
选择:因为需要额外的空间计算和开销,所以应该尽量只在对小数进行计算的时候才使用decimal----涉及到财务计算类的业务。但是在数据量比较大的时候可以考虑使用bigint代替decimal,将需要存储的货币单位根据小数的位数乘以相应的倍数即可,这样就可以避免浮点计算的不精确和decimal精确计算的代价高的问题。
3.字符串类型
varchar类型:
varchar类型用于存储可变长度的字符串,是常见的字符串数据类型,它比定长类型更加的节省空间,因为它仅仅使用必要的空间,字符串越短存储空间越小;varchar需要使用1到2个额外的字节来记录字符串的长度:如果字符串长度小于255使用1个字节记录反之使用两个字节存储。比如varchar(1000)它需要1002个字节,因为需要两个字节存储字符串的长度。
在下面的几种情况下使用varchar是合适的:字符串列的大长度比平均长度大很多;列的更新很少;使用了utf-8这样的复杂的字符集。
char类型:
char类型是定长的:MySQL总是根据定义的字符集长度分配足够的空间。char适合存储很短的字符串,或者所有值都接近同一个长度。例如char非常的适合存储密码的MD5值,因为这些值得长度都定长。对于经常变动的值使用char比varchar更好,因为定长的char类型不容易产生碎片。对于非常短的列,char比varchar在存储空间上也有更好的效率。比如在存储“是”和“否”使用char(1)只使用一个字节,使用varchar(1)却需要两个字节,另一个来存储记录的长度。
4.blob和text类型
它们两个都被设计来存储很大的字符串类型的数据,blog使用二进制方式存储没有排序规则或字符集,text使用字符串方式存储有排序规则和字符集。与其他数据类型不同的是:MySQL把bolb和text值当做一个独立的对象处理。当它们的值太大时,InnoDB会使用专门的“外部”存储区域进行存储,这时每个值在行内需要1--4个字节存储一个指针,然后在外部存储真实的值。
对于bolb和text的排序规则也和其他的数据类型不同:bolb和text会对其中前sort_length字符排序,二不是整个字符串排序,还可以指定前多少个字符进行排序,只需要减少max_sort_length的配置即可。
【免责声明】本文系本网编辑部分转载,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与管理员联系,我们会予以更改或删除相关文章,以保证您的权益!请读者仅作参考。更多内容请加抖音太原达内IT培训学习了解。