2022.1.12-1.13 Javaweb数据库(二)

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默认情况下自动提交事务。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值