在学习MySQL数据库之前我们要知道MySQL数据库的操作语言的分类;
一种是在建库语句上带上字符编码
另一种是在启动服务时添加配置文件
我们知道utf-8是我们平时表示汉字的常用字符编码,所以我么在创建数据库时就必须先设置它能识别和存储的字符编码;
建库SQL语句(在mysql提示符下运行)
create database 数据库名 character set utf8mb4;
mysql中的utf8字符不够完整,utf8mb4是完整版本的
删除数据库
drop database 数据库名;
查看建库信息
show create database 数据库名;
要修改全局的设置,在mysql解压目录添加 my.ini 配置文件,在其中输入(推荐)
[mysqld]
character-set-server=utf8mb4
这里注意我们在安装目录下写入了配置文件后,如果想要它生效,就必须删除我们之前安装的MySQL服务,然后重新安装服务器端mysqld,这样配置文件才能生效;
停止旧服务,删除旧服务,安装新服务,启动新服务
net stop mysql
sc delete mysql
mysqld install
net start mysql
建表(table)
一个库中有多张表,每张表里有多条数据
表分成行(row 横向)与列(column 纵向)
学号 姓名 性别
1 张三 男
2 李四 女
…
create table 表名(
列1名 类型,
列2名 类型,
...
);
create table student(
id int,
name varchar(10),
sex char(1)
);
建表所需数据类型介绍:
整数类型: tinyint(1个字节), smallint(2个字节), int(4个字节), bigint(8个字节)
无符号数字 tinyint unsigned (0~255)
浮点类型: float, double
定点小数: decimal(总位数, 小数位数)
decimal(10, 2) 小数部分两位,整数部分最大8位
字符类型
char(长度) char(10) 表示最多存10个字符, 定长,效率高
varchar(长度) varchar(10) 表示最多存储10个字符,变长
“abc” "abc " 存储时,长度不足,用空格补齐
“abc” “abc” 存储时,根据实际长度存储,可以节省空间
日期类型
datetime
timestamp
insert into 表名(列1, 列2, ... 列n) values (值1, 值2, ... 值n);
注意:值个数要与列个数一致
insert into student(id,name,sex) values(1, '张三', '男');
select 列1, 列2, ... from 表名;
select id, name, sex from student;
show databases;
show tables;
create table 表名(
列1名 类型 primary key,
列2名 类型,
...
);
删表语法:drop table 表名;
create table student(
id int primary key,
name varchar(10),
sex char(1)
);
insert into student(id,name,sex) values(null, ‘李四’, ‘男’);
自增列,用来解决主键冲突问题
在主键列后加入:auto_increment
1 2 3 4 …
因为id列由数据库维护,所以有了自增列后就不需要给id列赋值了
create table student(
id int primary key auto_increment,
name varchar(10),
sex char(1)
);
修改表语法:
alter table 表 ... (添加列, 修改列, 删除列, 重命名列8.0才有)
一次插入多条记录(mysql独有)
insert into student(name,sex) values(‘李四’, ‘男’),(‘王五’, ‘男’),(‘赵柳’, ‘男’);
查询所有列
select * from student;
mysql会把*翻译成:id,name,sex
删除记录(只删除数据,不删表)
delete from 表 where 条件;
drop table 表;
只删除id=6的记录
delete from student where id=6;
alter table stduent add age tinyint unsigned;
alter table student modify name varchar(20);
删除列
语法:alter table 表名 drop 列名;
重命名列
语法:alter table 表名 rename column 旧列名 to 新列名;
语法1:
insert into 表名(列...) values(值...); 插入一行
语法2:
insert into 表名(列...) values(值...), (值...), (值...), (值...); 插入多行
create table student2(
id int primary key,
name varchar(20),
sex char(1)
);
语法3:从表1查询,把查询结果插入表2
insert into 表2 select * from 表1;
如果两张表结构不一样,可以在select后加具体的列名,以便和新表的列相匹配
例如:
create table student3(
id int primary key,
name varchar(20)
);
insert into student3 select id,name from student;
可以把外部文本文件的内容导入到数据库表中
语法:load data infile ‘文件路径\文件名字’ into table 表名;
create table hero(
id int primary key,
name varchar(10),
loc varchar(10),
sex char(1),
birth int,
death int,
power int
);
要让load data命令生效,必须修改设置:
[mysqld]
character-set-server=utf8mb4
secure-file-priv=
其中secure-file-priv默认是null值,表示不允许加载文件
可以改为具体目录名,表示只能从这个目录加载文件
如果改为"",表示可以从任意目录加载文件
例如:加载之前heroes.txt,把数据存入hero:
load data infile 'e:\\heroes.txt' into table hero;
如果文件中的列分隔符是, 不是默认\t 键,需要用 fields TERMINATED BY来指定分隔符
load data infile 'e:\\person.txt' into table person fields TERMINATED BY ',';
source 文件路径/文件名
语法:
update 表名 set 列名=新值 where 条件;
update person set sex='男'; // 把所有记录性别都改为男
update person set sex='男' where id=1; // 只修改id=1的性别为男
语法:
delete from 表名; // 删除表中所有记录(危险操作)
delete from 表名 where 条件; // 删除满足条件的记录
语法:
select 列名... from 表 where 条件 group by 分组条件 having 分组筛选条件 order by 排序条件 limit;
= 等值匹配
!= 不等值匹配
> 大于
< 小于
>= 大于等于
<= 小于等于
逻辑运算符组合多个条件
逻辑与(两个条件同时成立) and 例如:
select * from hero where sex='女' and loc='建业';
逻辑或(两个条件有一个成立,结果就是真) or
select * from hero where name='小乔' or id=200;
逻辑非 (条件取反) not
列 between 值1 and 值2 等价于 列 >= 值1 and 列 <= 值2, 注意小值要在前面,包含边界的值
列 in (值1,值2,… 值n) 等价于 列=值1 or 列=值2 … or 列=值n 注意值列表的长度
like 模糊查询 其中匹配通配符 % 表示匹配0~多个任意字符
通配符 _ 表示匹配1个任意字符
例如:
select * from hero where power between 85 and 90;
select * from hero where power >= 85 and power <=90;
not in
not like
not between ... and
排序条件:列名 升降序 如果升降序关键字省略,默认是asc
升序-> 由小到大 asc
降序-> 由大到小 desc
select * from hero order by power desc limit 10;
多列排序: 排序条件1, 排序条件2 …
先按照条件1排序,条件1中取值相同的,再按照条件2排序
limit m; // 最多返回m个结果
limit n,m; // 最多返回m个结果,n代表起始下标,下标从0开始
经常用来实现分页应用,假设每页10条
第一页 limit 0,10;
第二页 limit 10,10;
第三页 limit 20,10;
select count(*),max(sal),min(sal),sum(sal),avg(sal),deptno from emp group by deptno;
count(*) 表示求每组的个数
max(列) 求最大值
min(列) 求最小值
sum(列) 求和
avg(列) 求平均值
分组之后,
但是它的执行顺序较后;
where > group by > having > select > order by > limit // sql语句的执行顺序
select count(*), deptno from emp where count(*) >=5 group by deptno;
// 因为where先执行,这时候还没有分组,不知道个数,错误
select count(*), deptno from emp group by deptno having count(*)>=5;
//后执行就可以用count(*)做条件的约束
有时候筛选条件既可以写在where 上,也可以写在having (优先采用where)
select count(*), deptno from emp where deptno=10 or deptno=30 group by deptno;
select count(*), deptno from emp group by deptno having deptno=10 or deptno=30;
多个列取值都相同的分为一组
group by 列1,列2 ...
select count(*),deptno,job from emp group by job,deptno;
多列分组时,列的顺序不影响结果
select ... from 表1 inner join 表2 on 连接条件
where group by having order by limit;
select empno,ename,sal,emp.deptno,dept.deptno,dname,loc from emp
inner join dept on emp.deptno = dept.deptno;
表1 表1别名
select empno,ename,sal,e.deptno,d.deptno,dname,loc
from emp e inner join dept d on e.deptno = d.deptno;
表1 inner join 表2 on 连接条件 (内连接:两张表的记录必须完全满足连接条件,才会出现在最后结果中)
表1 left outer join 表2 on 连接条件 (左外连接)
表1 right outer join 表2 on 连接条件 (右外连接)
select empno, ename, e.deptno, d.deptno, d.dname, d.loc
from emp e left outer join dept d on d.deptno=e.deptno;
left outer join 位于连接左侧的表,不管是否连接到了记录,都会出现在结果中
符合连接条件的记录,和内连接效果一样
不符合连接条件的记录,对应另一张表的列都是null值
right outer join 位于连接右侧的表,不管是否连接到了记录,都会出现在结果中
outer可以省略
select ... from 表1,表2 where 连接条件;
select e.empno,e.ename,e.deptno,d.deptno,d.dname from emp e, dept d where e.deptno=d.deptno;
select ... from 表1 inner|left join 表2 using(deptno); // 两张表的连接列名要相同
select e.empno,e.ename,e.deptno,d.deptno,d.dname from emp e inner join dept d using(deptno);
select count(*) from emp; // 求整张表的行数
select max(sal) from emp; // 求整张表的工资最大值
Bit Functions 位运算函数
Comparison operators 比较运算符
Control flow functions 流程控制
Date and Time Functions 日期函数
year() 截取年份
month()
date()
date_add(日期 时间间隔); 其中时间间隔的语法:interval n 单位
select empno,ename,date_add(hiredate, interval 1 month ),hiredate from emp; 加一个月
select empno,ename,date_add(hiredate, interval 3 day ),hiredate from emp; 加3天
SELECT EXTRACT(DAY_MINUTE FROM '2009-07-02 13:02:03'); 提取日期中的从天到分钟的部分
select now() 获取当前时间
Encryption Functions 加密
Information Functions
Logical operators 逻辑运算符
Miscellaneous Functions 剩余的函数
Numeric Functions 数学函数
rand() 生成一个从[0.0 ~ 1.0) 之间的随机小数, 小于1.0
floor() 舍去小数
round() 四舍五入
String Functions 字符串函数
left(字符串, n) n代表从左边要截取的字符
lower()
upper()
substr(字符串,下标, 长度) 下标从1开始
求字符串长度的例子:select * from hero where char_length(name)=4;