DQL
查询基础
条件查询
注意 null值的比较不能使用= 或者!=来比较 ,应该使用is 或者 is not 来比较
通配符:
(1)_:代表单个任意字符
(2)%:代表任意个数字符
自动增长:auto_increment:当列是数字类型 并且唯一约束
create table dept(
id int primary key auto_increment ,
dep_name varchar(20),
addr varchar(20)
);
create table emp(
id int primary key auto_increment,
name varchar(20),
age int ,
dep_id int
);
alter table emp add CONSTRAINT fk_empt_dept FOREIGN key (dep_id) REFERENCES dept(id);
insert into dept(dep_name,addr) values ('研发部','广州'),('销售部','深圳');
insert into emp (name,age,dep_id)values
('张三',20,1),
('李四',20,1),
('王五',20,1),
('赵六',20,2),
('孙七',22,2),
('周八',18,2);
emp员工表为从表,dept部门表为主表。
先创建主表,再创建从表。
插入语句顺序:先加入部门数据,再加入员工数据。
数据库设计
一对多:
在多的一方建立外键,指向一的一方的主键。
多对多:
订单–商品`
实现方式:建立第三张表,中间表至少包含两个外键,分别关联两方主键。
create table tb_order(
id int primary key auto_increment,
payment double(10,2),
payment_type TINYINT,
status TINYINT
);
CREATE TABLE tb_goods(
id int primary key auto_increment,
title varchar(100),
price double(10,2)
);
-- 订单商品中间表
create table tb_order_goods(
id int primary key auto_increment,
order_id int ,
goods_id int ,
count int
);
-- 建表完后,添加外键
alter table tb_order_goods add CONSTRAINT fk_order_id FOREIGN key (order_id) references tb_order(id);
alter table tb_order_goods add CONSTRAINT fk_goods_id FOREIGN key (goods_id) REFERENCES tb_goods(id);
一对一实现方式:在任意一方加入外键,关联另一方主键,并且设置外键为唯一(UNIQUE)
数据库案例
CREATE TABLE Music (
id INT PRIMARY KEY auto_increment,
-- 编号(唯一),主键
title VARCHAR (32),
-- 专辑名
alias VARCHAR (32),
-- 专辑别名
image VARCHAR (64),
-- 封面图片
style VARCHAR (8),
-- 流派(如经典、流行、民谣、电子等)
type VARCHAR (4),
-- 类型(专辑、单曲等)
MEDIUM VARCHAR (4),
-- 介质(CD、黑胶、数字等)
publish_time date,
-- 发行时间
publisher VARCHAR (16),
-- 出版者
number TINYINT,
-- 唱片数
barcode BIGINT,
-- 条形码
summary VARCHAR (1024),
-- 简介
artist VARCHAR (16)
-- 艺术家
);
CREATE TABLE song (
id INT,
-- 编号(唯一)
NAME VARCHAR (32),
-- 歌曲名
serial_number TINYINT,
-- 歌曲序号
Music_id int
-- 添加外键Music_id , 关联Music表的id主键
);
-- 建表完成 添加歌曲外键 -->专辑
alter table song add CONSTRAINT fk_music_id FOREIGN key (Music_id) references Music(id);
CREATE TABLE User (
id INT PRIMARY KEY ,
-- 用户编号(主键)
username VARCHAR (16) UNIQUE,
-- 用户名(唯一)
image VARCHAR (64),
-- 用户头像图片地址
signature VARCHAR (64),
-- 个人签名
nickname VARCHAR (16)
-- 用户昵称
);
CREATE TABLE Review (
content VARCHAR (256),
-- 评论内容
rating TINYINT,
-- 评分
review_time datetime,
-- 评论时间
Music_id int,
-- 专辑id,关联Music表id的主键
User_id int
-- 用户id,关联User表id的主键
);
-- 建表完成 添加评论外键 -->专辑、用户
alter table Review add CONSTRAINT fk_music2_id FOREIGN key (Music_id) references Music(id);
alter table Review add CONSTRAINT fk_user_id FOREIGN key (User_id) references User(id);
-- 用户和专辑多对多
CREATE table Music_User(
id int primary KEY auto_increment,
Music_id int,
User_id int
);
ALTER table Music_User add CONSTRAINT fk_Music foreign key(Music_id) REFERENCES Music(id);
ALTER table Music_User add CONSTRAINT fk_User foreign key(User_id) REFERENCES User(id);
多表查询
连接查询避免笛卡尔积:
select * from dept,emp where emp.dep_id=dept.id;
DROP TABLE IF EXISTS emp;
DROP TABLE IF EXISTS dept;
DROP TABLE IF EXISTS job;
DROP TABLE IF EXISTS salarygrade;
-- 部门表
CREATE TABLE dept (
id INT PRIMARY KEY PRIMARY KEY, -- 部门id
dname VARCHAR(50), -- 部门名称
loc VARCHAR(50) -- 部门所在地
);
-- 职务表,职务名称,职务描述
CREATE TABLE job (
id INT PRIMARY KEY,
jname VARCHAR(20),
description VARCHAR(50)
);
-- 员工表
CREATE TABLE emp (
id INT PRIMARY KEY, -- 员工id
ename VARCHAR(50), -- 员工姓名
job_id INT, -- 职务id
mgr INT , -- 上级领导
joindate DATE, -- 入职日期
salary DECIMAL(7,2), -- 工资
bonus DECIMAL(7,2), -- 奖金
dept_id INT, -- 所在部门编号
CONSTRAINT emp_jobid_ref_job_id_fk FOREIGN KEY (job_id) REFERENCES job (id),
CONSTRAINT emp_deptid_ref_dept_id_fk FOREIGN KEY (dept_id) REFERENCES dept (id)
);
-- 工资等级表
CREATE TABLE salarygrade (
grade INT PRIMARY KEY, -- 级别
losalary INT, -- 最低工资
hisalary INT -- 最高工资
);
-- 添加4个部门
INSERT INTO dept(id,dname,loc) VALUES
(10,'教研部','北京'),
(20,'学工部','上海'),
(30,'销售部','广州'),
(40,'财务部','深圳');
-- 添加4个职务
INSERT INTO job (id, jname, description) VALUES
(1, '董事长', '管理整个公司,接单'),
(2, '经理', '管理部门员工'),
(3, '销售员', '向客人推销产品'),
(4, '文员', '使用办公软件');
-- 添加员工
INSERT INTO emp(id,ename,job_id,mgr,joindate,salary,bonus,dept_id) VALUES
(1001,'孙悟空',4,1004,'2000-12-17','8000.00',NULL,20),
(1002,'卢俊义',3,1006,'2001-02-20','16000.00','3000.00',30),
(1003,'林冲',3,1006,'2001-02-22','12500.00','5000.00',30),
(1004,'唐僧',2,1009,'2001-04-02','29750.00',NULL,20),
(1005,'李逵',4,1006,'2001-09-28','12500.00','14000.00',30),
(1006,'宋江',2,1009,'2001-05-01','28500.00',NULL,30),
(1007,'刘备',2,1009,'2001-09-01','24500.00',NULL,10),
(1008,'猪八戒',4,1004,'2007-04-19','30000.00',NULL,20),
(1009,'罗贯中',1,NULL,'2001-11-17','50000.00',NULL,10),
(1010,'吴用',3,1006,'2001-09-08','15000.00','0.00',30),
(1011,'沙僧',4,1004,'2007-05-23','11000.00',NULL,20),
(1012,'李逵',4,1006,'2001-12-03','9500.00',NULL,30),
(1013,'小白龙',4,1004,'2001-12-03','30000.00',NULL,20),
(1014,'关羽',4,1007,'2002-01-23','13000.00',NULL,10);
-- 添加5个工资等级
INSERT INTO salarygrade(grade,losalary,hisalary) VALUES
(1,7000,12000),
(2,12010,14000),
(3,14010,20000),
(4,20010,30000),
(5,30010,99990);
-- 1.查询所有员工信息。查询员工编号,员工姓名,工资,职务名称,职务描述
select emp.id ,emp.ename ,emp.salary,job.jname,job.description from emp, job where emp.job_id = job.id;
select emp.id ,emp.ename ,emp.salary,job.jname,job.description from emp inner join job on emp.job_id = job.id;
-- 2.查询员工编号,员工姓名,工资,职务名称,职务描述,部门名称,部门位置
SELECT
emp.id,
emp.ename,
emp.salary,
job.jname,
job.description,
dept.dname,
dept.loc
FROM
emp,
job,
dept
WHERE
emp.job_id = job.id
and emp.dept_id=dept.id;
-- 3.查询员工姓名,工资,工资等级
select emp.ename, emp.salary,t2.grade from emp,salarygrade t2 where emp.salary > t2.losalary and emp.salary< t2.hisalary;
-- 4.查询员工姓名,工资,职务名称,职务描述,部门名称,部门位置,工资等级
SELECT
emp.id,
emp.ename,
emp.salary,
job.jname,
job.description,
dept.dname,
dept.loc,
t2.grade
FROM
emp
inner join job on emp.job_id = job.id
inner join dept on emp.dept_id = dept.id
inner join salarygrade t2 on emp.salary between t2.losalary and t2.hisalary;
-- 5.查询出部门编号、部门名称、部门位置、部门人数
SELECT
dept.id,
dept.dname,
dept.loc,
t2.count
FROM
dept,(
SELECT
dept_id,
count(*) count
FROM
emp
GROUP BY
dept_id
) t2
WHERE
dept.id = t2.dept_id;
事务
·数据库事务是一种机制、一个操作序列,包含了一组数据库操作命令
·事务把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这一组数据库命令要么同时成功,要么同时失败。
·事务是一个不可分割的工作逻辑单元。
Mysql默认情况下自动提交事务。