1.函数
sql也是一种编程语言,它里面也有函数,分为内置得函数和自定义得函数(高级)。
内置函数:
1.聚合函数。
2.字符串函数。---操作字符串
3.时间函数--->操作得时间
4.算术函数--->数学操作。
5.其他函数
2.字符串函数。---操作字符串
常用函数:
函数 | 功能 |
---|---|
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 student;
--字符串转大小写
select name,upper(name) from student;
select name,lower(name) from student;
--去除头尾空格
select name,address,trim(address) from student;
--字符串截取
select * from student where substr(name,1,1)='张';
3.数字函数
常见函数:
函数 | 功能 |
---|---|
CEIL(x) | 向上取整 |
FLOOR(x) | 向下取整 |
MOD(x, y) | 返回x/y的模 |
abs(x) | 求某个数得绝对值 |
--数字函数
--向上取整
select ceil(1.2);
--向下取整
select floor(1.2);
--取绝对值
select abs(-5);
--取余
select mod(10,3);
--要求如果status为0变为1 为1变为0
update set status=abs(status-1);
select status if(status=1,0,1) from student;
4.时间函数
常用函数:
函数 | 功能 |
---|---|
CURDATE() | 返回当前日期 |
CURTIME() | 返回当前时间 |
NOW() | 返回当前日期和时间 |
YEAR(date) | 获取指定date的年份 |
MONTH(date) | 获取指定date的月份 |
DAY(date) | 获取指定date的日期 |
DATE_ADD(date, INTERVAL expr type) | 返回一个日期/时间值加上一个时间间隔expr后的时间值 |
DATEDIFF(date1, date2) | 返回起始时间date1和结束时间date2之间的天数 |
--时间函数 后面可以不用跟表名
--返回当前日期
select curdate();
--查询昨天入职人员
select * from tb_emp where curdate()-entrydate=1;
--返回当前时间
select curtime();
--返回日期时间
select now();
--获取指定日期年
select year('2000-1-10');
--获取2022年入职的员工
select * from tb_emp where year(entrydate)=2022;
--获取指定日期月
select month('2000-01-10');
--获取指定日期,日
select day('2000-1-10');
--返回一个日期/时间值加上一个时间间隔expr后的时间值
select date_add('2000-10-09',interval 3 year);
select date_add('2000-10-09',interval 3 month);
select date_add('2000-10-09',interval 3 day);
--返回起始时间和结束时间之间的天数
select datediff('2000-10-24','2000-10-09');
--入职30天的员工
select * from tb_emp where datediff(now(),entrydate)>30;
5.流程函数
常用函数:
函数 | 功能 |
---|---|
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
select job ,ifnull(job,'工作待定') from tb_emp;
6.约束
什么是约束? 就是在表中为某些列添加约束,使该列得值必须符合这个约束。
分类:
约束 | 描述 | 关键字 |
---|---|---|
非空约束 | 限制该字段的数据不能为null | NOT NULL |
唯一约束 | 保证该字段的所有数据都是唯一、不重复的 | UNIQUE |
主键约束 | 主键是一行数据的唯一标识,要求非空且唯一 | PRIMARY KEY |
默认约束 | 保存数据时,如果未指定该字段的值,则采用默认值 | DEFAULT |
检查约束(8.0.14版本后) | 保证字段值满足某一个条件 | CHECK |
外键约束 | 用来让两张图的数据之间建立连接,保证数据的一致性和完整性 | FOREIGN KEY |
约束是作用于表中==字段==上的,可以再==创建表==/==修改表==的时候添加约束。
create table teather(
id int primary key auto_increment, /*该列值唯一,不能为空*/
name varchar(5) unique, /*唯一约束,可以多个null*/
age int not null, /*不能为空*/
sex varchar(2) default '男' /*不写默认为男*/
);
insert into t_teacher values(null,'张三',18,'男');
insert into t_teacher values(null,'张三',19,'男');---具有唯一约束,名字不能重复,但可以有多个null
insert into t_teacher values (null,'小明',null,'男');---年龄不能为空
insert into t_teacher(id,name,age) values(null,'尔康',20);---sex有默认约束 所以在添加数据时可以不为sex设置值,则采用默认值。
6.1外键约束
--外键约束
create table s_class(
cid int primary key auto_increment,
cname varchar(11)
);
create table t_stu(
sid int primary key auto_increment,
cname varchar(11),
clsaaid int
);
--alter table 从表名 add constraint 约束名随便起 foreign key 外键列名 references 主表(主键)
--add contraint 约束得名称 foregin key 外键得列名 REFERENCES 主表名(主键)
alter table t_stu add constraint wj_stu_class foreign key (clsaaid)references s_class(cid);
insert into s_class values(null,'QY145'),(null,'QY151');
insert into t_stu values(null,'李文',2);
insert into t_stu values(null,'史蒂夫',3);--因为classid=3这个值在我们得班级表中不存在所以不能添加