查询、创建、删除
查询所有数据库
mysql
show databases;
查询当前数据库
mysql
select database();
创建一个数据库
mysql
create database test;
如果该数据库不存在就创建这个数据库
mysql
create database test if not exists test;
创建数据库并设置字符集格式
mysql
create database test1 default charset utf8mb4;
删除一个数据库
mysql
drop database[if exists]数据库名;
drop database if exists test;
使用
mysql
use 数据库名;
查询当前数据库所有表
mysql
show tables;
查询表结构
mysql
desc 表名;
data:image/s3,"s3://crabby-images/057f8/057f8ff4ecc345e5778a57b7578e136bfd26ab6a" alt=""
查询指定表的建表语句
mysql
show create table 表名;
创建表
mysql
create table 表名(
字段1 字段1类型[comment 字段1注释],
字段2 字段2类型[comment 字段2注释],
字段3 字段3类型[comment 字段3注释],
......
字段n 字段n类型[comment 字段n注释],
)[comment 表注释];
[...]为可选参数,最后一个字段后面没有逗号
data:image/s3,"s3://crabby-images/40bb3/40bb3920b4c33e5a98989b1b1fecfb93e74a4393" alt=""
mysql
create table tb_user(
id int comment'编号',
name varchar(20) comment'姓名',
age int comment'年龄',
gender varchar(1) comment'性别'
);
表的修改
添加字段
mysql
alter table 表名 add 字段名 类型(长度) [comment注释][约束];
alter table tb_user add nickname varchar(20) comment'昵称';
data:image/s3,"s3://crabby-images/54d9a/54d9a80ba2a3221d8cbdf0a629e4b0c081f47a27" alt=""
修改数据类型
mysql
alter table 表名 modify 字段名 新数据类型(长度);
修改字段名和字段类型
mysql
alter table 表名 change 旧字段名 新字段名 类型(长度) [comment 注释][约束];
alter table tb_user change nickname username varchar(30);
data:image/s3,"s3://crabby-images/b5198/b5198ae6c3fb6573ccbc314799503730add35803" alt=""
删除字段
mysql
alter table 表名 drop 字段名;
alter table tb_user drop username;
data:image/s3,"s3://crabby-images/63904/639049b170062bd8df3fbcd054a12e2a24a7800c" alt=""
修改表名
mysql
alter table 表名 rename to 新表名;
alter table tb_user rename to user;
data:image/s3,"s3://crabby-images/d5e4b/d5e4bf1a3c670dc5dd9cfaaa5e4b1bac3d0a09cf" alt=""
删除表
mysql
drop table[if exists]表名;
删除指定表,并且重新创建该表
mysql
truncate table 表名;
添加数据
mysql
insert into 表名(字段名1,字段名2,...) values(值1,值2,.。。);
给全部字段添加数据
insert into 表名 values(值1,值2,...);
批量添加数据
mysql
insert into 表名(字段名1,字段名2,...) values(值1,值2,...),values(值1,值2,...),values(值1,值2,...);
INSERT INTO USER(id,name,age,gender) VALUES(12,'张三',18,'男');
mysql
insert into 表名 values(值1,值2,...),(值1,值2,...),(值1,值2,...);
修改数据
mysql
updata 表名 set 字段名1=值1,字段名2=值2,...[where 条件];
UPDATE user set name= 'hayaizo' WHERE id =1;
删除数据
mysql
delete from 表名[where 条件]
delete from user where gender = '女';
delete语句的条件可以有,也可以没有,如果没有条件,则会删除整张表的所有数据。
delete语句不能删除某一个字段的值(可以使用update)。
查询语句
data:image/s3,"s3://crabby-images/3707e/3707ee1cdd0ec28f3e441a6a76ba9c8090151814" alt=""
data:image/s3,"s3://crabby-images/277ef/277ef4ecb995f6d0c85beafe862f8b341270c0e8" alt=""
查询多个字段
mysql
select 字段1,字段2,字段3... from 表名;
select name,workno,age from user;
mysql
select * from 表名;
select * from user;
设置别名
mysql
select 字段1 [as 别名1]... from 表名;
select workaddress as '工作地址' from user;
去除重复记录
mysql
select distinct 字段列表 from 表名;
select distinct workaddress '工作地址' from user;
条件查询
mysql
select 字段列表 from 表名 where 条件列表;
data:image/s3,"s3://crabby-images/36f29/36f29e72f76774f59e7612a77f1b28d5be118be6" alt=""
查询没有身份证号的员工信息。
mysql
select * from user where idcard is null;
查询有身份证号的员工信息
mysql
select * from user where idcard is not null;
查询年龄等于18或者20或者40的员工信息
mysql
select * from user where age in(18,20,40);
查询名字为两个字的员工
mysql
select * from user where name like '__';
查询身份证号最后一位是X的员工信息
mysql
select * from user where idcard like '%X';
聚合函数
data:image/s3,"s3://crabby-images/0a01b/0a01b06b2c83b01d46f99b8a51feac5346e64c95" alt=""
语法:
mysql
select 聚合函数(字段列表) from 表名;
统计员工数量
mysql
select count(*) from user;
select count(id) from user;
null不参与聚合计算。
统计企业员工的平均年龄
mysql
select avg(age) from user;
统计企业员工中年龄最大的员工
mysql
select max(age) from user;
统计企业员工中年龄最小的员工
mysql
select min(age) from user;
统计西安地区员工的年龄之和
mysql
select sum(age) from emp where workaddress='西安'
分组查询
mysql
select 字段列表 from 表名[where 条件] group by 分组字段名[having 分组后过滤条件];
data:image/s3,"s3://crabby-images/557eb/557eb7730a4c31be4238564784fdb7ff8366fd3f" alt=""
根据性别分组,统计男性员工和女性员工的数量。
mysql
select gender,count(*) from user group by gender;
根据性别分组,统计男性员工和女性员工的平均年龄。
mysql
select gender,avg(age) from user group by gender;
查询年龄小于45的员工,并且根据工作地址分组,获取员工数量大于等于3的工作地址。
mysql
select workaddress,count(*) as address_count from user where age<=45 group by workaddress having address_count>=3;
排序查询
mysql
select 字段列表 from 表名 order by 字段1 排序方式1,字段2 排序方式2;
data:image/s3,"s3://crabby-images/09779/09779ae480670e2ab45b1acc1acea0c19335289a" alt=""
注:如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序。
根据年龄对公司的员工进行升序排序
mysql
select * from user order by age asc;
根据年龄对公司的员工进行升序排序,年龄相同,再按照入职时间进行降序排序。
mysql
select * from user order by age asc,entrydata desc;
分页查询
data:image/s3,"s3://crabby-images/12410/12410a33ed497914c432cf634c1bf668ae511da5" alt=""
mysql
select 字段列表 from 表名 limit 起始索引,查询记录数;
data:image/s3,"s3://crabby-images/7b72a/7b72a4d274fc4801477155c5ca9171f04ab7631b" alt=""
查询第一页员工数据,每一页展示10条记录
mysql
select * from user limit 0,10;
DQL执行顺序
data:image/s3,"s3://crabby-images/8d48a/8d48afe1fdb8d047062cdd1acf738cee6eed3075" alt=""