MySQL数据库(四)函数与约束

1.函数

sql也是一种编程语言,它里面也有函数,分为内置得函数和自定义得函数(高级)。
内置函数:

  1. 聚合函数。
  2. 字符串函数。---操作字符串
  3. 时间函数--->操作得时间
  4. 算术函数--->数学操作。
  5. .其他函数

1.1.字符串函数

常用函数:

函数功能
CONCAT(s1, s2, ..., sn)字符串拼接,将s1, s2, ..., sn拼接成一个字符串
LOWER(str)将字符串全部转为小写
UPPER(str)将字符串全部转为大写
LPAD(str, n, pad)左填充,用字符串pad对str的左边进行填充,达到n个字符串长度
RPAD(str, n, pad)右填充,用字符串pad对str的右边进行填充,达到n个字符串长度
TRIM(str)去掉字符串头部和尾部的空格
SUBSTRING(str, start, len)返回从字符串str从start位置起的len个长度的字符串
-- 字符串拼接函数
select concat('姓名:',name,' 年龄:',age) from tb_emp;
-- 字符串转换为大写和小写
select t_name,upper(t_name),t_address,lower(t_address) from t_student;
-- 去除前后空格
select t_id,trim(t_id) from t_student;
-- 找到姓张的学生 字符串截取
select * from t_student where substr(t_name,1,1)='张';

1.2.数字函数

常见函数:

函数功能
CEIL(x)向上取整
FLOOR(x)向下取整
MOD(x, y)返回x/y的模
abs(x)求某个数得绝对值
-- 向上取整 向下取整 返回x/y的模  绝对值
select ceil(5.1),floor(5.9),abs(-5.9) from t_student;
-- 要求如果status为0变为1 为1变为0  update
update aaa set status=abs(status-1);

1.3.时间函数

常用函数:

函数功能
CURDATE()返回当前日期
CURTIME()返回当前时间
NOW()返回当前日期和时间
YEAR(date)获取指定date的年份
MONTH(date)获取指定date的月份
DAY(date)获取指定date的日期
DATE_ADD(date, INTERVAL expr type)返回一个日期/时间值加上一个时间间隔expr后的时间值
DATEDIFF(date1, date2)返回起始时间date1和结束时间date2之间的天数
-- CURDATE()返回当前日期  后面可以不用跟表名
select curdate();
-- 使用where
select * from tb_emp where curdate()-entrydate=30;
-- CURTIME()返回当前时间
select curtime();
-- NOW()返回当前日期和时间
select now();
-- YEAR(date)获取指定date的年份
select year('2343-12-23');
-- DATE_ADD(date, INTERVAL expr  type)返回一个日期/时间值加上一个时间间隔expr后的时间值
select date_add('2000-03-18',interval 15 year);
-- DATEDIFF(date1, date2)返回起始时间date1和结束时间date2之间的天数
select datediff('2080-09-12',curdate());
-- 入职7000天的员工.
select * from tb_emp where datediff(curdate(),entrydate)>7000;

1.4.流程函数

常用函数:

函数功能
IF(value, t, f)如果value为true,则返回t,否则返回f
IFNULL(value1, value2)如果value1不为空,返回value1,否则返回value2
CASE WHEN [ val1 ] THEN [ res1 ] ... ELSE [ default ] END如果val1为true,返回res1,... 否则返回default默认值
CASE [ expr ] WHEN [ val1 ] THEN [ res1 ] ... ELSE [ default ] END如果expr的值等于val1,返回res1,... 否则返回default默认值
-- 如果年龄>30中年  否则青年
select age,if(age>30,'中年','年轻人') from tb_emp;
-- ifnull 如果为null,则
select job,ifnull(job,'开除') from tb_emp;

2.约束

什么是约束? 就是在表中为某些列添加约束,使该列得值必须符合这个约束。

分类:

约束描述关键字
非空约束限制该字段的数据不能为nullNOT NULL
唯一约束保证该字段的所有数据都是唯一、不重复的UNIQUE
主键约束主键是一行数据的唯一标识,要求非空且唯一PRIMARY KEY
默认约束保存数据时,如果未指定该字段的值,则采用默认值DEFAULT
检查约束(8.0.14版本后)保证字段值满足某一个条件CHECK
外键约束用来让两张图的数据之间建立连接,保证数据的一致性和完整性FOREIGN KEY

约束是作用于表中字段上的,可以再创建表/修改表的时候添加约束。

-- 约束
use demo1;

create table t_stu1(
	     id int primary key auto_increment,-- 主键约束,该列的值必须唯一且非空
			 tname varchar(20) unique, -- unique 唯一约束,该列的值唯一,可位null
			 age int not null,  -- not null 非空约束,该列的值不能为空
			 sex char(2) default '男' -- default 默认约束,该列若不设值,则为默认值
);

2.1.外键约束

        一个表的外键关联到主表的主键约束或者unique(唯一)约束都可以,不一定非要主键约束,但必须是唯一性索引。
外键约束用来让两张图的数据之间建立连接,保证数据的一致性和完整性。 
-- 外键
create table t_class(
    cid int primary key auto_increment,
		cname varchar(20)
);
create table t_stu(
     sid int primary key auto_increment,
		 sname varchar(20),
		 classid int -- 表示外键列。
);
-- add contraint 约束名称  foregin key 外键列名 REFERENCES 主表名(主键)  

-- alter table 从表名 add contraint 约束名自定义 foreign key 外键列名 references  主表(主键)
alter table t_stu add CONSTRAINT fk_stu_class FOREIGN key (classid) REFERENCES t_class(cid);

insert into t_class values(null,'QY145'),(null,'QY151');

insert into t_stu values(null,'李二',2);
-- 因为classid=3 这个值 在班级表中不存在。所以不能添加
insert into t_stu values(null,'张三',1);

注意: 外键列得数据类型 必须和主表中主键得数据类型一致。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Naaaaa.a

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值