Mysql-函数

1.常用函数

1、数据函数

SELECT ABS(-8);			-- 绝对值
SELECT CEIL(9.4);		-- 向上取整
SELECT FLOOR(9.4);		-- 向下取整
select round(x,y);    	-- 求参数x的四舍五入的值,保留y位小数
select sqrt(x);       	-- 算术平方根
select pow(m, n);      	-- m^n
select pi();           	-- 获得圆周率
SELECT RAND();			-- 随机数,返回一个0-1之间的随机数
SELECT SIGN(0);			-- 符号函数: 负数返回-1,正数返回1,0返回0
SELECT MOD(x,y);		-- 返回x/y的模

2、字符串函数

SELECT CONCAT('我','爱','程序'); -- 合并字符串,参数可以有多个
SELECT LOWER('KuangShen'); 		-- 将字符串str全部转为小写
SELECT UPPER('KuangShen');		-- 将字符串str全部转为大写
SELECT LPAD(str,n,pad); 		-- 左填充,用字符串pad对str的左边进行填充,达到n个字符串长度
SELECT RPAD(str,n,pad); 		-- 左填充,用字符串pad对str的左边进行填充,达到n个字符串长度
SELECT TRIM(str); 				-- 去掉字符串头部和尾部的空格
select rtrim(string); 			-- 去除后端空格
select substring(str,start,len) -- 返回从字符串str从start位置起的len个长度的字符串
# select substring('abcdefg',2,2);结果:bc

SELECT CHAR_LENGTH('坚持就成功'); -- 返回字符串包含的字符数
select length(string);			-- string长度,字节
SELECT INSERT('我爱编程helloworld',1,2,'超级热爱');	-- 替换字符串,从某个位置开始替换某个长度(下标从1开始)
#结果 超级热爱编程helloworld

SELECT LEFT('hello,world',5);		-- 从左边截取
SELECT RIGHT('hello,world',5);		-- 从右边截取
SELECT REPLACE('狂神说坚持就能成功','坚持','努力');		-- 替换字符串
SELECT SUBSTR('狂神说坚持就能成功',4,6);		-- 截取字符串,开始和长度
#结果 坚持就能成功
 
SELECT REVERSE('狂神说坚持就能成功');		-- 反转
select repeat(string, count);			-- 重复count次
#结果:select repeat('密码',6); 密码密码密码密码密码密码

3、日期和时间函数

SELECT CURDATE();			-- 获取当前日期
SELECT CURTIME();			-- 返回当前时间
SELECT NOW();				-- 获取当前日期和时间
 
SELECT CURRENT_DATE();		-- 获取当前日期
SELECT LOCALTIME();			-- 获取当前日期和时间
SELECT SYSDATE();			-- 获取当前日期和时间
SELECT DATE_ADD(date, INTERVAL exprtype); -- 返回一个日期/时间值加上一个时间间隔expr后的时间值
SELECT DATEDIFF(date1,date2);			  -- 返回起始时间date1和结束时间date2之间的天数
 
 -- 获取年月日,时分秒
SELECT YEAR(NOW());
SELECT MONTH(NOW());
SELECT DAY(NOW());
SELECT HOUR(NOW());
SELECT MINUTE(NOW());
SELECT SECOND(NOW());

4、系统信息函数

SELECT VERSION();  /*版本*/
SELECT USER();     /*用户*/

5、流程函数

SELECT IF(value , t , f);			-- 如果value为true,则返回t,否则返回f
SELECT IFNULL(value1 , value2);		-- 如果value1不为空,返回value1,否则返回value2

-- 如果val1为true,返回res1,... 否则返回default默认值
SELECT CASE WHEN [ val1 ] THEN [res1] ...ELSE [ default ] END;	

-- 如果expr的值等于val1,返回res1,... 否则返回default默认值
SELECT CASE [ expr ] WHEN [ val1 ] THEN [res1] ... ELSE [ default ] END;

# 示例1:
select 
	( case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end ) as '工作地址'
from emp;

# 示例2:
select
	(case when math >= 85 then '优秀' when math >=60 then '及格' else '不及格' end ) '数学',
	(case when english >= 85 then '优秀' when english >=60 then '及格' else '不及格' end ) '英语',
	(case when chinese >= 85 then '优秀' when chinese >=60 then '及格' else '不及格' end ) '语文'
from score;

2.MD5 加密

一、MD5简介

MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。

二、实现数据加密

新建一个表 testmd5

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,'kuangshen','123456'),(2,'qinjiang','456789')

如果我们要对pwd这一列数据进行加密,语法是:

update testmd5 set pwd = md5(pwd);

如果单独对某个用户(如kuangshen)的密码加密:

INSERT INTO testmd5 VALUES(3,'kuangshen2','123456')
update testmd5 set pwd = md5(pwd) where name = 'kuangshen2';

插入新的数据自动加密

INSERT INTO testmd5 VALUES(4,'kuangshen3',md5('123456'));

查询登录用户信息(md5对比使用,查看用户输入加密后的密码进行比对)

SELECT * FROM testmd5 WHERE `name`='kuangshen' AND pwd=MD5('123456');
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值