5、MySQL函数
5、MySQL函数
文档在官网:https://dev.mysql.com/doc/refman/5.7/en/sql-function-reference.html
5.1、常用函数
-- ==============常用函数=========
-- 数学运算
SELECT ABS(-12)-- 绝对值
SELECT CEILING(12.3) -- 向上取整13
SELECT FLOOR(12.3) -- 向下取整12
SELECT RAND()-- 返回随机数
SELECT SIGN(-10)-- 判断一个数的符号 0-0 负数为-1,正数为1
-- 字符串函数
SELECT CHAR_LENGTH('哈哈哈哈哈哈') -- 查看字符串长度
SELECT CONCAT('hello','sql','world') -- 拼接字符串
SELECT INSERT('编程超酷行吧',1,2,'跑酷') -- 从某个字符串,替换几个字符串
SELECT REPLACE('坚持就能成功','坚持','努力')-- 用某个字符串代替某个字符串
SELECT LOWER('sjdfnHHHHHHH') -- 转为小写
SELECT UPPER('xjcsndkjcnsdkj') -- 转为大写
SELECT INSTR('asnks','k') -- 返回第一次出现子串的索引
SELECT SUBSTR('爱上了错买的什么V',3,2) --返回指定的子字符串(源字符串,截取的位置,截取的长度)
SELECT REVERSE('十八级大台风') -- 反转
-- 查询姓张的同学,将其姓字改为何
SELECT REPLACE(`studentname`,'张','何')
FROM `student`
WHERE `studentname` LIKE '张%'
-- 时间和日期函数(记住)
SELECT CURRENT_DATE() -- 获取当前日期
SELECT CURDATE() -- 获取当前日期
SELECT NOW() -- 获取当前时间
SELECT LOCALTIME() -- 获取当地时间
SELECT SYSDATE() -- 获取系统时间
SELECT YEAR(NOW())
SELECT MONTH(NOW())
SELECT DAY(NOW())
SELECT HOUR(NOW())
SELECT MINUTE(NOW())
SELECT SECOND(NOW())
-- 系统
SELECT SYSTEM_USER() -- 获取系统用户
SELECT USER()
SELECT VERSION() -- 查看MySQL的版本号
5.2、聚合函数(常用)
函数名称 | 描述 |
---|---|
COUNT() | 计数 |
SUM() | 求和 |
AVG() | 平均值 |
MAX() | 最大值 |
MIN() | 最小值 |
..... | ...... |
-- =======聚合函数=============
-- 都能统计 表中的数据(想查询一个表有多少记录,用count函数)
SELECT COUNT(`studentno`) FROM `student` -- count(字段),会忽略null值
SELECT COUNT(*) FROM `student` -- 不会忽略null值,本质 计算行数
SELECT COUNT(1) FROM `student` -- 不会忽略null值,本质 计算行数,这个与上一条没有太大差别
SELECT SUM(`studentresult`) AS 总和 FROM `result`;
SELECT AVG(`studentresult`) AS 平均值 FROM `result`;
SELECT MAX(`studentresult`) AS 最高分 FROM `result`;
SELECT MIN(`studentresult`) AS 最低分 FROM `result`;
5.3、数据库级别的MD5加密(扩展)
什么是MD5?
主要是增强算法复杂度和不可逆性
MD5不可逆,具体相同的值经过MD5加密后,是相同的
MD5 破解网站的原理,背后有一个字典,MD5加密后的值与MD5加密前的值相对应。
-- ======测试MD5加密=======
CREATE TABLE `testMD5`(
`id` INT(4) NOT NULL,
`name` VARCHAR(20) NOT NULL,
`pwd` VARCHAR(50) NOT NULL,
PRIMARY KEY(`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
-- 明文密码
INSERT INTO `testmd5` VALUES ('1','张三','12345'),('2','李四','44444'),('3','王五','55555');
-- 加密特定一行
UPDATE `testmd5` SET `pwd`=MD5(`pwd`) WHERE id=1
-- 加密所有
UPDATE `testmd5` SET `pwd`=MD5(`pwd`)
-- 插入的时候,加密
INSERT INTO `testmd5` VALUES ('4','赵四',MD5('12345'))
-- 如何校验:将用户输入的密码进行MD5加密,然后对比加密后的值
SELECT * FROM `testmd5` WHERE `pwd`=MD5('55555');