iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL(7)-mysql索引和存储引擎
  • 685
分享到

MySQL(7)-mysql索引和存储引擎

2024-04-02 19:04:59 685人浏览 薄情痞子
摘要

     本篇博客讲的是Mysql的索引的功能和使用 , 以及存储引擎的基本简介 一. mysql索引索引的简介和作用索引在Mysql中叫做"键" , 是存储引擎用于快速找到记录的一种数据结构 . 索引对良

     本篇博客讲的是Mysql索引的功能和使用 , 以及存储引擎的基本简介


 一. mysql索引


索引的简介和作用


索引在Mysql中叫做"键" , 是存储引擎用于快速找到记录的一种数据结构 . 索引对良好的性能非常关键 , 尤其是当表中的数据量越来越大时 , 索引对于性能的影响愈来愈发重要 .

作用 : 通过一定的算法将数据库中的记录按一定的规律进行分组 , 这样查信息时可以缩小数据的搜索范围 , 从而提高溜了查询效率

生活实例来说 , 索引就好像书的目录 , 清单上的列表 ; 好比人去吃火锅 , 当菜单拿到客户手上 , 客户可以根据菜单上的分类(海鲜 , 蔬菜类 , 肉类 , 饮料类等) , 根据自己的口味能第一时间找到自己想吃的菜 .


索引的分类


索引可分为 : 普通索引 , 唯一索引 , 全文索引 , 单列索引 , 多列索引 , 空间索引


语法格式:


CREATE TABLE 表名 (
       字段名1  数据类型 [完整性约束条件…],
       字段名2  数据类型 [完整性约束条件…],
       [UNIQUE | FULLTEXT | SPATIAL ]   INDEX | KEY
[索引名]  (字段名[(长度)]  [ASC |DESC])
);


示例 : 

创建一个INDEX普通索引

CREATE TABLE dept(
     dept_id INT,
     dept_name VARCHAR(30) ,
     comment VARCHAR(50),
     index  (dept_name)              # 将表中的dept_name字段指定为普通索引字段
);

MySQL(7)-mysql索引和存储引擎


创建一个UNIQUE唯一索引:

CREATE TABLE dept2 (
     dept_id INT,
     dept_name VARCHAR(30) ,
     comment VARCHAR(50),
     UNIQUE INDEX  (dept_name)
);

相比普通索引来说 , 比上面的索引选项多了一个unique选项


创建一个全文索引;

CREATE TABLE dept3 (
     dept_id INT,
     dept_name VARCHAR(30) ,
     comment VARCHAR(50),
     log text,
FULLTEXT INDEX  (log)
)engine=myisam;

: 只有MYISAM存储引擎支持全文索引,innodb存储引擎不支持全文索引

MySQL(7)-mysql索引和存储引擎


创建多列索引

CREATE TABLE dept13 (
     dept_id INT,
     dept_name VARCHAR(30) ,
     comment VARCHAR(50),
INDEX  (dept_name, comment)
);

相比普通索引来说 , 就是将多个字段设置为索引


对已存在的表创建索引


语法一:

CREATE  [UNIQUE | FULLTEXT | SPATIAL ]  INDEX  索引名  ON 表名 (字段名[(长度)]  [ASC |DESC]) ;

创建普通索引示例:此方法要指定索引名称
CREATE INDEX index_dept_name ON dept6  (dept_name);

创建唯一索引示例:
CREATE UNIQUE INDEX index_dept_name ON dept6 (dept_name);

创建全文索引示例:
CREATE FULLTEXT INDEX index_dept_name ON dept6 (dept_name);

创建多列索引示例:
CREATE INDEX index_dept_name_ comment ON dept6 (dept_name, comment);


语法二:

ALTER TABLE在已存在的表上创建索引:
ALTER  TABLE  表名  ADD  [UNIQUE | FULLTEXT | SPATIAL ] INDEX
     索引名 (字段名[(长度)]  [ASC |DESC]) ;


管理索引:


查看索引: show  create  table  表名\G

测试索引: explain  select  *  from  表名  where  字段名='xx';

删除索引: drop  index  索引名  on  表名


索引检测实例:


要求 : 创建一个school的数据库 , 创建一张t2表 , 用存储过程脚本t2表插入1000W条数据 , 然后查询t2数据看看花费了多长时间 ; 再为t2创建一个索引 , 再次查看数据看看所花费的时间 


准备:

           create  database  school                                          #创建school数据库

           create table school.t2(id int,name varchar(30));    #创建一张t2表 , 里面记录id号和名字


定义一个插入1000W条数据的存储过程 , 并调用此存储过程

mysql> delimiter $$                            //设置命令的界定符(也称为结束符)
mysql> create procedure autoinsert1()          //创建autoinsert1这个存储过程(类似于shell脚本)
    -> BEGIN
    -> declare i int default 1;
    -> while(i<100000)do
    -> insert into school.t2 values(i,'ccc');
    -> set i=i+1;
    -> end while;
    -> END$$
mysql> delimiter ;
       call  atuoinsert1();

MySQL(7)-mysql索引和存储引擎


分两次查询数据 , 对比所花的时间(实验中途插入1000W条数据花了33分钟 , 插100W估计就能看出效果了):

MySQL(7)-mysql索引和存储引擎


 从上述实验可以看到 , 在一个存放1000W的表中 , 查询一条数据跟创建索引后查询一条数据相差了4S的时间 , 随着数据更大 , 查询时间也会不断增大 , 所以足以证明 , 创建索引会大大提高MySQL的查询工作效率!!!




二. MySQL存储引擎介绍


了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)

oracleSQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。而MySql数据库提供了多种存储引擎。用户可以根据不同的需求为数据表选择不同的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。


1. 查看存储引擎
SHOW ENGINES;
SHOW ENGINES\G               查看MYSQL支持的存储引擎
SHOW VARIABLES LIKE 'storage_engine%';    查看当前的存储引擎
SHOW VARIABLES LIKE 'auto_inc%';       查看自增长的设置状态
show global variables   like  '%connet%'   查看connet环境变量设置
mysql> show variables\G          查看所有的环境变量
show variables当前的会话
show global variables\G全局


2. 选择存储引擎
方法1.
mysql> create table innodb1(
-> id int
-> )engine=innodb;
mysql> show create table innodb1;

create tables test100(id init)engine=inodb;

方法2.
/etc/my.cnf
[mysqld]     在此行下添加下面的一行内容
default-storage-engine=INNODB



MySQL常用的存储引擎


MyISAM存储引擎
由于该存储引擎不支持事务、也不支持外键,所以访问速度较快。因此当对事务完整性没有要求并以访问为主的应用适合使用该存储引擎。

InnoDB存储引擎(MYSQL默认用此存储引擎)
由于该存储引擎在事务上具有优势,即支持具有提交、回滚及崩溃恢复能力等事务特性,所以比MyISAM存储引擎占用更多的磁盘空间。
因此当需要频繁的更新、删除操作,同时还对事务的完整性要求较高,需要实现并发控制,建议选择。

MEMORY
MEMORY存储引擎存储数据的位置是内存,因此访问速度最快,但是安全上没有保障。适合于需要快速的访问或临时表。

BLACKHOLE
黑洞存储引擎,可以应用于主备复制中的分发主库。
使用BLACKHOLE存储引擎的表不存储任何数据,但如果mysql启用了二进制日志,SQL语句被写入日志(并被复制到从服务器)。这样使用BLACKHOLE存储引擎的mysqld可以作为主从复制中的中继重复器或在其上面添加过滤器机制。




您可能感兴趣的文档:

--结束END--

本文标题: MySQL(7)-mysql索引和存储引擎

本文链接: https://www.lsjlt.com/news/47887.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • oracle怎么查询当前用户所有的表
    要查询当前用户拥有的所有表,可以使用以下 sql 命令:select * from user_tables; 如何查询当前用户拥有的所有表 要查询当前用户拥有的所有表,可以使...
    99+
    2024-05-14
    oracle
  • oracle怎么备份表中数据
    oracle 表数据备份的方法包括:导出数据 (exp):将表数据导出到外部文件。导入数据 (imp):将导出文件中的数据导入表中。用户管理的备份 (umr):允许用户控制备份和恢复过程...
    99+
    2024-05-14
    oracle
  • oracle怎么做到数据实时备份
    oracle 实时备份通过持续保持数据库和事务日志的副本来实现数据保护,提供快速恢复。实现机制主要包括归档重做日志和 asm 卷管理系统。它最小化数据丢失、加快恢复时间、消除手动备份任务...
    99+
    2024-05-14
    oracle 数据丢失
  • oracle怎么查询所有的表空间
    要查询 oracle 中的所有表空间,可以使用 sql 语句 "select tablespace_name from dba_tablespaces",其中 dba_tabl...
    99+
    2024-05-14
    oracle
  • oracle怎么创建新用户并赋予权限设置
    答案:要创建 oracle 新用户,请执行以下步骤:以具有 create user 权限的用户身份登录;在 sql*plus 窗口中输入 create user identified ...
    99+
    2024-05-14
    oracle
  • oracle怎么建立新用户
    在 oracle 数据库中创建用户的方法:使用 sql*plus 连接数据库;使用 create user 语法创建新用户;根据用户需要授予权限;注销并重新登录以使更改生效。 如何在 ...
    99+
    2024-05-14
    oracle
  • oracle怎么创建新用户并赋予权限密码
    本教程详细介绍了如何使用 oracle 创建一个新用户并授予其权限:创建新用户并设置密码。授予对特定表的读写权限。授予创建序列的权限。根据需要授予其他权限。 如何使用 Oracle 创...
    99+
    2024-05-14
    oracle
  • oracle怎么查询时间段内的数据记录表
    在 oracle 数据库中查询指定时间段内的数据记录表,可以使用 between 操作符,用于比较日期或时间的范围。语法:select * from table_name wh...
    99+
    2024-05-14
    oracle
  • oracle怎么查看表的分区
    问题:如何查看 oracle 表的分区?步骤:查询数据字典视图 all_tab_partitions,指定表名。结果显示分区名称、上边界值和下边界值。 如何查看 Oracle 表的分区...
    99+
    2024-05-14
    oracle
  • oracle怎么导入dump文件
    要导入 dump 文件,请先停止 oracle 服务,然后使用 impdp 命令。步骤包括:停止 oracle 数据库服务。导航到 oracle 数据泵工具目录。使用 impdp 命令导...
    99+
    2024-05-14
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作