MySQL常用函数

目录

聚合函数 

数值型函数

字符串型函数

日期和时间函数

时间戳和日期转换函数

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

时间日期的计算

加密函数

 流程控制函数

数据库设计

三范式

第一范式

 第二范式

 第三范式

 常见的表关系

一对一

一对多

多对多


聚合函数 

count:计数。count(*)≈count(1)>count(主键)

count(*):MySQL对count(*)底层优化,count(0)

        count(1)

        count(主键)

        count(字段)

min:最小值

max:最大值

sum:求和

avg:平均值

数值型函数

主要是对数值型进行处理

ceiling(x):向上取整

floor(x):向下取整

round:四舍五入

ttuncate(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(x):字符串大的长度

concat(s1,s2,s3......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');

日期和时间函数

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

 流程控制函数

可以进行条件判断,用来实现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);

数据库设计

三范式

第一范式:要求有主键,并且要求每一个字段的原子性不能再分。

第二范式:要求所有的非主键字段完全依赖主键,不能产生部分依赖

第三范式:所有非主键字段和主键字段之间不能产生传递依赖。

第一范式

必须有主键,这是数据库设计的基本要求,一般情况下采用数值或定长字符串,列不能再分

关于第一范式,列不能再分,比如:联系方式

 第二范式

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

 解决方案

学生表:学号是主键

 课程表:课程编号是主键

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

 第三范式

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

不满足第三范式:

解决方案:

学生表:学号是主键

​​​​​​​

 课程表:课程编号是主键

 常见的表关系

一对一

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

分为两张表,共享主键

分为两张表,用外键连接

一对多

两张表,外键在多的一方

分为两张表存储,在多的一方加外键

这个外键字段引用的是一方的主键

多对多

分为三张表存储,在学生表存储学生信息,在课程表存储课程信息

在成绩表中存储学生和课程的对应关系

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值