中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL 儲存引擎 MyISAM 和 InnoDB 配置

發布時間:2020-06-23 01:09:47 來源:網絡 閱讀:743 作者:HHHNDYD 欄目:MySQL數據庫

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。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宜丰县| 郴州市| 阿城市| 仁布县| 安国市| 香格里拉县| 虎林市| 元谋县| 诏安县| 二手房| 武威市| 文登市| 浑源县| 陵川县| 武功县| 镇平县| 琼中| 文成县| 荆州市| 婺源县| 田东县| 贺兰县| 林州市| 谢通门县| 凯里市| 定日县| 南岸区| 宜章县| 绵阳市| 江永县| 濉溪县| 景宁| 米泉市| 昌都县| 饶河县| 永胜县| 莆田市| 伊宁市| 巨野县| 灵寿县| 安岳县|