资料下载
https://atgfwacnz-my.sharepoint.com/:f:/g/personal/gtfonedriver_365vip_eu_org/EiXBj0rHlm9Eh3HNpvfG7-UB7rPSc-HxisfDWmzvwt1CEQ?e=g7ejcJ
简介:各个版本的区别 官网:https://dev.mysql.com/downloads/mysql/
资料中有mysql一键安装脚本centos7的 简介:mysql的service服务管理与登录管理
查看mysql服务进程:ps -ef | grep mysql
service服务管理:cp -a mysql.server /etc/rc.d/init.d/mysql
启动命令:service mysql start 关闭命令:service mysql stop 重新启动命令:service mysql restart 查看状态命令:service mysql status
登录管理: ln -s /usr/local/mysql/bin/* /bin 登录命令:mysql -uroot -p
默认端口号:3306 配置文件:/etc/my.cnf
简介:命令行的登录与图形化界面的登录
命令行模式:
登录命令:mysql -u用户 -p密码 退出命令:exit; quit;
图形化模式: ip地址或者主机名:120.76.62.13
简介:mysql数据库的基本概念详解
简介:mysql的操作语句分类
简介:细讲数据库的创建使用
create database db1;
select database();
use 库名;
create database if not exists db2;
create database db3 default character set gbk;
show create database XD;
show variables like 'character%';
简介:细讲常用数据类型
create table test_time (
date_value date,
time_value time,
year_value year,
datetime_value datetime,
timestamp_value timestamp
) engine=innodb charset=utf8;
insert into test_time values(now(), now(), now(), now(), now());
简介:讲解表是怎么来创建的,以及常见约束条件举例说明
CREATE TABLE 表名 (
字段名1 字段类型1 约束条件1 说明1,
字段名2 字段类型2 约束条件2 说明2, 字段名3 字段类型3 约束条件3 说明3 );
create table 新表名 as select * from 旧表名 where 1=2;(注意:建议这种创建表的方式用于日常测试, 因 为可能索引什么的会复制不过来)
create table 新表名 like 旧表名;
comment ----说明解释
not null ----不为空
default. ----默认值
unsigned. ----无符号(即正数)
auto_increment. ----自增
zerofill. ----自动填充
unique key. ----唯一值
CREATE TABLE student (
id tinyint(5) zerofill auto_increment not null comment '学生学号',
name varchar(20) default null comment '学生姓名', age tinyint default null comment '学生年龄', class varchar(20) default null comment '学生班级', sex char(5) not null comment '学生性别',
unique key (id)
)engine=innodb charset=utf8;;
CREATE TABLE student (
id tinyint(5) auto_increment default null comment '学生学号',
name varchar(20) default null comment '学生姓名', age tinyint default null comment '学生年龄', class varchar(20) default null comment '学生班级', sex char(5) not null comment '学生性别',
unique key (id)
)engine=innodb charset=utf8;;
简介:如何查看表的基本结构信息 查看数据库中的所有表:show tables; 查看表结构:desc 表名; 查看创建表的sql语句:show create table 表名; \G :有结束sql语句的作用,还有把显示的数据纵向旋转90度 \g :有结束sql语句的作用
简介:细讲核心知识表结构的修改
rename table 旧表名 to 新表名; rename table student to user;
给表添加一列:alter table 表名 add 列名 类型; alter table user add addr varchar(50);
alter table add 列名 类型 comment '说明';
alter table user add famliy varchar(50) comment '学生父母';
给表最前面添加一列:alter table 表名 add 列名 类型 first; alter table user add job varchar(10) first;
给表某个字段后添加一列:alter table 表名 add 列名 类型 after 字段名; alter table user add servnumber int(11) after id;
注意:没有给表某个字段前添加一列的说法。
alter table 表名 modify 列名 新类型;
alter table user modify servnumber varchar(20);
alter table 表名 change 旧列名 新列名 类型;
alter table user change servnumber telephone varchar(20);
alter table 表名 drop 列名; alter table user drop famliy;
alter table 表名 character set 字符集; alter table user character set GBK;
drop table 表名; drop table user;
看表是否存在,若存在则删除表:drop table if exists 表名; drop table if exists teacher;
简介:讲解表数据新增的多种例子
insert into 表名(字段名) values(字段对应值);
insert into employee (empno,ename,job,mgr,hiredate,sal,deptnu) values ('1000','小明','经
理','10001','2019-03-03','12345.23','10');
insert into 表名 values(所有字段对应值);
insert into employee values ('1001','小明','经理','10001','2019-03-03','12345.23','10');
insert into 表名1 select * from 表名2;
insert into 表名1(字段名1,字段名2) select 字段名1,字段名2 from 表名2; insert into emp (empno,ename) select empno,ename from employee;
create table 表名1 as select 字段名1,字段名2 from 表名2; create table emp as select empno ,ename from employee;
insert into 表名 (字段名) values (对应值1),(对应值2),(对应值3);
CREATE TABLE employee(
empno
ename
job
mgr
hiredate
sal
deptnu
);
INT PRIMARY KEY comment '雇员编号', VARCHAR(20) comment '雇员姓名', VARCHAR(20) comment '雇员职位',
INT comment '雇员上级编号',
DATE comment '雇佣日期', DECIMAL(7,2) comment '薪资', INT comment '部门编号'
简介:讲解如何对表数据进行修改删除以及注意事项
update 表名 set 字段名1=值1 where 字段名=值;
update 表名 set 字段名1=值1,字段名2=值2 where 字段名=值;
delete from 表名 where 字段名=值;
truncate table 表名; delete from 表名; drop table 表名;
面试时:面试官问在删改数据之前,你会怎么做?
答案:会对数据进行备份操作,以防万一,可以进行数据回退
面试时:面试官会问,delete与truncate与drop 这三种删除数据的共同点都是删除数据,他们的不同点是什么? delele 会把删除的操作记录给记录起来,以便数据回退,不会释放空间,而且不会删除定义。 truncate不会记录删除操作,会把表占用的空间恢复到最初,不会删除定义 drop会删除整张表,释放表占用的空间。
drop > truncate > delete
简介:详细讲解汉字显示乱码问题
[client] default-character-set=gbk 作用于外部的显示
[mysqld]
character_set_server=gbk 作用于内部,会作用于创建库表时默认字符集
alter database xiaoxiao default character set gbk;
alter table employee default character set utf8;
简介:细讲对数据表中的数据进行各种查询,以及项目实战查询
/*创建部门表*/
CREATE TABLE dept(
deptnu INT PRIMARY KEY comment '部门编号',
dname VARCHAR(50) comment '部门名称',
addr VARCHAR(50) comment '部门地址'
);
CREATE TABLE employee(
empno INT PRIMARY KEY comment '雇员编号',
ename VARCHAR(50) comment '雇员姓名',
job VARCHAR(50) comment '雇员职位',
mgr INT comment '雇员上级编号',
hiredate DATE comment '雇佣日期',
sal DECIMAL(7,2) comment '薪资',
deptnu INT comment '部门编号'
)ENGINE=MyISAM DEFAULT CHARSET=utf8;
/*创建工资等级表*/
CREATE TABLE salgrade(grade INT PRIMARY KEY comment '等级',
lowsal INT comment '最低薪资',
higsal INT comment '最高薪资'
);
/*插入dept表数据*/
INSERT INTO dept VALUES (10, '研发部', '北京');
INSERT INTO dept VALUES (20, '工程部', '上海');
INSERT INTO dept VALUES (30, '销售部', '广州');
INSERT INTO dept VALUES (40, '财务部', '深圳');
/*插入emp表数据*/
INSERT INTO employee VALUES (1009, '唐僧', '董事长', NULL, '2010-11-17', 50000, 10);
INSERT INTO employee VALUES (1004, '猪八戒', '经理', 1009, '2001-04-02', 29750, 20);
INSERT INTO employee VALUES (1006, '猴子', '经理', 1009, '2011-05-01', 28500, 30);
INSERT INTO employee VALUES (1007, '张飞', '经理', 1009, '2011-09-01', 24500,10);
INSERT INTO employee VALUES (1008, '诸葛亮', '分析师', 1004, '2017-04-19', 30000, 20);
INSERT INTO employee VALUES (1013, '林俊杰', '分析师', 1004, '2011-12-03', 30000, 20);
INSERT INTO employee VALUES (1002, '牛魔王', '销售员', 1006, '2018-02-20', 16000, 30);
INSERT INTO employee VALUES (1003, '程咬金', '销售员', 1006, '2017-02-22', 12500, 30);
INSERT INTO employee VALUES (1005, '后裔', '销售员', 1006, '2011-09-28', 12500, 30);
INSERT INTO employee VALUES (1010, '韩信', '销售员', 1006, '2018-09-08', 15000,30);
INSERT INTO employee VALUES (1012, '安琪拉', '文员', 1006, '2011-12-03', 9500, 30);
INSERT INTO employee VALUES (1014, '甄姬', '文员', 1007, '2019-01-23', 7500, 10);
INSERT INTO employee VALUES (1011, '妲己', '文员', 1008, '2018-05-23', 11000, 20);
INSERT INTO employee VALUES (1001, '小乔', '文员', 1013, '2018-12-17', 8000, 20);
/*插入salgrade表数据*/
INSERT INTO salgrade VALUES (1, 7000, 12000);
INSERT INTO salgrade VALUES (2, 12010, 14000);
INSERT INTO salgrade VALUES (3, 14010, 20000);
INSERT INTO salgrade VALUES (4, 20010, 30000);
INSERT INTO salgrade VALUES (5, 30010, 99990);
简介:详解where条件下的各种查询
select * from employee;
select empno,ename,job as ename_job from employee;
select * from employee where ename='后裔'; select * from employee where sal != 50000; select * from employee where sal <> 50000; select * from employee where sal > 10000;
show variables like '%aracter%';
select * from employee where ename like '林%';
select * from employee where sal between 10000 and 30000;
select * from employee where hiredate between '2011-01-01' and '2017-12-1';
select * from employee where ename in ('猴子','林俊杰','小红','小胡');
select distinct(job) from employee;
count(code)或者count(*)
select count(*) from employee; select count(ename) from employee;
sum() 计算总和
select sum(sal) from employee;
max() 计算最大值
select * from employee where sal= (select max(sal) from employee);
avg() 计算平均值
select avg(sal) from employee;
min() 计算最低值
select * from employee where sal= (select min(sal) from employee);
concat函数: 起到连接作用
select concat(ename,' 是 ',job) as aaaa from employee;
简介:详解group by的用法以及应用场景
eg:
select deptnu,count(*) from employee group by deptnu;
select deptnu,job,count(*) from employee group by deptnu,job;
select job,count(*) from employee group by job;
作用:对查询的结果进行筛选操作 语法:having 条件 或者 having 聚合函数 条件 适用场合:一般跟在group by之后
eg:
select job,count(*) from employee group by job having job ='文员';
select deptnu,job,count(*) from employee group by deptnu,job having count(*)>=2; select deptnu,job,count(*) as 总数 from employee group by deptnu,job having 总数>=2;
简介:详解order by的用法以及应用场景
eg:
select * from employee order by sal;
select * from employee order by hiredate;
select deptnu,job,count(*) as 总数 from employee group by deptnu,job having 总数>=2
order by deptnu desc;
select deptnu,job,count(*) as 总数 from employee group by deptnu,job having 总数>=2
order by deptnu asc;
select deptnu,job,count(*) as 总数 from employee group by deptnu,job having 总数>=2
order by deptnu;
顺序:where ---- group by ----- having ------ order by
简介:详解limit的用法以及应用场景
eg:
select * from XD.employee limit 4,5;
简介:详解exists的用法
分为俩种:exists跟 not exists select 1 from employee where 1=1;
select * from 表名 a where exists (select 1 from 表名2 where 条件);
eg:查询出公司有员工的部门的详细信息
select * from dept a where exists (select 1 from employee b where a.deptnu=b.deptnu); select * from dept a where not exists (select 1 from employee b where a.deptnu=b.deptnu);
简介:详解左右连接的用法以及应用场景
eg:列出部门名称和这些部门的员工信息,同时列出那些没有的员工的部门 dept,employee
select a.dname,b.* from dept a left join employee b on a.deptnu=b.deptnu;
select b.dname,a.* from employee a right join dept b on b.deptnu=a.deptnu;
简介:详解内连接与联合查询的用法以及应用场景
eg:想查出员工张飞的所在部门的地址
select a.addr from dept a inner join employee b on a.deptnu=b.deptnu and b.ename='张
飞';
select a.addr from dept a,employee b where a.deptnu=b.deptnu and b.ename='张飞';
(1)两个select语句的查询结果的“字段数”必须一致; (2)通常,也应该让两个查询语句的字段类型具有一致性;
(3)也可以联合更多的查询结果;
(4)用到order by排序时,需要加上limit(加上最大条数就行),需要对子句用括号括起来
eg:对销售员的工资从低到高排序,而文员的工资从高到低排序
(select * from employee a where a.job = '销售员' order by a.sal limit 999999 )
union (select * from employee b where b.job = '文员' order by b.sal desc limit 999999);
简介:高级查询实战
涉及表: employee dept
语句:select deptnu,count(*) from employee group by deptnu
语句:select a.deptnu,a.dname,a.addr, b.zongshu from dept a,(select deptnu,count(*) as
zongshu from employee group by deptnu) b where a.deptnu=b.deptnu;
涉及表:employee
语句:select * from employee where sal > (select sal from employee where ename='安琪 拉');
涉及表:employee
语句:select a.ename,ifnull(b.ename,'BOSS') as leader from employee a left join employee b on a.mgr=b.empno;
涉及表:employee dept
条件:a.hiredate < b.hiredate
语句:select a.empno,a.ename,c.dname from employee a left join employee b on
a.mgr=b.empno left join dept c on a.deptnu=c.deptnu where a.hiredate < b.hiredate;
涉及表:dept employee
语句:select a.dname,b.* from dept a left join employee b on a.deptnu=b.deptnu;
涉及表:employee dept
条件:job='文员'
语句:select deptnu,count(*) as zongshu from employee group by deptnu; 语句:select b.ename,a.dname,b.job,c.zongshu from dept a ,employee b ,(select
deptnu,count(*) as zongshu from employee group by deptnu) c where a.deptnu=b.deptnu and b.job='文员' and b.deptnu=c.deptnu;
简介:高级查询实战续
涉及表:employee
条件:min(sal) > 15000
语句:select job,count(*) from employee group by job having min(sal) > 15000;
涉及表:employee dept
select ename from employee where deptnu=(select deptnu from dept where dname='销售部');
涉及表:employee dept
语句:select a.ename,b.dname from employee a,dept b where a.deptnu=b.deptnu and a.job=
(select job from employee where ename='诸葛亮');
语句:select a.ename,b.dname from employee a left join dept b on a.deptnu=b.deptnu where
a.job=(select job from employee where ename='诸葛亮');
涉及表:employee dept
语句:select a.ename,a.sal,b.dname from employee a ,dept b where a.deptnu=b.deptnu and sal > (select max(sal) from employee where deptnu=30);
涉及表:employee
语句:select deptnu , count(*) ,avg (sal) from employee group by deptnu;
涉及表:employee dept salgrade
条件:select avg(sal) from employee
语句:elect a.*,c.dname,b.ename,d.grade from employee a,employee b,dept c ,salgrade d
where a.mgr=b.empno and a.deptnu =c.deptnu and a.sal > (select avg(sal) from
employee) and a.sal between d.lowsal and d.higsal;
简介:精讲数据控制语言如何限制用户的各种权限
什么是DCL数据控制语言? 数据控制语言(DCL:Data Control Language)是用来设置或者更改数据库用户或角色权限的语句,这些语句 包括GRANT、DENY、REVOKE等语句
简介:详解如何从安全角度出发限制root用户指定ip登录
select user,host from mysql.user where user='root';
update mysql.user set host='localhost' where user='root';
flush privileges;
简介:详解忘记密码以及如何修改用户密码
set password for root@localhost = password('root');
mysqladmin -urootmysqladmin -uroot -proot password;
update mysql.user set authentication_string=password('root') where user='root' and
host='localhost';
简介:讲解如何创建新用户与删除用户并限制ip登录
username:你将创建的用户名 host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机 登
陆,可以使用通配符% password:该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器
create user 'pig'@'%' identified by '123456';
创建一个pig用户,并指定登录密码:为空,指定在120网段的机器登录
create user 'pig'@'120.%.%.%' identified by '';
select * from mysql.user where user='pig'\G
mysql> show grants for 'pig'@'%';
+---------------------------------+
| Grants for pig@% |
+---------------------------------+
| GRANT USAGE ON *.* TO 'pig'@'%' |
+---------------------------------+
USAGE:无权限的意思
mysql> show grants for 'root'@'localhost'; +---------------------------------------------------------------------+
| Grants for root@localhost | +---------------------------------------------------------------------+ | GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION | +---------------------------------------------------------------------+ WITH GRANT OPTION:表示这个用户拥有grant权限,即可以对其他用户授权
drop user 'pig'@'%';
delete from mysql.user where user='pig';
简介:讲解如何限制用户对库表的增删改查权限
grant 权限1,权限2..... on 数据库对象 to '用户'@'host' identified by 'password';
对现有用户进行授权:对现有用户pig授予所有库所有表所有权限。 grant all privileges on *.* to 'pig';
对没有的用户进行授权:创建一个新用户dog授予XD库的所有权限,登录密码123456,任何一台主机登录 grant all privileges on XD.* to 'dog'@'%' identified by '123456';
对没有的用户进行授权:创建一个新用户cat授予XD库的employee表 查与修改权限,登录密码123456,任何一台主机登 录
grant select,update on XD.employee to 'cat'@'%' identified by '123456'
对没有的用户进行授权:对用户cat授予XD库的employee表insert 权限,登录密码123456,任何一台主机登录 grant insert on XD.employee to 'cat'@'%' identified by '123456';
回收pig用户的所有权限(注意:并没有回收它的登录权限) revoke all privileges on *.* from 'pig' @ '%'; flush privileges;
回收pig用户的所有权限(并回收它的登录权限) delete from mysql.user where user='pig'; flush privileges;
回收cat用户对XD库的employee的查与修改权限
revoke select,update on XD.employee from 'cat'@'%'; flush privileges;
简介:深入详解事务
答:数据库事务通常指对数据库进行读或写的一个操作过程。有两个目的,第一个是为数据库操作提供了一个从失败中恢复
到正常状态的方法,同时提供了数据库即使在异常状态下仍能保持一致性的方法;第二个是当多个应用程序在并发访问数据
库时,可以在这些应用程序之间提供一个隔离方法,以防止彼此的操作互相干扰。
简介:主要讲解事务的开启以及事务实战,深入了解什么是事务
创建一个账户表模拟转账
create table account (
id tinyint(5) zerofill auto_increment not null comment 'id编号', name varchar(20) default null comment '客户姓名',
money decimal(10,2) not null comment '账户金额',
primary key (id)
)engine=innodb charset=utf8;
OFF(0):表示关闭 ON (1):表示开启
mysql> set autocommit=0;
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit | OFF |
+---------------+-------+
mysql> set autocommit=1;
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit | ON |
修改配置文件:vi /etc/my.cnf 在[mysqld]下面加上:autocommit=1 记得重启服务才会生效
简介:详细讲解视图的优缺点以及应用
视图(view)是一种虚拟存在的表,是一个逻辑表,它本身是不包含数据的。作为一个select语句保存在数据字典中的。 通过视图,可以展现基表(用来创建视图的表叫做基表base table)的部分数据,说白了视图的数据就是来自于基表
1)简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件 的结果集。
2)安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就 可以简单的实现。
3)数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则 可以通过修改视图来解决,不会造成对访问者的影响。
4)不占用空间:视图是逻辑上的表,不占用内存空间 总而言之,使用视图的大部分情况是为了保障数据安全性,提高查询效率。
创建的基本语法是:
create view <视图名称> as select 语句; create view <视图名称> (字段) as select 语句; create or replace view <视图名称>;
修改的语法是:
alter view <视图名称> as select 语句;
视图删除语法:
drop view <视图名称> ;
1)性能差:sql server必须把视图查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,即 使是视图的一个简单查询,sql server也要把它变成一个复杂的结合体,需要花费一定的时间。
2)修改限制:当用户试图修改试图的某些信息时,数据库必须把它转化为对基本表的某些信息的修改,对于简单的试图来 说,这是很方便的,但是,对于比较复杂的试图,可能是不可修改的。
简介:介绍什么是触发器以及如何来创建
触发器就是监视某种情况,并触发某种操作
create trigger 触发器名称 after/before insert/update/delete on 表名 for each row
begin sql语句; end
after/before:可以设置为事件发生前或后 insert/update/delete:它们可以在执行insert、update或delete的过程中触发 for each row:每隔一行执行一次动作
drop trigger 触发器名称;
创建一个员工迟到表:
create table work_time_delay(
empno int not null comment '雇员编号',
ename varchar(50) comment '雇员姓名', status int comment '状态'
);
delimiter // 自定义语句的结束符号
mysql> delimiter //
mysql>
mysql> create trigger trig_work after insert on work_time_delay
-> for each row
-> begin
-> update employee set sal=sal-100 where empno=new.empno;
-> end
-> //
Query OK, 0 rows affected (0.01 sec) new:指的是事件发生before或者after保存的新数据
简介:介绍什么是存储过程
存储过程就是把复杂的一系列操作,封装成一个过程。类似于shell,python脚本等。
优点是: 1)复杂操作,调用简单 2)速度快
缺点是: 1)封装复杂
2) 没有灵活性
create procedure 名称 (参数....) begin
过程体; 过程体; end
参数:in|out|inout 参数名称 类型(长度) in:表示调用者向过程传入值(传入值可以是字面量或变量) out:表示过程向调用者传出值(可以返回多个值)(传出值只能是变量) inout:既表示调用者向过程传入值,又表示过程向调用者传出值(值只能是变量)
show create procedure 名称\G;
创建一个简单的存储过程:
mysql> delimiter //
mysql> create procedure name(in n int)
-> begin
-> select * from employee limit n;
-> end -> //
Query OK, 0 rows affected (0.00 sec)
mysql> set @n=5;
-> //
Query OK, 0 rows affected (0.00 sec)
mysql>
mysql> call name(@n);
mysql> ->
->
->
->
-> //
create procedure name()
begin
declare n int default 6;
select * from employee limit n;
end
Query OK, 0 rows affected (0.00 sec)
mysql> call name();
简介:主要来详细介绍MyISAM与InnoDB引擎
(1)什么是数据库存储引擎?
数据库引擎是数据库底层软件组件,不同的存储引擎提供不同的存储机制,索引技巧,锁定水平等功能,使用不同的数据库
引擎,可以获得特定的功能
(2)如何查看引擎?
如何查看数据库支持的引擎
show engines;
查看当前数据的引擎:
show create table 表名\G
查看当前库所有表的引擎:
show table status\G
(3)建表时指定引擎
create table yingqin (id int,name varchar(20)) engine='InnoDB';
(4)修改表的引擎
alter table 表名 engine='MyiSAm';
修改默认引擎
• vi /etc/my.cnf
• [mysqld]下面
• default-storage-engine=MyIsAM
• 记得保存后重启服务
(5)MyISAM与InnoDB的区别
MyISAM:支持全文索引(full text);不支持事务;表级锁;保存表的具体行数;奔溃恢复不好
Innodb:支持事务;以前的版本是不支持全文索引,但在5.6之后的版本就开始支持这个功能了;行级锁(并非绝对,当执行 sql语句时不能确定范围时,也会进行锁全表例如: update table set id=3 where name like 'a%';);不保存表 的具体行数;奔溃恢复好
(6)总结:什么时候选择什么引擎比较好
MyISAM:
• 一般来说MyISAM不需要用到事务的时候
• 做很多count计算
InnoDB:
• 可靠性要求高的,或者要求支持事务
• 想要用到外键约束的时候(讲外键的时候会讲)
推荐:
• 推荐用InnoDB
简介:讲解什么是索引,索引的优缺点,以及常见索引有哪些
索引是一个单独的,存储在磁盘中上的数据库结构,它们包含着对数据表里的所有记录的引用指针。使用索引可以快速的找
出在某列或多列中有特定值的行。
• 通过创建唯一索引,来保证数据库表中的每一行数据的唯一性。
• 可以加快数据的检索速度。
• 可以保证表数据的完整性与准确性
• 索引需要占用物理空间。
• 对表中的数据进行改动时,索引也需要跟着动态维护,降低了数据的维护速度。
• index:普通索引
• unique:唯一索引
• primary key:主键索引
• foreign key:外键索引
• fulltext: 全文索引
• 组合索引
create table test (
id int(7) zerofill auto_increment not null,
username varchar(20),
servnumber varchar(30),
password varchar(20),
createtime datetime,
primary key (id)
)DEFAULT CHARSET=utf8;
#!/bin/bash
echo "请输入字段servnumber的值:" read serber
echo "请输入创建sql语句的数量:" read number
# char=`head /dev/urandom | tr -dc 0-9 | head -c 11`
for (( i=0;i<$number;i++ ))
do
pass=`head /dev/urandom | tr -dc a-z | head -c 8`
let serber=serber+1
echo "insert into test(id,username,servnumber,password,createtime)
values('$i','user${i}','${serber}','$pass',now());" >>sql.txt
done
vi test.sh 执行shell脚本:sh test.sh 进行插数操作:source /home/dazhu/sql.txt
简介:介绍普通索引与唯一索引
普通索引(index)顾名思义就是各类索引中最为普通的索引,主要任务就是提高查询速度。其特点是允许出现相同的索引 内容,允许空(null)值
唯一索引:(unique)顾名思义就是不可以出现相同的索引内容,但是可以为空(null)值
create table test (
id int(7) zerofill auto_increment not null,
username varchar(20),
servnumber varchar(30),
password varchar(20),
createtime datetime,
unique (id)
)DEFAULT CHARSET=utf8;
直接为表添加索引
语法:
alter table 表名 add index 索引名称 (字段名称);
eg:
alter table test add unique unique_username (username);
注意:假如没有指定索引名称时,会以默认的字段名为索引名称
直接创建索引
语法:create index 索引 on 表名 (字段名);
eg:create index index_createtime on test (createtime);
语法:show index from 表名\G eg: show index from test\G
语法:drop index 索引名称 on 表名; eg:drop index unique_username on test;
语法:alter table 表名 drop index 索引名; eg:alter table test drop index createtime;
简介:详细讲解主键索引
把主键添加索引就是主键索引,它是一种特殊的唯一索引,不允许有空值,而唯一索引(unique是允许为空值的)。指定 为“PRIMARY KEY”
主键:主键是表的某一列,这一列的值是用来标志表中的每一行数据的。
注意:每一张表只能拥有一个主键
1)创建表的时候创建
2)直接为表添加主键索引
语法:alter table 表名 add primary key (字段名); eg:alter table test add primary key (id);
语法:
alter table 表名 drop primary key; eg:
alter table test drop primary key;
注意:在有自增的情况下,必须先删除自增,才可以删除主键
删除自增:alter table test change id id int(7) unsigned zerofill not null;
简介:介绍什么是全文索引以及使用
全文索引是将存储在数据库中的文章或者句子等任意内容信息查找出来的索引,单位是词。全文索引也是目前搜索引擎 使用的一种关键技术。指定为 fulltex
create table command (
id int(5) unsigned primary key auto_increment,
name varchar(10),
instruction varchar(60)
)engine=MyISAM;
insert into command values('1','ls','list directory contents');
insert into command values('2','wc','print newline, word, and byte counts for each file');
insert into command values('3','cut','remove sections from each line of files'); insert into command values('4','sort','sort lines of text files');
insert into command values('5','find','search for files in a directory hierarchy'); insert into command values('6','cp','复制文件或者文件夹');
insert into command values('7','top','display Linux processes');
insert into command values('8','mv','修改文件名,移动');
insert into command values('9','停止词','is,not,me,yes,no ...');
alter table command add fulltext(instruction);
select * from 表名 where match (字段名) against ('检索内容');
select * from command where match(instruction) against ('sections');
select * from command where match(instruction) against ('directory');
出现频率很高的词,将会使全文索引失效
in boolean mode:意思是指定全文检索模式为布尔全文检索(简单可以理解为是检索方式) select * from 表名 where match (字段名) against ('检索内容' in boolean mode);
使用通配符*时,只能放在词的后边,不能放前边。
alter table command drop index instruction;
• 1、一般情况下创建全文索引的字段数据类型为 char、varchar、text 。其它字段类型不可以
• 2、全文索引不针对非常频繁的词做索引。比如is,no,not,you,me,yes这些,我们称之为停止词
• 3、对英文检索时忽略大小写
简介:解析什么是外键约束,以及有什么作用
外键就是作用于两个表数据之间的链接的一列或多列,用来保证表与表之间的数据的完整性和准确性。
语法:foreign key (字段名) references 关联的表名(关联表的字段名) 注意:主键跟外键的字段类型一定要相
create table的方法:
CREATE TABLE `employee` (
`empno` int(11) NOT NULL COMMENT '雇员编号',
`ename` varchar(50) DEFAULT NULL COMMENT '雇员姓名', `job` varchar(30) DEFAULT NULL,
`mgr` int(11) DEFAULT NULL COMMENT '雇员上级编号', `hiredate` date DEFAULT NULL COMMENT '雇佣日期', `sal` decimal(7,2) DEFAULT NULL COMMENT '薪资', `deptnu` int(11) DEFAULT NULL COMMENT '部门编号', PRIMARY KEY (`empno`),
foreign key (deptnu) references dept(deptnu)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
alter table的方法:
alter table employee add foreign key (deptnu) references dept(deptnu);
注意:在干掉外键索引之前必须先把外键约束删除,才能删除索引
mysql> alter table employee drop index deptnu;
ERROR 1553 (HY000): Cannot drop index 'deptnu': needed in a foreign key constraint
mysql>
mysql> alter table employee drop foreign key employee_ibfk_1;
Query OK, 0 rows affected (0.01 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql>
mysql> alter table employee drop index deptnu;
Query OK, 0 rows affected (0.01 sec)
Records: 0 Duplicates: 0 Warnings: 0
(1)俩个表,主键跟外键的字段类型一定要相同 (2)要使用外键约束表的引擎一定得是InnoDB引擎,MyISAM是不起作用的 (3)在干掉外键索引之前必须先把外键约束删除,才能删除索引
简介:详细介绍联合索引
联合索引又称组合索引或者复合索引,是建立在俩列或者多列以上的索引。
alter table 表名 add index(字段1,字段2,字段3);
alter table test add index(username,servnumber,password);
alter table test drop index username;
联合索引的效率远远高于单列索引
• 索引并非越多越好,过多的索引会增加数据的维护速度还有磁盘空间的浪费。 • 当表的数据量很大的时候,可以考虑建立索引。
• 表中经常查数据的字段,可以考虑建立索引。
• 想要保证表中数据的唯一性,可以考虑建立唯一索引。
• 想要保证俩张表中的数据的完整性跟准确性,可以考虑建立外键约束。 • 经常对多列数据进行查询时,可以考虑建立联合索引。
简介:介绍如何开启慢查询日志与问题定位
mysql> show variables like 'slow%';
+---------------------+--------------------------------------+
| Variable_name | Value |
+---------------------+--------------------------------------+
| slow_launch_time | 2 |
| slow_query_log | OFF |
| slow_query_log_file | /data/mydata/xdclass-public-slow.log |
+---------------------+--------------------------------------+
set global slow_query_log = on ;
日志路径也可以自定义:
set global slow_query_log_file = '路径';
show variables like '%long%';
set long_query_time=0.4;
永久生效的设置方法:修改配置文件 vi /etc/my.cnf [mysqld]
slow_query_log = 1
long_query_time = 0.1
slow_query_log_file =/usr/local/mysql/mysql_slow.log
最后必须重启服务才能生效!
简介:介绍如何开启性能详情
mysql> show variables like '%profiling%';
+------------------------+-------+
| Variable_name | Value |
+------------------------+-------+
| have_profiling | YES |
| profiling | OFF |
| profiling_history_size | 15 |
+------------------------+-------+
set profiling = on ;
mysql> show profiles;
+----------+------------+---------------------------------------------------+
| Query_ID | Duration | Query |
+----------+------------+---------------------------------------------------+
| 1 | 0.00177775 | show variables like '%profiling%' |
| 2 | 0.00037900 | select * from test where id='087878' |
| 3 | 0.34618025 | select * from test where servnumber='1367008787' |
| 4 | 0.31986825 | select * from test where servnumber='13670087879' |
+----------+------------+---------------------------------------------------+
mysql> show profile for query 4;
+----------------------+----------+
| Status | Duration |
+----------------------+----------+
| starting | 0.000100 |
| checking permissions | 0.000010 |
| Opening tables
| init
| System lock
| optimizing
| statistics
| preparing
| executing
| Sending data
| end
| 0.000023 |
| 0.000045 |
| 0.000015 |
| 0.000016 |
| 0.000028 |
| 0.000020 |
| 0.000006 |
| 0.319489 |
| 0.000037 |
| 0.000012 |
| 0.000012 |
| 0.000040 |
| 0.000017 |
| query end
| closing tables
| freeing items
| cleaning up
+----------------------+----------+
https://dev.mysql.com/doc/refman/5.7/en/general-thread-states.html
简介:介绍日常工作应该尽量避免的sql语句
尽量避免使用select *from ,尽量精确到想要的结果字段
尽量避免条件使用or
记得加上limit 限制行数,避免数据量过大消耗性能
使用模糊查询时,%放在前面是会使索引失效
mysql> explain select * from test where servnumber like '%1367000%'\G
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: test
partitions: NULL
type: ALL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: 996303
filtered: 11.11
Extra: Using where
要小心条件字段类型的转换
简介:数据库备份的意义
(1)保护数据的安全;
(2)在出现意外的时候(硬盘的损坏,断电,黑客的攻击),以便数据的恢复;
(3)导出生产的数据以便研发人员或者测试人员测试学习;
(4)高权限的人员操作失误导致数据丢失,以便恢复;
简介:介绍数据备份
(1)完全备份:对整个数据库的数据进行备份
(2)部分备份:对部分数据进行备份(可以是一张表也可以是多张表)
增量备份:是以上一次备份为基础来备份变更数据的,节约空间
差异备份:是以第一次完全备份的基础来备份变更备份的,浪费空间
(1)逻辑备份:直接生成sql语句保存起来,在恢复数据的时候执行备份的sql语句来实现数据的恢复 (2)物理备份:直接拷贝相关的物理数据
区别:逻辑备份效率低,恢复数据效率低,但是逻辑备份节约空间;物理备份浪费空间,但是相对逻辑备份而言效率比
较高
(1)热备份:备份时,数据库的读写操作不会受到影响
(2)温备份:备份时,数据库的读操作可以进行,但是写操作不能执行 (3)冷备份:备份时,不能进行任何操作
简介:如何利用mysql自带命令mysqldump来备份单库或者多库
mysqldump -u 用户 -h host -p 密码 dbname table > 路径
mysqldump -uroot -pabc123456 -h120.25.93.69 zabbix | gzip >
/mysql_data_back/zabbix_users.sql.gz
mysqldump -uroot -pabc123456 -h120.25.93.69 --databases zabbix | gzip >
/mysql_data_back/zabbix_bak.sql.gz
mysqldump -uroot -pabc123456 -h120.25.93.69 zabbix users | gzip >
/mysql_data_back/zabbix_users.sql.gz
mysqldump -uroot -pabc123456 -h120.25.93.69 --databases zabbix XD | gzip >
/mysql_data_back/zabbix_XD.sql.gz
mysqldump -uroot -pabc123456 -h120.25.93.69 --all-databases | gzip >
/mysql_data_back/all.sql.gz
简介:如何恢复数据
mysql -uroot -pabc123456 -h120.25.93.69 < zabbix_bak.sql
mysql -uroot -pabc123456 -h120.25.93.69 zabbix < zabbix_bak.sql
简介:详解数据库源文件以及如何物理备份
mysql> show variables like 'datadir%';
+---------------+---------------+
| Variable_name | Value |
+---------------+---------------+
| datadir | /data/mydata/ |
+---------------+---------------+
cat /etc/my.cnf
db.opt:创建库的时候生成,主要存储着当前库的默认字符集和字符校验规则 .frm :记录着表结构信息的文件
.MYI:记录着索引的文件
.MYD :记录着表的数据
db.opt:创建库的时候生成,主要存储着当前库的默认字符集和字符校验规则 .frm :记录着表结构信息的文件
.ibd :独立表空间,里边记录这个表的数据和索引 ibdata1:共享表空间,里边记录表的数据和索引
flush tables with read lock;
unlock tables;
简介:讲解如何利用二进制日志来备份数据
二进制日志就是记录着mysql数据库中的一些写入性操作,比如一些增删改,但是,不包括查询!
一般情况下,二进制日志有着数据复制和数据恢复的功能
开启二进制日志会有1%的性能消耗!
mysql> show variables like 'log_bin%';
+---------------------------------+-------+
| Variable_name | Value |
+---------------------------------+-------+
| log_bin | OFF |
[mysqld]
log-bin=/data/mydata/log_bin/mysql-bin
server-id=1
mysql> show master logs;
+------------------+-----------+
| Log_name | File_size |
+------------------+-----------+
| mysql-bin.000001 | 23638 |
+------------------+-----------+
flush logs;
mysql> show master logs;
+------------------+-----------+
| Log_name | File_size |
+------------------+-----------+
| mysql-bin.000001 | 1091 |
+------------------+-----------+
mysqldump -uroot -p XD user -F > user_bak.sql
简介:讲解如何利用二进制日志来恢复数据
[root@xdclass-public log_bin]# mysqlbinlog mysql-bin.000002
mysqlbinlog: [ERROR] unknown variable 'default-character-set=utf8'
第一种:在mysqlbinlog 后边加上 --no-defaults 第二种:注释掉配置文件里边的default-character-set=utf8
mysqlbinlog --base64-output=DECODE-ROWS -v mysql-bin.000002 > mysqlbin.sql
(1)找出关键字的行数:mysqlbinlog --no-defaults mysql-bin.000002 | cat -n | grep -iw 'drop'
[root@xdclass-public log_bin]# mysqlbinlog --no-defaults mysql-bin.000002 | cat -n |
grep -iw 'drop'
4180 DROP TABLE `user` /* generated by server */
(2)打印出相关内容:mysqlbinlog --no-defaults mysql-bin.000002 | cat -n | sed -n '4170,4180p'
[root@xdclass-public log_bin]# mysqlbinlog --no-defaults mysql-bin.000002 | cat -n |
sed -n '4170,4180p'
4170 # at 59578
4171 #190419 0:41:48 server id 1 end_log_pos 59609 CRC32 0x36cda2b7
6380
4172 COMMIT/*!*/;
4173 # at 59609
4174 #190419 0:41:48 server id 1 end_log_pos 59674 CRC32 0x8de2f06a
Anonymous_GTID last_committed=145 sequence_number=146
4175 SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
4176 # at 59674
4177 #190419 0:41:48 server id 1 end_log_pos 59787 CRC32 0x6b2edd2b
thread_id=14 exec_time=0 error_code=0
4178 use `XD`/*!*/;
4179 SET TIMESTAMP=1555605708/*!*/;
4180 DROP TABLE `user` /* generated by server */
[root@xdclass-public log_bin]#
Xid =
Query
第一步:把备份的数据表user恢复到数据库中:mysql -uroot -p XD < /mysql_data_back/user_bak.sql 第二步:利用上面找到的删除的位置进行恢复数据
mysqlbinlog --no-defaults --set-charset=utf8 --stop-position="59674"
/data/mydata/log_bin/mysql-bin.000002 | mysql -uroot -p
登录数据库查看数据是否恢复回来