MySQL常用函数聚合函数

  • count:计数。count(*)≈count(1)>count(主键)
    • count(*):MySQL对count(*)底层优化,count(0)。
    • count(1)
    • count(主键)
    • count(字段)
  • min:最小值
  • max:最大值
  • sum:求和
  • avg:平均值

数值型函数

主要是对数值型进行处理。

  • ceiling(x):向上取整
  • floor(x):向下取整
  • round(x):四舍五入
  • truncate(x,y):返回数字x截断为y位小数的结果
  • PI:圆周率,π
  • rand:返回0到1的随机数
  • abs:绝对值
-- 绝对值select ABS(-4) 4的绝对值,ABS(-1.1);-- 向下取整,向上取整,四舍五入select CEILING(4.1),FLOOR(1.1),ROUND(-4.4)-- 取余select MOD(60,11);-- 随机数select RAND(),RAND(),RAND()-- 截断select TRUNCATE(2.33999999,2);

字符串型函数

对字符串进行处理。

  • length(s):字符串的长度
  • concat(s1,s2,…..sn):合并字符串
  • lower(str):将字母转成小写
  • upper(str):将字母转成大写
  • left(str,x):返回字符串str的左边的x个字符
  • right(str,x):返回字符串str右边的x个字符
  • trim:去掉左右两边的空格
  • replace:替换
  • substring:截取
  • reverse:反转
select LEFT('abcdefg',2);select RIGHT('abcdefg',2);select REVERSE('hijklmn');select REPLACE('abcdefg','abc','x');

日期和时间函数

date,time,datetime,timestamp,year。

获取时间和日期

  • 【curdate】和【current_date】,返回当前的系统日期。
  • 【curtime】和【current_time】,返回当前的系统时间。
  • 【now】和【sysdate】,返回当前的系统时间和日期。
select CURRENT_DATE();select CURTIME();select now();

时间戳和日期转换函数

  • 【UNIX_TIMESTAMP】获取unix时间戳函数
  • 【FROM_UNIXTIME】将时间戳转换为时间格式
select UNIX_TIMESTAMP();select FROM_UNIXTIME(1660785720);

根据日期获取年月日的数值

select MONTH(SYSDATE());select MONTHNAME(SYSDATE());select DAYNAME(SYSDATE());select DAYOFWEEK(SYSDATE());select WEEK(SYSDATE());select DAYOFMONTH(SYSDATE());select YEAR(SYSDATE());

时间日期的计算

-- 日期加法select DATE_ADD(SYSDATE(),INTERVAL 70 DAY);-- 日期减法select DATE_SUB(SYSDATE(),INTERVAL 10 DAY);-- 时间间隔select DATEDIFF('2023-01-01',SYSDATE());-- 日期格式化select DATE_FORMAT(SYSDATE(),'%W %M %D %Y');

加密函数

-- 把传入的参数的字符串按照md5算法进行加密,得到一个32位的16进制的字符串select MD5('123456');

md5算法是不可逆的。

流程控制函数

可以进行条件判断,用来实现SQL语句的逻辑。

  • if(test,t,f):如果test是真,则返回t,否则返回f
  • ifnull(arg1,arg2):如果arg1不是空,返回arg1,否则返回arg2
  • nullif(arg1,arg2):如果arg1=arg2返回null,否则返回arg1
select IF(2 > 1,'a','b');select IFNULL(sal,0);select NULLIF(age,0);

对一系列的值进行判断:

-- 输出学生的各科的成绩,以及评级,60以下D,60-70是C,71-80是B,80以上是ASELECT*,CASEWHEN score = 60 AND score = 70 AND score = 80 THEN'A' END AS '评级' FROMmystudent;
-- 行转列SELECTuser_name,max( CASE course WHEN '数学' THEN score ELSE 0 END ) '数学',max( CASE course WHEN '语文' THEN score ELSE 0 END ) '语文',max( CASE course WHEN '英语' THEN score ELSE 0 END ) '英语' FROMmystudent GROUP BYuser_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.com12321321321
1002bbbbbb@163.com32132654654
1003cccccc@163.com45654654654

必须有主键,这是数据库设计的基本要求,一般情况下我们采用数值型或定长字符串,列不能再分,比如:联系方式。

关于第一范式,保证每一行的数据是唯一,每个表必须有主键。

第二范式

建立在第一范式的基础上,要求所有非主键字段完全依赖于主键,不能产生部分依赖。

学号性别姓名课程编号课程名称教室成绩
1001a2001java30189
1002b2002mysql30290
1003c2003html30391
1004d2004python30452
1005e2005c++30567
1006f2006c#30684

解决方案:

学生表:学号是主键

学号性别姓名
1001a
1002b
1003c
1004d
1005e
1006f

课程表:课程编号是主键

课程编号课程名称教室
2001java301
2002mysql302
2003html303
2004python304
2005c++305
2006c#306

成绩表:学号和课程编号为联合主键

学号课程编号成绩
1001200189
1002200290
1003200391
1004200452
1005200567
1006200684

第三范式

建立在第二范式基础上,非主键字段不能传递依赖于主键字段。

不满足第三范式:

学号姓名课程编号课程名称
1001a2001java
1002b2002mysql
1003c2003html
1004d2004python
1005e2005c++
1006f2006c#

解决方案:

学生表:学号是主键

学号姓名课程编号
1001a2001
1002b2002
1003c2003
1004d2004
1005e2005
1006f2006

课程表:课程编号是主键

课程编号课程名称
2001java
2002mysql
2003html
2004python
2005c++
2006c#

常见的表关系一对一

学生信息表分为基本信息表和信息信息表。

  • 分为两张表,共享主键。
  • 分两张表,用外键连接。

一对多

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

  • 分两张表存储,在多的一方加外键
  • 这个外键字段引用是一的一方的主键

多对多

  • 分三张表存储,在学生表存储学生信息,在课程表存储课程信息。
  • 在成绩表中存储学生和课程的对应关系。

mysql未完待续….

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