IT评测·应用市场-qidao123.com

标题: 2022-08-18 MySQL常用函数 [打印本页]

作者: 刘俊凯    时间: 2022-9-16 17:18
标题: 2022-08-18 MySQL常用函数
MySQL常用函数

聚合函数

数值型函数

主要是对数值型进行处理。
  1. -- 绝对值
  2. select ABS(-4) 4的绝对值,ABS(-1.1);
  3. -- 向下取整,向上取整,四舍五入
  4. select CEILING(4.1),FLOOR(1.1),ROUND(-4.4)
  5. -- 取余
  6. select MOD(60,11);
  7. -- 随机数
  8. select RAND(),RAND(),RAND()
  9. -- 截断
  10. select TRUNCATE(2.33999999,2);
复制代码
字符串型函数

对字符串进行处理。
  1. select LEFT('abcdefg',2);
  2. select RIGHT('abcdefg',2);
  3. select REVERSE('hijklmn');
  4. select REPLACE('abcdefg','abc','x');
复制代码
日期和时间函数

date,time,datetime,timestamp,year。
获取时间和日期

  1. select CURRENT_DATE();
  2. select CURTIME();
  3. select now();
复制代码
时间戳和日期转换函数

  1. select UNIX_TIMESTAMP();
  2. select FROM_UNIXTIME(1660785720);
复制代码
根据日期获取年月日的数值
  1. select MONTH(SYSDATE());
  2. select MONTHNAME(SYSDATE());
  3. select DAYNAME(SYSDATE());
  4. select DAYOFWEEK(SYSDATE());
  5. select WEEK(SYSDATE());
  6. select DAYOFMONTH(SYSDATE());
  7. select YEAR(SYSDATE());
复制代码
时间日期的计算
  1. -- 日期加法
  2. select DATE_ADD(SYSDATE(),INTERVAL 70 DAY);
  3. -- 日期减法
  4. select DATE_SUB(SYSDATE(),INTERVAL 10 DAY);
  5. -- 时间间隔
  6. select DATEDIFF('2023-01-01',SYSDATE());
  7. -- 日期格式化
  8. select DATE_FORMAT(SYSDATE(),'%W %M %D %Y');
复制代码
加密函数
  1. -- 把传入的参数的字符串按照md5算法进行加密,得到一个32位的16进制的字符串
  2. select MD5('123456');
复制代码
md5算法是不可逆的。
流程控制函数

可以进行条件判断,用来实现SQL语句的逻辑。
  1. select IF(2 > 1,'a','b');
  2. select IFNULL(sal,0);
  3. select NULLIF(age,0);
复制代码
对一系列的值进行判断:
  1. -- 输出学生的各科的成绩,以及评级,60以下D,60-70是C,71-80是B,80以上是A
  2. SELECT
  3.         *,
  4. CASE
  5.                
  6.                 WHEN score < 60 THEN 'D' WHEN score >= 60
  7.                 AND score < 70 THEN 'C' WHEN score >= 70
  8.                         AND score < 80 THEN 'B' WHEN score >= 80 THEN
  9.                                 'A'
  10.                         END AS '评级'
  11.         FROM
  12.         mystudent;
复制代码
  1. -- 行转列
  2. SELECT
  3.         user_name,
  4.         max( CASE course WHEN '数学' THEN score ELSE 0 END ) '数学',
  5.         max( CASE course WHEN '语文' THEN score ELSE 0 END ) '语文',
  6.         max( CASE course WHEN '英语' THEN score ELSE 0 END ) '英语'
  7. FROM
  8.         mystudent
  9. GROUP BY
  10.         user_name
复制代码
数据库设计

三范式

第一范式

不符合第一范式表结构:
idname联系方式1001aaa[aaa@163.com , 13314569878](mailto:aaa@163.com , 13314569878)1002bbb[bbb@163.com , 13245678945](mailto:bbb@163.com , 13245678945)1003ccc[ccc@163.com , 15000456987](mailto:ccc@163.com , 15000456987)符合第一范式的表结构:
idname邮箱手机号1001aaaaaa@163.com123213213211002bbbbbb@163.com321326546541003cccccc@163.com45654654654必须有主键,这是数据库设计的基本要求,一般情况下我们采用数值型或定长字符串,列不能再分,比如:联系方式。
关于第一范式,保证每一行的数据是唯一,每个表必须有主键。
第二范式

建立在第一范式的基础上,要求所有非主键字段完全依赖于主键,不能产生部分依赖。
学号性别姓名课程编号课程名称教室成绩1001男a2001java301891002女b2002mysql302901003男c2003html303911004男d2004python304521005女e2005c++305671006男f2006c#30684解决方案:
学生表:学号是主键
学号性别姓名1001男a1002女b1003男c1004男d1005女e1006男f课程表:课程编号是主键
课程编号课程名称教室2001java3012002mysql3022003html3032004python3042005c++3052006c#306成绩表:学号和课程编号为联合主键
学号课程编号成绩100120018910022002901003200391100420045210052005671006200684第三范式

建立在第二范式基础上,非主键字段不能传递依赖于主键字段。
不满足第三范式:
学号姓名课程编号课程名称1001a2001java1002b2002mysql1003c2003html1004d2004python1005e2005c++1006f2006c#解决方案:
学生表:学号是主键
学号姓名课程编号1001a20011002b20021003c20031004d20041005e20051006f2006课程表:课程编号是主键
课程编号课程名称2001java2002mysql2003html2004python2005c++2006c#常见的表关系

一对一

学生信息表分为基本信息表和信息信息表。
一对多

两张表,外键在多的一方。
多对多

mysql未完待续....

索引,视图,存储过程,触发器,函数....

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4