MySQL 儲存引擎 MyISAM 和 InnoDB 配置
阿新 • • 發佈:2018-07-05
abc ports duplicate 資源 rec 批量 top 更新 null MySQL 存儲引擎 MyISAM 和 InnoDB 配置
MyISAM 和 InnoDB 最大特點:
MyISAM :
① 不支持事務 。
② 表級鎖定形式 ,數據在更新時鎖定整個表 。
③ 不支持外鍵約束 ,只支持全文索引 。
④ 數據庫在讀取過程中相互阻塞 。
⑤ 數據單獨寫入或讀取 , 速度較快且占用資源相對要少 。
InnoDB:
① 支持事務 。
② 行級鎖定 ,但是全表掃描仍然會是表級鎖定 。
③ 支持分區、表空間 ,類似Oracle 數據庫 。
④ 讀寫阻塞與事務隔離級別相關 。
⑤ 表與主鍵以簇的方式儲存 。
⑥ 具有非常高效的緩存特性 ,能緩存引索 ,也能緩存數據 。
如何查看存儲引擎:
查看 MySQL 默認存儲引擎 :
mysql> show engines; +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | Engine | Support | Comment | Transactions | XA | Savepoints | +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES
查看 MySQL 支持的引擎以及默認存儲引擎 。
查看表正在使用的存儲引擎 :
方法一:
show table status from 庫名 where name=‘表名‘;
mysql> show table status from jdy where name=‘test‘; +------+--------+---------+------------+------+ | Name | Engine | Version | Row_format | Rows | +------+-------------+-----------------+--------------+ | test | InnoDB | 10 | Dynamic | 0 | # 表的存儲引擎 InnoDB
方法二:
show create table 表名;
mysql> use jdy; # 進入查看表的數據庫
Database changed
mysql> show create table test;
+-------+---------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+---------------------------------------------------------------------------------------------------------------------------+
| test | CREATE TABLE "test" (
"name" varchar(10) DEFAULT NULL,
"id" int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 | # 表的存儲引擎 InnoDB
如何修改存儲引擎:
-
方法一 :
mysql> use jdy; # 進入查看表的數據庫
Database changed
mysql> show create table test;
+-------+---------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+---------------------------------------------------------------------------------------------------------------------------+
| test | CREATE TABLE "test" (
"name" varchar(10) DEFAULT NULL,
"id" int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 | # 表的存儲引擎 InnoDB
#命令: alter table 表名 engine=引擎;
mysql> alter table test engine=MyISAM; #修改表的存儲引擎為 MyISAM
Query OK, 0 rows affected (0.39 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> show create table test;
+-------+---------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+---------------------------------------------------------------------------------------------------------------------------+
| test | CREATE TABLE "test" (
"name" varchar(10) DEFAULT NULL,
"id" int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8 | #修改成功
方法二 :
-
修改 MySQL 的配置文件 my.cnf ,指定默認存儲引擎
vim /etc/my.cnf
[mysqld]
default-storage-engine=MyISAM #添加指定默認存儲引擎
mysql> create table test01 (id int ); #創建表
Query OK, 0 rows affected (0.00 sec)
mysql> show create table test01;
+--------+------------------------------------------------------------------------------------------+
| Table | Create Table |
+--------+------------------------------------------------------------------------------------------+
| test01 | CREATE TABLE "test01" (
"id" int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8 | #創建的新表默認 MyISAM
設置默認存儲引擎 ,創建的新表將使用 MyISAM 存儲引擎 。
方法三 :
-
創建表的時候指定存儲引擎
mysql> create table test02 (id int ) engine=InnoDB;
Query OK, 0 rows affected (0.35 sec)
mysql> show create table test02;
+--------+------------------------------------------------------------------------------------------+
| Table | Create Table |
+--------+------------------------------------------------------------------------------------------+
| test02 | CREATE TABLE "test02" (
"id" int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 | #新表存儲引擎是 InnoDB
方法四:
-
使用mysql_convert_table_format 命令批量轉換
[root@localhost ~]#mysql_convert_table_format --host=localhost --user=root --password=abc123 --socket=/tmp/mysql.scok --engine=InnoDB jdy test01 test02
執行會報錯 ,需要安裝操作模塊
yum install perl perl-DBD-MySQL -y
無法轉換InnoDB引擎 ,mysql_convert_table_forma命令bug,需要修改命令腳本。
vim /usr/local/mysql/bin/mysql_convert_table_format #修改命令腳本 $opt_help=$opt_version=$opt_verbose=$opt_force=0; $opt_user=$opt_database=$opt_password=undef; $opt_host="localhost"; $opt_socket=""; $opt_engine="MYISAM"; $opt_port=0; $exit_status=0; GetOptions( "e|engine|type=s" => \$opt_type, #把type修改成engine "f|force" => \$opt_force, "help|?" => \$opt_help, "h|host=s" => \$opt_host, "p|password=s" => \$opt_password, "u|user=s" => \$opt_user, "v|verbose" => \$opt_verbose, "V|version" => \$opt_version, "S|socket=s" => \$opt_socket, "P|port=i" => \$opt_port ) || usage(0);
ps: 第四種方法只適合MySQL 5.5版本 。MySQL 5.5 默認存儲引擎MyISAM 5.7 默認存儲引擎 InnoDB。
MySQL 儲存引擎 MyISAM 和 InnoDB 配置