date : 日期值。只包含年月日 eg :birthday date :
datetime : 混合日期和时间值。包含年月日时分秒
字符串
char : 定长字符串。 优点:存储性能高 缺点:浪费空间 eg : name char(10) 如果存储的数据字符个数不足10个,也会占10个的空间
varchar : 变长字符串。 优点:节约空间 缺点:存储性能底 eg : name varchar(10) 如果存储的数据字符个数不足10个,那就数据字符个数是几就占几个的空间
5.4案例设计
需求:设计一张学生表,请注重数据类型、长度的合理性
1. 编号
2. 姓名,姓名最长不超过 10
个汉字
3. 性别,因为取值只有两种可能,因此最多一个汉字
4. 生日,取值为年月日
5. 入学成绩,小数点后保留两位
6. 邮件地址,最大长度不超过 64
7. 家庭联系电话,不一定是手机号码,可能会出现 -
等字符
8. 学生状态(用数字表示,正常、休学、毕业 ...
)
create table student(
id int,
name varchar(10),
sex char(1),
birthday date,
score double(5,2), #double(总长度,保留位数)
email varchar(64),
tel varchar(20),
status tinyint #只占用一个字节
);
5.5修改表
修改表名
alter table student rename to st;
添加一列
alter table st add no int;
修改数据类型
alter table st modify no varchar(20);
修改列名和数据类型
alter table st change no No int;
删除列
alter table st drop No;
6、DML
操作表也就是对表进行增(Create)删(Retrieve)改(Update)查(Delete)
6.1添加数据
给指定列添加数据
给指定列添加数据 insert into 表名(列名1,列名2) values(值1,值2);
insert into st(编号,姓名) values(1,"张三");
给全部列添加数据
给所有列添加数据 (可以省略列名)
insert into st values(2,'李四','男
','2001-10-23',88.88,'[email protected]','17779343025',1);
批量添加数据
批量添加
insert into st values(3,'李四','男','2001-10-23',88.88,'[email protected]','17779343025',1),(2,'王五','男','2001-10-23',88.88,'[email protected]','17779343025',1),(2,'杨六','男','2001-10-23',88.88,'[email protected]','17779343025',1);
6.2修改数据
修改表数据
-- 如果update没有加where ,则会把表中所有数据全部都给修改了
update st set 性别='女' where 姓名 ='张三';
6.3删除数据
删除表数据
-- 如果delete没有加where ,则会把表中所有数据全部都给删除了
delete from st where 姓名 ='李四';
7、DQL 查询
SELECT字段列表
FROM表名列表
WHERE条件列表
GROUP BY 分组字段
HAVING分组后条件
ORDER BY 排序字段
LIMIT分页限定
7.1 数据准备
-- 创建stu表
CREATE TABLE stu (
id int, -- 编号
name varchar(20), -- 姓名
age int, -- 年龄
sex varchar(5), -- 性别
address varchar(100), -- 地址
math double(5,2), -- 数学成绩
english double(5,2), -- 英语成绩
hire_date date -- 入学时间
);
-- 添加数据
INSERT INTO stu(id,NAME,age,sex,address,math,english,hire_date) VALUES (1,'马运',55,'男','杭州',66,78,'1995-09-01'), (2,'马花疼',45,'女','深圳',98,87,'1998-09-01'), (3,'马斯克',55,'男','香港',56,77,'1999-09-02'), (4,'柳白',20,'女','湖南',76,65,'1997-09-05'), (5,'柳青',20,'男','湖南',86,NULL,'1998-09-01'), (6,'刘德花',57,'男','香港',99,99,'1998-09-01'), (7,'张学右',22,'女','香港',99,99,'1998-09-01'), (8,'德玛西亚',18,'男','南京',56,65,'1994-09-02');
7.2 基础查询
-- 查询地址类型
# distinct去除重复数据
select address from stu; # (会出现重复数据)
select distinct address from stu;
# 查询姓名,数学,英语成绩
select name,math,english from stu;
#起别名
select name as 名字,math as 数学,english as 英语 from stu; #(也可以不加as,但是别名要和字段名空格一下)
7.3 条件查询
-- 1. 查询年龄大于20岁的学员信息
select * from stu where age>20;
-- 2.查询年龄大于20并且小于30的学员信息
select * from stu where age>20 and age<30;
-- 3.查询入学日期在'1998-09-01'到'1999-09-01'之间的学员信息
select * from stu where hire_date between '1998-09-01' and '1999-09-01';
-- 4.查询年龄等于18岁的信息
select * from stu where age=18;#这个地方不用==
-- 5.查询年龄不等于18岁的信息
select * from stu where age!=18;
-- 6.查询年龄等于18岁或者年龄等于20岁或者年龄等于22岁的学员的信息
select * from stu where age=18 or age=20;
select * from stu where age in(18,20);
-- 7.查询英语成绩为null的学员信息
-- 注意:null的值的比较不能用“=” or “!=” 需要用"is" "is not"
select * from stu where english is null;
7.4 模糊查询
模糊查询 LIKE
-- 1.查询姓'马'的学员信息
select * from stu where name like '马%';
-- 2.查询第二个字是'花'的学员的信息
select * from stu where name like '_花%';
-- 3.查询名字中包含'德'的学员信息(最为常用)
select * from stu where name like '%德%';
7.5 排序查询
排序查询 ORDER BY
-- 排序方式:
-- ASC:升序排列(默认值)
-- DESC:降序排序
-- select 字段列表 from 表名 order by 排序字段名1[排序方式1],排序字段名2[排序方式2]......
-- 1.查询学生的信息,按照年龄升序排列
select * from stu order by age ASC;
-- 2.查询学生信息,按照数学成绩降序排序
select * from stu order by math DESC;
-- 3.查询学生成绩,按照数学成绩降序排序,如果数学成绩一样,按照英语成绩升序排列
select * from stu order by math DESC,english ASC;
7.6 分组查询
分组查询 GROUP BY
-- 聚合函数
-- 1.统计班级一共有多少学生
select count(*) from stu; # count(主键)
-- 2.查询数学成绩的最高分
select max(math) from stu;
-- 3.查询数学成绩的最低分
select min(math) from stu;
-- 4.查询数学成绩的总分
select sum(math) from stu;
-- 5.查询数学成绩的平均分
select avg(math) from stu;
-- 6.查询英语成绩的最低分
select min(english) from stu; #这个地方不查询null
-- 分组查询
-- 1.查询男同学和女同学各自的数学平均分
#分组之后,查询的字段只能是聚合函数,查询其它字段无任何意义
select sex,avg(math) from stu group by sex;
-- 2.查询男同学和女同学各自的数学平均分以及各自的人数
select sex,count(*),avg(math) from stu group by sex;
-- 3.查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组
select sex,avg(math),count(*) from stu where math>70 group by sex;
-- 4.查询男同学和女同学各自的数学平均分,以及各自人数,要求:分数低于70分的不参与分组,分组之后人数大于2个的
select sex,avg(math),count(*) from stu where math>70 group by sex having count(*)>2;
7.7 分页查询
-- 分页查询 LIMIT
-- 语法:select 字段列表 from 表名 limit 起始索引,查询条目数量;
-- 1.从0开始查询,查询三条数据
select * from stu limit 0,3; #原始下标从0开始
-- 2.每页显示三条数据,查询第1页数据
select * from stu limit 0,3;
-- 3.每页显示3条数据,查询第2页数据
select * from stu limit 3,3;
-- 4.每页显示3条数据,查询第3页数据
select * from stu limit 6,3;