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');


posted @ 2020-08-25 09:17  DannyBoy~  阅读(126)  评论(0编辑  收藏  举报