91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

說GTID - GTID-based復制中的限制

發布時間:2020-05-22 11:40:53 來源:網絡 閱讀:539 作者:coveringindex 欄目:MySQL數據庫
  • 同一個事務(語句)中,不能同時涉及事務和非事務數據表的變更,這會導致一個事務對應多個GTID,違反了事務與GTID的一對一對應原則。


[root@mysql.sock][db1]> show create table t2 \G

*************************** 1. row ***************************

? ? ? ?Table: t2

Create Table: CREATE TABLE `t2` (

? `id` int(11) NOT NULL AUTO_INCREMENT,

? PRIMARY KEY (`id`)

) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4

1 row in set (0.00 sec)


[root@mysql.sock][db1]> start transaction;

Query OK, 0 rows affected (0.00 sec)


[root@mysql.sock][db1]> insert into t1 select null;

Query OK, 1 row affected (0.00 sec)

Records: 1? Duplicates: 0? Warnings: 0


[root@mysql.sock][db1]> insert into t2 select null;

ERROR 1785 (HY000): Statement violates GTID consistency: Updates to non-transactional tables can only be done in either autocommitted statements or single-statement transactions, and never in the same statement as updates to transactional tables.

[root@mysql.sock][db1]> commit;

Query OK, 0 rows affected (0.01 sec)



  • 不能使用CREATE TABLE ... SELECT語句。


[root@mysql.sock][db1]> create table t2 select * from t2;

ERROR 1786 (HY000): Statement violates GTID consistency: CREATE TABLE ... SELECT.




  • 在事務,存儲過程,函數和觸發器中,不能使用CREATE TEMPORARY TABLE,和DROP TEMPORARY TABLE語句。


[root@mysql.sock][db1]> start transaction;

Query OK, 0 rows affected (0.00 sec)


[root@mysql.sock][db1]> create temporary table t4 (id int auto_increment primary key);

ERROR 1787 (HY000): Statement violates GTID consistency: CREATE TEMPORARY TABLE and DROP TEMPORARY TABLE can only be executed outside transactional context.? These statements are also not allowed in a function or trigger because functions and triggers are also considered to be multi-statement transactions.

[root@mysql.sock][db1]> rollback;

Query OK, 0 rows affected (0.00 sec)


[root@mysql.sock][db1]> create temporary table t4 (id int auto_increment primary key);

Query OK, 0 rows affected (0.01 sec)


[root@mysql.sock][db1]> desc t4;

+-------+---------+------+-----+---------+----------------+

| Field | Type? ? | Null | Key | Default | Extra? ? ? ? ? |

+-------+---------+------+-----+---------+----------------+

| id? ? | int(11) | NO? ?| PRI | NULL? ? | auto_increment |

+-------+---------+------+-----+---------+----------------+

1 row in set (0.00 sec)


[root@mysql.sock][db1]> drop temporary table t4;

Query OK, 0 rows affected (0.00 sec)


[root@mysql.sock][db1]> desc t4;

ERROR 1146 (42S02): Table 'db1.t4' doesn't exist



  • 開啟--enforce-gtid-consistency參數,阻止執行違反GTID-based復制原則的語句。



  • 跳過事務的執行,參數sql_slave_skip_counter不再起作用,需要使用如下注入空事務的方式跳過。


SET GTID_NEXT='aaa-bbb-ccc-ddd:N';


BEGIN;

COMMIT;


SET GTID_NEXT='AUTOMATIC';



CHANGE MASTER TO語句中的IGNORE_SERVER_IDS不在起作用,已經回放過的事務會自動跳過。



  • 在開啟GTID的實例上使用mysqldump導出數據時,在備份文件中會設置@@SESSION.SQL_LOG_BIN= 0,當使用該備份文件向目標實例導入數據時,不記錄二進制日志。



  • 在開啟GTID的實例上使用mysql_upgrade原地升級MySQL版本時,要不寫二進制日志(這也是mysql_upgrade的默認行為,沒開啟--write-binlog)。


向AI問一下細節

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

AI

娱乐| 湖州市| 宾川县| 贵州省| 通州区| 星座| 茂名市| 东山县| 车险| 长汀县| 长治市| 信丰县| 正定县| 柘荣县| 平昌县| 彭水| 江陵县| 乌兰浩特市| 正安县| 湟源县| 达拉特旗| 邛崃市| 民乐县| 托克逊县| 襄汾县| 沭阳县| 商丘市| 安化县| 天门市| 惠东县| 利辛县| 崇明县| 宽甸| 鹤峰县| 桦川县| 克拉玛依市| 清水河县| 甘谷县| 荆州市| 宜兰县| 辰溪县|