目录
[增insert 删delete 改update 查select](#增insert 删delete 改update 查select)
[order by](#order by)
[min sum avg](#min sum avg)
[group by](#group by)
登录
mysql -u root -p
data:image/s3,"s3://crabby-images/7ba81/7ba81ff25f5dc92d60ef8929843cad401e068163" alt=""
显示数据库
show databases;
data:image/s3,"s3://crabby-images/a3660/a3660228b773ea7ad38892ffbac673d7ba0fb833" alt=""
创建数据库
craate database <数据库名> ;
data:image/s3,"s3://crabby-images/2104a/2104a34dc3e5c987ccba0f3d3b9a9f5b42799865" alt=""
删除数据库
drop database <数据库名> ;
data:image/s3,"s3://crabby-images/b42be/b42bef9d6b3b546b02d243e3b1fbe828e29f4ffb" alt=""
使用数据库
use <数据库名>
data:image/s3,"s3://crabby-images/dcf4c/dcf4ca16b79eca9431412788782749277b7c0588" alt=""
创建表
primary key 主键
not null 非空
unique 惟一
default 默认值
auto_increment 自增长
int unsigned 无符号整数
sql
DROP TABLE IF EXISTS staffer;
CREATE TABLE staffer (
id int NOT NULL AUTO_INCREMENT COMMENT '员工编号',
dept_id int NOT NULL COMMENT '部门编号',
staff_name varchar(10) NOT NULL COMMENT '员工名字',
sex enum('F','M') DEFAULT 'F' COMMENT '性别',
birthday date COMMENT '生日',
phone char(11) COMMENT '电话',
salary decimal(11,2) UNSIGNED DEFAULT 1.00 COMMENT '工资',
staff_memo varchar(100) COMMENT '备注',
PRIMARY KEY (id),
FOREIGN KEY (dept_id) REFERENCES department (id),
CHECK ((salary > 0) and (salary < 100000))
) AUTO_INCREMENT=10512;
sql
DROP TABLE IF EXISTS item ;
CREATE TABLE item(
item_id int AUTO_INCREMENT,
order_id int,
goods_id int,
quantity int,
total_price decimal(11, 2),
PRIMARY KEY ( item_id ),
FOREIGN KEY ( goods_id ) REFERENCES goods ( goods_id ),
FOREIGN KEY ( order_id ) REFERENCES orders ( order_id )
);
添加数据表数据
sql
INSERT INTO staffer VALUES (10501, 1, '燕南飞', 'M', '1995-09-18', '13011231890', '5000.10', '职员');
INSERT INTO staffer VALUES (10502, 2, '陈一南', 'M', '1990-09-12', '13011233333', '6000.10', '职员');
INSERT INTO staffer VALUES (10503, 4, '李思思', 'F', '1979-11-01', null, '9900.00', '总经理');
INSERT INTO staffer VALUES (10504, 1, '张燕红', 'F', '1985-06-01', '13566567456', '8000.00', '部门经理');
INSERT INTO staffer VALUES (10505, 3, '南海峰', 'M', '1986-04-01', null, '7000.00', '职员');
INSERT INTO staffer VALUES (10506, 3, '张红燕', 'F', '1982-09-21', '13823671111', '9000.00', '部门经理');
INSERT INTO staffer VALUES (10507, 2, '王南峰', 'M', '1986-04-01', '13668992222', '7000.00', '职员');
INSERT INTO staffer VALUES (10508, 5, '刘燕玲', 'F', '1981-07-01', '13823679988', '6000.00', '职员');
INSERT INTO staffer VALUES (10509, 5, '李玉燕', 'F', '1984-02-08', '13823677889', '9000.00', '部门经理');
INSERT INTO staffer VALUES (10510, 4, '王树思', 'M', '1996-04-01', '13668998888', '7000.00', '职员');
INSERT INTO staffer VALUES (10511, 1, '思灵玉', 'F', '1992-03-01', '13823679999', '6000.00', '职员');
sql
INSERT INTO item VALUES (1, 1, 1, 20, NULL);
INSERT INTO item VALUES (2, 1, 2, 2, NULL);
INSERT INTO item VALUES (3, 1, 3, 3, NULL);
INSERT INTO item VALUES (4, 2, 1, 7, NULL);
INSERT INTO item VALUES (5, 2, 2, 5, NULL);
INSERT INTO item VALUES (6, 2, 3, 6, NULL);
INSERT INTO item VALUES (7, 3, 1, 10, NULL);
INSERT INTO item VALUES (8, 3, 4, 10, NULL);
INSERT INTO item VALUES (9, 4, 1, 6, NULL);
INSERT INTO item VALUES (10, 4, 2, 3, NULL);
SET FOREIGN_KEY_CHECKS = 1;
查询表
sql
select * from staffer;
添加数据表多条数据
一次性在department表中添加2条记录,分别为:(部门名称:市场部;电话:020-87993093)、
(部门名称:宣传部;电话:020-87993065)
sql
select * from department;
insert into department (dept_name,dept_phone) values ('市场部','020-87993093'),('宣传部','020-87993065');
select * from department;
查询表中某数据
在goods表中查询各商品的3件费用
-- 3件费用是商品单价*3的价格,可使用表达式计算
data:image/s3,"s3://crabby-images/d7696/d76967fc796b874fdf17f44ea2ac259416e9861b" alt=""
sql
select goods_name,unit_price,unit_price*3 as '3件费用' from goods_;
查询goods_表第一行开始的2条记录
sql
select * from goods_ limit 1,2;
查询staffer表中姓张的员工,并显示其staff_id,staff_name,deptartment_id,sex
sql
select staff_id,staff_name,deptartment_id,sex from staffer where staff_name like '张%';
item 表,按商品和供应商分组,查询各商品的各供应商提供的销售数量和总数量
-- 分析:当汇总有2个以上字段是需要用with rollup 子句才能达到按从左到右分类的目的
sql
select * from item;
select goods_id,order_id,sum(quantity) from item group by goods_id,order_id with rollup;
增insert 删delete 改update 查select
data:image/s3,"s3://crabby-images/c27b9/c27b9926004d7a0977f2bdcc229990d06786faba" alt=""
data:image/s3,"s3://crabby-images/8b64c/8b64c178de9e1fcc1825ca41f54c9a416a0e9b87" alt=""
data:image/s3,"s3://crabby-images/0d3c7/0d3c7e4c3fd4aae3be8a9bc31aaca880da148bca" alt=""
data:image/s3,"s3://crabby-images/b332d/b332d426e5c58f5b6ebea248d22796da3564dc4a" alt=""
data:image/s3,"s3://crabby-images/54f98/54f98a0f4abbc6b2b574bed283c32e4df8fd31c2" alt=""
data:image/s3,"s3://crabby-images/d799e/d799ebf1fde571e44906cdb44a20fa2cbd14f744" alt=""
data:image/s3,"s3://crabby-images/762fe/762fe1ddb3ecab1d09530d8488634cf05454d879" alt=""
data:image/s3,"s3://crabby-images/359cf/359cfd41bebf18eeac661382a804776a59e11c5c" alt=""
where
select 后面的"或者字段名,决定了返回什么样的字段(列):
select 中 where 子句,决定了返回什么样的记录(行);
data:image/s3,"s3://crabby-images/28b75/28b75fa3f34ee3df198f21f057381373f1001a5c" alt=""
data:image/s3,"s3://crabby-images/6f31b/6f31b14c8c47368618ee1495f87b589e5806bef3" alt=""
like
data:image/s3,"s3://crabby-images/c0ac9/c0ac95876da2624e275486eda241ed9cb23e7c0a" alt=""
范围查找
data:image/s3,"s3://crabby-images/3a611/3a611a5e7090ad9c7926902c405647f5e77dc987" alt=""
data:image/s3,"s3://crabby-images/cc1fc/cc1fceed1fb8345ae1f91ff617d0cb65ad6bb1eb" alt=""
order by
当一条select语句出现了where和order by
select * from 表名 where 条件 order by 字段1,字段2;
一定要把where写在order by前面
asc 从小到大 可以省略desc 从大到小
默认从小到大 (asc)
data:image/s3,"s3://crabby-images/e457c/e457cfb6f7c3359e5fe29930de6d9cfdf0227ca3" alt=""
聚合函数
count
data:image/s3,"s3://crabby-images/4db8d/4db8d6faeff3c0376fba252dedbdecb4dc523c87" alt=""
max
data:image/s3,"s3://crabby-images/49c0c/49c0cfdb6e2079b0b7f404250d8fd6dba8994df9" alt=""
min sum avg
data:image/s3,"s3://crabby-images/16523/165232123eefa03bce85deb5fb3b0bb440b5b662" alt=""
data:image/s3,"s3://crabby-images/0dbfd/0dbfd8af00de2983bcc6e8e0d9d6908389138998" alt=""
data:image/s3,"s3://crabby-images/caf06/caf06757ecfee789c02685799eaf0cf3d6f2f3a7" alt=""
group by
select 聚合函数 from 表名 where 条件 group by 字段
select 聚合函数 from 表名 group by 字段
group by就是配合聚合函数使用的
where和group by 和order by的顺序:
select * from 表名 where 条件 group by 字段 order by 字段
data:image/s3,"s3://crabby-images/339d0/339d026932ca9d4c09c56613929ac1fbcd4953ce" alt=""
data:image/s3,"s3://crabby-images/119c9/119c9916fac8e7f10757b269a2726610e721fff2" alt=""
having
having子句
总是出现在group by之后
select * from 表名 group by 字段 having 条件
对比 where 与 having:
where 是对 from 后面指定的表进行数据筛选属于对原始数据的筛选having 是对 group by 的结果进行筛选;
having 后面的条件中可以用聚合函数,where 后面的条件不可以使用聚合函数。
having语法:
select 字段1,字段2,聚合...from 表名group by 字段1,字段2,字段3...
having 字段1,...聚合...
data:image/s3,"s3://crabby-images/7bfdf/7bfdf497e63d36108e14cf3f262000f407e39186" alt=""
data:image/s3,"s3://crabby-images/41bd2/41bd2fbbf6bbb3fcf203c45f03c0574eecea0642" alt=""
limit
data:image/s3,"s3://crabby-images/e7341/e7341ada2c3c4069725e9118f6870a3e281dc4cc" alt=""
空判断
null不是0,也不是",null在SQL里面代表空,什么也没有
null不能用比较运算符的判断
is null ---是否为null
is not null ---是否不为null
(不能用字段名 = null 字段名 != null这些都是错误的)
data:image/s3,"s3://crabby-images/c6a22/c6a22ec76fff5a883c306a8264c4934fbffddc89" alt=""
视图
建立部门员工视图,显示部门名称和员工对外查阅资料 | staffer 表和 department 表
sql
select * from staffer;
select * from department;
drop view if exists v_staffer;
create view v_staffer
as select dept_name,staff_name,sex,phone from staffer
inner join department on staffer.deptartment_id=department.dept_id;
select * from v_staffer;
存储
创建带入in 参数和输出 out 参数的存储过程
-若需要从存储过程中返回一个或多个检索或统计的值,则可以使用代out关键字定义的输出参数,将返回值传回调用环境
在数据库db_shop中建立一个存储过程,能够通过部门编号统计该部门员工的人数,返回统计值,并调佣该存储过程
-- 分析:部门编号是输入参数,统计的员工人数是输出参数
sql
drop procedure if exists p_count;
delimiter //
create procedure p_count(in id int,out n int)
BEGIN
select count(*) into n from staffer where deptartment_id=id;
end //
delimiter ;
call p_count(1,@a);
select @a as '1号部门员工数';
data:image/s3,"s3://crabby-images/fbda3/fbda3f488857c35e3937d58756029cd26e332efa" alt=""
编写一个函数,可按职员编号查询员工姓名。
sql
use db_shop;
-- 创建函数时,mysql 默认开启了bin-log,因含有sql语句会出错,则需参加
drop function if exists staffer_search;
set global log_bin_trust_function_creators = 1;
delimiter //
create FUNCTION staffer_search(sid int)
returns varchar(10)
begin
declare sname varchar (10);
select staff_name into sname from staffer where deptartment_id=sid;
if isnull(sname) then
return '无人';
else
return sname;
end if;
END //
delimiter ;
set @sname = staffer_search(6);
select @sname,staffer_search(7);
data:image/s3,"s3://crabby-images/d1b88/d1b8899fa695878b942e21d4b84153a039b6ff88" alt=""