数值越界测试:
create table tt1(num tinyint);
基本语法:
bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。
insert into tt4 values(65, 65);
select * from tt4;
如果我们有这样的值,只存放0或1,这时可以定义bit(1)。这样可以节省空间。
语法:
float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节
案例:
小数:float(4,2)表示的范围是-99.99 ~ 99.99,MySQL在保存值时会进行四舍五入
。
问题: 当我们的float(4,2)如果是一个有符号的,则表示范围是-99.99 ~ 99.99,如果float(6,3),请说说范围是多少?
-999.999~999.999
案例:
如果定义的是float(4,2) unsigned 这时,因为把它指定为无符号的数,范围是 0 ~ 99.99
语法:
decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数。
有区别
:float和decimal表示的精度不一样
decimal
的精度更准确
,因此如果我们希望某个数据表示高精度,选择decimal。语法:char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值
可以为255
。
案例(char):
说明:
char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过2个, 最大只能是255。
语法:varchar(L): 可变长度字符串
(这是重点,char是定长字符串,而varchar是变长字符串
。),L表示字符长度,**最大长度65535个字节**
。
案例:
说明:关于varchar(len),len到底是多大,这个len值,和表的编码密切相关:
有1 - 3 个字节用于记录数据大小
,所以说有效字节数是65532
。mysql> create table t11(name varchar(21845)) charset=utf8;
/*验证了utf8确实是不能超过21844*/
ERROR 1118 (42000): Row size too large. The maximum row
size for the used table type, not counting BLOBs, is 65535.
This includes storage overhead, check the manual. You have to
change some columns to TEXT or BLOBs
mysql> create table t11(name varchar(21844)) charset=utf8;
Query OK, 0 rows affected (0.02 sec)
长度都一样,就使用定长
(char),比如:身份证,手机号,md5但是你要保证最长的能存的进去。
常用的日期有如下三个:
date
:日期 ‘yyyy-mm-dd
’ ,占用三字节。datetime
时间日期格式 ‘yyyy-mm-dd HH:ii:ss
’ 表示范围从 1000 到 9999 ,占用八字节
。timestamp
:时间戳,从1970年开始
的 yyyy-mm-dd HH:ii:ss
格式和 datetime
完全一致,占用四字节
。案例:
说明如果添加数据是不给时间戳输入值,时间戳默认给定当前时间。
以上说明,你更新表里面的数据,时间戳又会自动更新至当前时间。
语法:
该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,…最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。
该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,…
说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。最多64个。
案例:有一个调查表votes,需要调查人的喜好, 比如(登山,游泳,篮球,武术)中去选择(可以多选),(男,女)[单选]
使用如下查询语句:
不能查询出所有,爱好为登山的人。
集合查询使用find_ in_ set函数
:
find_in_set(sub,str_list) :如果 sub 在 str_list 中,
则返回下标;如果不在,返回0;str_list 用逗号分隔的字符串。