类型转换函数
类型转换函数和case函数
1.隐式类型转换和显式类型转换的概念
隐式类型装换:
两个值进行运算或者比较,首先要求数据类型必须一致。如果发现两个数据类型不一致时就会发生隐式类型转换。例如,把字符串转成数字,或者相反:
SELECT 1+‘1’; – 字符串1转成数字
SELECT concat(2,’ test’); – 数字2转成字符串
显式类型转换:
利用函数进行数据类型的转换
2.Cast函数
CAST(expr AS type)
将任意类型的表达式expr转换成指定类型type的值。type可以是以下任意类型之一:
BINARY[(N)] :二进制字符串,转换后长度小于N个字节( 不足长度N则尾部补上0x00 )
CHAR[(N)] :字符串,转换后长度小于N个字符
DATE :日期
DATETIME :日期时间
DECIMAL[(M[,N])] :浮点数,M为数字总位数(包括整数部分和小数部分),N为小数点后的位数
SIGNED [INTEGER] :有符号整数
TIME :时间
UNSIGNED [INTEGER] :无符号整数
字符串转成数字
转成decimal时,从头扫描字符串直到第一个不为数字的字符为至。对截断的那一位进行四舍五入
1)默认不限定M,N,转换为整数,按照小数点后第一位进行四舍五入:
SELECT cast(‘28.82abc’ AS DECIMAL);
2)限定M不限定N,转换为整数(M尽量大一些):
SELECT cast(‘28.82abc’ AS DECIMAL(4));
如果M的长度小于实际