iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >InnoDB有什么用
  • 961
分享到

InnoDB有什么用

2024-04-02 19:04:59 961人浏览 泡泡鱼
摘要

小编给大家分享一下InnoDB有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!InnoDB是一个通用的高性能、高可靠性的存

小编给大家分享一下InnoDB有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

InnoDB是一个通用的高性能、高可靠性的存储引擎。从Mysql 5.5开始,是mysql默认的存储引擎

InnoDB表关键特性

1.   DML操作遵循ACID原则,事务通过commit, rollback, and crash-recovery等功能来保护用户数据

2.   支持行级,类似oracle方式一致性读来提高多用户并发和性能

3.   InnoDB表按照主键的顺序组织存放在磁盘上(索引组织表),优化基于主键的查询

4.   支持外键约束

5.   可以与其他存储引擎的表混合使用。如join查询等

6.   当处理大量数据时,innoDB能高效利用CPU

 

InnoDB引擎特点

InnoDB有什么用

a.支持地理空间索引 从Mysql 5.7.5开始

b.Innodb不支持hash索引,但是innodb内部使用hash索引实现自适应哈希功能

c.支持全文索引 从MySQL 5.6.4开始

d.Barracuda文件格式下支持压缩表

e、f、g.在server层实现 数据加密、主从复制、备份和point-in-time恢复

InnoDB在内存中使用buffer pool来缓存数据和索引。

默认,innodb_file_per_table是开启的,每个表和与其相关的索引存储在单独的一个文件中;

当innodb_file_per_table关闭时,所有innodb表和索引都存储在单个系统表空间(可能包含几个文件或者分区)。

从MySQL 5.7.6开始,innodb表可以存储在普通表空间,多个表共享一个表空间存储数据

Innodb表可以处理大量数据,即使在文件大小限制为2GB的OS下

 

Innodb作为默认存储引擎

MySQL 5.7 innodb是默认的存储引擎。Innodb在mysql中是事务安全的存储引擎,通过commit, rollback, and crash-recovery功能来保护用户数据。Innodb 行级锁(没有锁升级的问题),并且类似oracle的一致性读来提高多用户并发性。Innodb表是索引组织表,以主键的顺序来组织存放数据从而减少io。支持外键约束。

 

Innodb表的好处

1.       Crash recovery

2.       Buffer pool缓冲访问的数据和索引,热点数据直接在内存中处理,此缓存使用于多种类型的信息,从而加速了处理。

3.       外键约束

4.       如果磁盘或者内存中的数据损坏了,在使用它之前可以使用checksum机制来修复数据

5.       索引组织表的特性,通过主键where ,order by,group by和join查询是快速的

6.       Change buffering特性,自动优化DML操作。Innodb表不仅允许并行的读写,它还缓存修改的数据来减少IO

7.       自适应哈希

8.       压缩表和与其关联的索引

9.       在线删除和创建索引

10.   可以快速的Truncate一个file_per_table,并且释放的空间,操作系统可重用。而不是file_per_table关闭状态下,是存放在系统表空间,释放的空间,仅仅innodb可以重用

11.   对于BLOB和long text的存储效率更高,在动态行模式下

12.   可以通过INFORMATION_SCHEMA监控内部工作

13.    可以通过Performance 下面的表来查看性能相关信息

 

Innodb表最佳实践

一些使用innodb表的建议:

1.       为每张表定义一个主键:使用最常查询的列(或多列),若没有明显的主键,使用一个自增长的值作为主键

2.       关闭autocommit:对性能的上限最大每秒提交上百次(由存储设备的IO性能限制)

3.       使用START TRANSACTION 和COMMIT来控制事务提交的粒度

4.       不要使用LOCK TABLES语句,innodb在不牺牲可靠性和高性能的同时能处理多个会话对同一个表的读和写。为了得到一些行独占访问,可以使用SELECT ... FOR UPDATE来锁定期望的行

5.       开启innodb_file_per_table选项将各个表的数据和索引存放在单独的文件中,而不是放在一个巨大的system表空间。并且便于一些功能的使用,如:表压缩、快速truncate等。

innodb_file_per_table 从MySQL 5.6.6开始默认是开启的

6.       评估你的数据和访问模式是否适用于innodb表压缩特性(在create table语句指定(ROW_FORMAT=COMPRESSED)),表压缩可以提高IO性能

7.       运行时指定--sql_mode=NO_ENGINE_SUBSTITUTION选项来防止需要的存储引擎被禁用或未编译,自动替换存储引擎

关闭InnoDB引擎

Oracle推荐innoDB为首选,从MySQL 5.5开始,其为默认存储引擎。

从MySQL 5.7.5开始,--skip-innodb (--innodb=OFF, --disable-innodb)选项被弃用,如果使用此选项,将会得到一个警告。在未来的MySQL版本中此选项将被删除。

而在5.7.5之前,如果你不想使用innodb表,则通过如下步骤来关闭:

1.       启动的时候指定--innodb=OFF 或者--skip-innodb来关闭innodb引擎

2.       因为innodb是默认引擎,所以要想关闭其,必须使用--default-storage-engine 和--default-tmp-storage-engine来设置默认的其他引擎来为永久和临时表引擎

3.       为了防止当查询innodb相关information_schema表时数据库crash,需要禁用其相关表。在my.cnf位置文件中[mysqld]部分指定如下内容:

loose-innodb-trx=0
loose-innodb-locks=0
loose-innodb-lock-waits=0
loose-innodb-cmp=0
loose-innodb-cmp-per-index=0
loose-innodb-cmp-per-index-reset=0
loose-innodb-cmp-reset=0
loose-innodb-cmpmem=0
loose-innodb-cmpmem-reset=0
loose-innodb-buffer-page=0
loose-innodb-buffer-page-lru=0
loose-innodb-buffer-pool-stats=0
loose-innodb-metrics=0
loose-innodb-ft-default-stopWord=0
loose-innodb-ft-inserted=0
loose-innodb-ft-deleted=0
loose-innodb-ft-being-deleted=0
loose-innodb-ft-config=0
loose-innodb-ft-index-cache=0
loose-innodb-ft-index-table=0
loose-innodb-sys-tables=0
loose-innodb-sys-tablestats=0
loose-innodb-sys-indexes=0
loose-innodb-sys-columns=0
loose-innodb-sys-fields=0
loose-innodb-sys-foreign=0
loose-innodb-sys-foreign-cols=0

以上是“InnoDB有什么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: InnoDB有什么用

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

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

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

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

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

  • 微信公众号

  • 商务合作