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;