本文主要给大家介绍MySQL 存储引擎知识讲解,希望可以给大家补充和更新些知识,如有其它问题需要了解的可以持续在开发云行业资讯里面关注我的更新文章的。1、MySQL键值(限制如何给字段赋值)
1)
索引:类似与“书的目录”树型目录
缺点:减慢写的速度(insert update delete)
占用物理存储空间
优点:加快查询速度
2)
使用索引
使用规则
一个表中可以由多个index字段
字段的值允许由重复,切可以赋NULL
经常把做查询条件的字段设置为index字段
index字段的key标志是MUL查看索引
desc 表名;show index for 表名;
#查看索引详细信息创建索引
create table 表名(
字段 类型,
index(索引名);
#建表时创建索引
#默认和字段名同名-> create table t21(
-> name char(10),
-> age int,
-> sex enum(‘boy’,’girl’),
-> index(name),
-> index(sex));#####################################################################create index 索引名 on 表名(字段);
#已有表创建索引
#索引名可以和字段名相同
#默认使用的索引类型:BRREE(二叉树)create index name on t3(name)drop index 索引名 on 表名;
#删除索引###################################################################
主键 parimary key使用规则
一个表中只能有一个 parimary key 字段
对应的字段值不允许有重复,且不允许赋值
如果有多个字段都作为 parimary key ,称为复合主键,必须一个创建。
主健字段的KEY标志死PRI
通常与 auto_increment 连用
经常把表中能够唯一标识记录的字段位主键
1)
-> create table t22( -> create table t22(
-> name char(10), -> name char(10)primary key ,
-> age int, -> age int,
-> likes set(‘a’,’b’,’c’), -> likes set(‘a’,’b’,’c’)0;
-> primary key(name));
#创建表时添加主键2)
alter table 表名 add primary key(字段);
#已有表添加主键3)
alter table 表名 drop primary key;
#删除主键##########################################################################
复合主键
多个字段一起做主键,字段值无法同时重复。1)
-> create table 表名(
-> cip char(15),
-> port smallint,
-> status enum(‘allow’,’deny’) default ‘deny’,
-> primary key(cip,port));
#创建复合主键,必须一起创建2)
alter table 表名 drop primary key;
#删除复合主键,必须同时删除3)
alter table t23 add primary key(cip,port);
#已有表创建复合主键#############################################################################
主键与 auto_increment 连用,让字段的最大值自动增长 +1 ,并且位数值类型1)
-> create table t24(
-> id int(2) zerofill primary key auto_increment,
-> name char(10),
-> class char(4),
-> index(name));
#创建表insert into t24(name,class) values(‘tom’,’1709′);
#添加信息 name class ,此时表中 id 字段自动 +1 。2)
alter table t24 modify id int(2) unsigned zerofill not null;
alter table t24 drop primary key;
#删除主键要先把 aotu_increment############################################################################
unique唯一索引
一个表中可以有多个unique字段
对应的字段值不允许有重复
un开发云主机域名ique字段的key标志是uni
unique字段的值允许为null,当将其修改为不允许为null,则此字段限制与主键相同############################################################################
外键:foreign key
作用:
限制给字段赋值的。
值必须在指定表中指定字段值的范围内选择。
条件:
表的存储引擎必须是innodb
字段类型要一致
被参照字段必须要是索引类型的一种(primary key)~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1)
foreign key(字段) references 被参考表(字段)
on update cascade on delete cascade
#使用方法,同步更新同步删除练习:
参考表
mysql> create table jfb(
-> id int(2) primary key auto_increment,
-> name char(10),
-> pay float(7,2)
-> )engine=innodb;insert into jfb(name,pay) values(‘bob’,20000),(‘lucy’,15000);
+——-+———-+—————–+
| id | name | pay |
+——-+———-+—————–+
| 1 | bob | 20000.00 |
| 2 | lucy | 15000.00 |
+——-+———-+—————–+外键表
mysql> create table xsb(
-> num int(2),
-> name char(10),
-> class char(9),
-> foreign key(num) references jfb(id)
-> on update cascade
-> on delete cascade
-> )engine=innodb;
#num字段参考jfb(id)insert into xsb values(1,’bob’,’nsd1709′),(2,’lucy’,’nsd1709′);
#将xsb写入数据
+———-+———-+—————-+
| num | name | class |
+———-+———–+—————+
| 1 | bob | nsd1709 |
| 2 | lucy | nsd1709 |
+———-+———-+—————-+insert into xsb values(3,’tom’,’nsd1709′);
#因为参考表jfb(id)没有3,所以无法创建insert into xsb values(2,’jerry’,’nsd1709′);
+———-+————+—————-+
| num | name | class |
+———-+————+—————-+
| 1 | bob | nsd1709 |
| 2 | lucy | nsd1709 |
| 2 | jerry | nsd1709 |
+———-+————+—————-+参考表jfb(id)只有两条数据,但是还是添加成功因为
参数 2 存在所以添加成功,但是参考表只有两条数据
为了避免这种情况我们要让 xsb(num) 也具有唯一性
在上面添加主键delete from xsb where name=’jerry’;
#删除重复数据alter table xsb add primary key(num);
#为 xsb(num) 设置主键jfb xfb
+——-+———-+—————–+ +———-+———-+—————-+
| id | name | pay | | num | name | class |
+——-+———-+—————–+ +———-+———–+—————+
| 1 | bob | 20000.00 | | 1 | bob | nsd1709 |
| 2 | lucy | 15000.00 | | 2 | lucy | nsd1709 |
+——-+———-+—————–+ +———-+———-+—————-+update jfb set id=8 where id=2;
#修改 jfb id=2 改为 id=8jfb xfb
+——-+———-+—————–+ +———-+———-+—————-+
| id | name | pay | | num | name | class |
+——-+———-+—————–+ +———-+———–+—————+
| 1 | bob | 20000.00 | | 1 | bob | nsd1709 |
| 8 | lucy | 15000.00 | | 8 | lucy | nsd1709 |
+——-+———-+—————–+ +———-+———-+—————-+delete from jfb where id=1;
#删除 jfb id 为1的数据jfb xfb
+——-+———-+—————–+ +———-+———-+—————-+
| id | name | pay | | num | name | class |
+——-+———-+—————–+ +———-+———–+—————+
| 8 | lucy | 15000.00 | | 8 | lucy | nsd1709 |
+——-+———-+—————–+ +———-+———-+—————-+delete from jfb;
error:被参考的表不能随便被删除的删除外键
show create table 表名
#外键名称自动生成。
alter table 表名 drop foreign key 外键名
#删除外键名字###########################################################################
存储引擎
MySQL 数据库服务软件自带的程序。
不同的存储引擎有不同的功能和数据存储方式
是处理表的处理器
表名.frm 存放数据库结构1)
show engines;
#查看数据库服务支持的存储引擎2)
存储引擎的特点
MyISAM:
表名.MYI 索引信息
表名.MYI 数据
表名.frm 表结构
功能:
支持表级锁:锁一张表
不支持事务 事务回滚InnoDB
表名.MYI 表结构
表名.idb 数据+索引信息
功能:
支持行级锁:只给当前被访问的行加锁
支持事务 事务回滚锁类型:读锁、 写锁
select insert delete update接收写操作的表适合使用 InnoDB 存储引擎
接收读操作的表适合使用 MyISAM 存储引擎锁粒度:表级锁 行级锁事务:一次数据访问从开始访问到访问结束的过程
事务回滚:一次数据访问过程中任意一步操作错误,都会恢复所有操作
事务特性:一致性 原子性 隔离性事务日志文件:记录InnoDB存储引擎的表执行过的操作。3)
在配置文件中写入 /etc/my.cnf
default_storage_engine=存储引擎名
#修改默认引擎alter table 表名 engine=存储引擎名
#修改表引擎create table 表名(。。。。)engine=innodb;
#设置表的存储引擎因当在表中没有存储数据时设置。###########################################################################################
MySQL 服务体系结构:(8个功能模块)
连接池
sql接口
分析器:分析命令语法
优化器:以最小消耗执行命令
查询缓存:存放曾经查找过的数据
存储引擎
文件系统:硬盘
管理工具:装包后提供的命令看了以上关于MySQL 存储引擎知识讲解,希望能给大家在实际运用中带来一定的帮助。本文由于篇幅有限,难免会有不足和需要补充的地方,如有需要更加专业的解答,可在官网联系我们的24小时售前售后,随时帮您解答问题的。
一、需求分析MySQL数据库一主两备,但是未在同一个分区,所谓分区是指数据存放在不同的存储上,目的是防止存储故障导致数据丢失。二、解决方案,数据迁移通过备库对数据进行迁移,不动主库,不影响业务。操作步骤如下:三、小结1、生产环境变更要走流程,开发云主机域名要合…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。