数据库复习(2)
1.单行函数
函数在计算机语言的使用中贯穿始终,函数的作用是什么呢?它可以把我们经常使用的代码封装起来, 需要的时候直接调用即可。这样既 提高了代码效率 ,又 提高了可维护性 。在 SQL 中我们也可以使用函数对检索出来的数据进行函数操作。使用这些函数,可以极大地 提高用户对数据库的管理效率 。 从函数定义的角度出发,我们可以将函数分成 内置函数 和 自定义函数 。在 SQL 语言中,同样也包括了 内置函数和自定义函数。内置函数是系统内置的通用函数,而自定义函数是我们根据自己的需要编写 的函数
1.2 不同DBMS函数的差异
我们在使用 SQL 语言的时候,不是直接和这门语言打交道,而是通过它使用不同的数据库软件,即
DBMS。DBMS 之间的差异性很大,远大于同一个语言不同版本之间的差异。实际上,只有很少的函数是
被 DBMS 同时支持的。比如,大多数 DBMS 使用(||)或者(+)来做拼接符,而在 MySQL 中的字符串拼
接函数为concat()。大部分 DBMS 会有自己特定的函数,这就意味着采用 SQL 函数的代码可移植性是很
差的,因此在使用函数的时候需要特别注意。 MySQL提供的内置函数从 实现的功能角度 可以分为数值函数、字符串函数、日期和时间函数、流程控制
函数、加密与解密函数、获取MySQL信息函数、聚合函数等。这里,我将这些丰富的内置函数再分为两
类: 单行函数 、 聚合函数(或分组函数)
2. 数值函数
2. 基本函数
函数用法
ABS(x)
返回x的绝对值
SIGN(X)
返回X的符号。正数返回1,负数返回-1,0返回0
PI()
返回圆周率的值
CEIL(x),CEILING(x)
返回大于或等于某个值的最小整数
FLOOR(x)
返回小于或等于某个值的最大整数
LEAST(e1,e2,e3…)
返回列表中的最小值
GREATEST(e1,e2,e3…)
返回列表中的最大值
MOD(x,y)
返回X除以Y后的余数
RAND()
返回0~1的随机值
RAND(x)
返回0~1的随机值,其中x的值用作种子值,相同的X值会产生相同的随机
数
ROUND(x)
返回一个对x的值进行四舍五入后,最接近于X的整数
ROUND(x,y)
返回一个对x的值进行四舍五入后最接近X的值,并保留到小数点后面Y位
TRUNCATE(x,y)
返回数字x截断为y位小数的结果
SQRT(x)
返回x的平方根。当X的值为负数时,返回NULL
3. 进制间的转换
BIN(x)
返回x的二进制编码
HEX(x)
返回x的十六进制编码
OCT(x)
返回x的八进制编码
CONV(x,f1,f2)
返回f1进制数变成f2进制数
4. 字符串函数
ASCII(S)
返回字符串S中的第一个字符的ASCII码值
CHAR_LENGTH(s)
返回字符串s的字符数。作用与CHARACTER_LENGTH(s)相同
LENGTH(s)
返回字符串s的字节数,和字符集有关
CONCAT(s1,s2,......,sn)
连接s1,s2,......,sn为一个字符串
CONCAT_WS(x,
s1,s2,......,sn)
同CONCAT(s1,s2,...)函数,但是每个字符串之间要加上x
INSERT(str, idx, len,
replacestr)
将字符串str从第idx位置开始,len个字符长的子串替换为字符串replacestr
REPLACE(str, a, b)
用字符串b替换字符串str中所有出现的字符串a
UPPER(s) 或 UCASE(s)
将字符串s的所有字母转成大写字母
LOWER(s) 或LCASE(s)
将字符串s的所有字母转成小写字母
LEFT(str,n)
返回字符串str最左边的n个字符
RIGHT(str,n)
返回字符串str最右边的n个字符
LPAD(str, len, pad)
用字符串pad对str最左边进行填充,直到str的长度为len个字符
RPAD(str ,len, pad)
用字符串pad对str最右边进行填充,直到str的长度为len个字符
LTRIM(s)
去掉字符串s左侧的空格
RTRIM(s)
去掉字符串s右侧的空格
TRIM(s)
去掉字符串s开始与结尾的空格
TRIM(s1 FROM s)
去掉字符串s开始与结尾的s1
TRIM(LEADING s1
FROM s)
去掉字符串s开始处的s1
TRIM(TRAILING s1
FROM s)
去掉字符串s结尾处的s1
REPEAT(str, n)
返回str重复n次的结果
SPACE(n)
返回n个空格
STRCMP(s1,s2)
比较字符串s1,s2的ASCII码值的大小
SUBSTR(s,index,len)
返回从字符串s的index位置其len个字符,作用与SUBSTRING(s,n,len)、
MID(s,n,len)相同
LOCATE(substr,str)
返回字符串substr在字符串str中首次出现的位置,作用于POSITION(substr
IN str)、INSTR(str,substr)相同。未找到,返回0
ELT(m,s1,s2,…,sn)
返回指定位置的字符串,如果m=1,则返回s1,如果m=2,则返回s2,如
果m=n,则返回sn
FIELD(s,s1,s2,…,sn)
返回字符串s在字符串列表中第一次出现的位置
5.获取月份、星期、星期数、天数等函数
YEAR(date) / MONTH(date) / DAY(date)
返回具体的日期值
HOUR(time) / MINUTE(time) /
SECOND(time)
返回具体的时间值
MONTHNAME(date)
返回月份:January,...
DAYNAME(date)
返回星期几:MONDAY,TUESDAY.....SUNDAY
WEEKDAY(date)
返回周几,注意,周1是0,周2是1,。。。周日是6
QUARTER(date)
返回日期对应的季度,范围为1~4
WEEK(date) , WEEKOFYEAR(date)
返回一年中的第几周
DAYOFYEAR(date)
返回日期是一年中的第几天
DAYOFMONTH(date)
返回日期位于所在月份的第几天
DAYOFWEEK(date)
返回周几,注意:周日是1,周一是2,。。。周六是