说GTID - 与GTID相关的4个基本函数和使用场景
admin
2023-04-16 00:01:29
0

4个基本函数


1. GTID_SUBSET(set1,set2) - 若在set1中的GTID,也在set2中,返回true,否则返回false(set1是set2的子集)。


[root@mysql.sock][(none)]> SELECT GTID_SUBSET('3E11FA47-71CA-11E1-9E33-C80AA9429562:23','3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57');

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

| GTID_SUBSET('3E11FA47-71CA-11E1-9E33-C80AA9429562:23','3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57') |

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

|                                                                                                   1 |

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

1 row in set (0.00 sec)


[root@mysql.sock][(none)]> SELECT GTID_SUBSET('3E11FA47-71CA-11E1-9E33-C80AA9429562:20-25','3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57');

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

| GTID_SUBSET('3E11FA47-71CA-11E1-9E33-C80AA9429562:20-25','3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57') |

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

|                                                                                                      0 |

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

1 row in set (0.00 sec)


2. GTID_SUBTRACT(set1,set2) - 返回在set1中,不在set2中的GTID集合(set1和set2的差集)。


[root@mysql.sock][(none)]> SELECT GTID_SUBTRACT('3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57','3E11FA47-71CA-11E1-9E33-C80AA9429562:20-25');

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

| GTID_SUBTRACT('3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57','3E11FA47-71CA-11E1-9E33-C80AA9429562:20-25') |

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

| 3e11fa47-71ca-11e1-9e33-c80aa9429562:26-57                                                               |

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

1 row in set (0.01 sec)


[root@mysql.sock][(none)]> SELECT GTID_SUBTRACT('3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57','3E11FA47-71CA-11E1-9E33-C80AA9429562:23-24');

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

| GTID_SUBTRACT('3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57','3E11FA47-71CA-11E1-9E33-C80AA9429562:23-24') |

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

| 3e11fa47-71ca-11e1-9e33-c80aa9429562:21-22:25-57                                                         |

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

1 row in set (0.00 sec)


3. WAIT_FOR_EXECUTED_GTID_SET(gtid_set[, timeout]) - 等待gtid_set执行完,即GTID_SUBSET(gtid_subset, @@GLOBAL.gtid_executed)成立。timeout是可选的,超时参数。函数返回0,代表成功;返回1,代表超时;返回其它值,代表出错。


[root@mysql.sock][(none)]> SELECT WAIT_FOR_EXECUTED_GTID_SET('c4e5d4a0-a9be-11e9-b444-080027f22add:1-5',5);

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

| WAIT_FOR_EXECUTED_GTID_SET('c4e5d4a0-a9be-11e9-b444-080027f22add:1-5',5) |

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

|                                                                        0 |

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

1 row in set (0.00 sec)


4. WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS(gtid_set[, timeout][,channel]) - 和WAIT_FOR_EXECUTED_GTID_SET()类似,多了channel参数。



使用场景


1. 检查slave节点上是否执行了master上的所有GTIDs。


在salve节点上执行,SELECT GTID_SUBSET(master_gtid_executed, slave_gtid_executed),若返回0,说明slave节点上还有GTIDs未执行。


在slave节点上执行,SELECT GTID_SUBTRACT(master_gtid_executed, slave_gtid_executed),若返回GTIDs,也说明slave节点上还有GTIDs未执行。

相关内容

热门资讯

今日重大发现“wepoker到... 家人们!今天小编来为大家解答wepoker透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪...
玩家最新攻略“新绍兴麻将到底是... 玩家最新攻略“新绍兴麻将到底是不是挂?”(确实真的有挂)您好,新绍兴麻将这个游戏其实有挂的,确实是有...
终于了解“微乐保皇开挂器?”(... 终于了解“微乐保皇开挂器?”(太坑了原来有挂)您好,微乐保皇这个游戏其实有挂的,确实是有挂的,需要了...
我来教教您“新上游炸/金/花到... 我来教教您“新上游炸/金/花到底是不是挂?”(太坑了原来有挂)您好,新上游炸/金/花这个游戏其实有挂...
玩家最新攻略“新西游开挂神器?... 网上科普关于“新西游有没有挂”话题很是火热,小编也是针对新西游作*弊开挂的方法以及开挂对应的知识点,...
终于懂了“永盈到底是不是挂?”... 网上科普关于“永盈有没有挂”话题很是火热,小编也是针对永盈作*弊开挂的方法以及开挂对应的知识点,寻找...
今日重磅消息“情怀莆仙怎么装挂... 今日重磅消息“情怀莆仙怎么装挂?”(太坑了果然有挂)您好,情怀莆仙这个游戏其实有挂的,确实是有挂的,...
【第一财经】“乐禧棋牌有挂吗?... 网上科普关于“乐禧棋牌有没有挂”话题很是火热,小编也是针对乐禧棋牌作*弊开挂的方法以及开挂对应的知识...
最新引进“欢聚水鱼虎步龙行可以... 家人们!今天小编来为大家解答欢聚水鱼虎步龙行透视挂怎么安装这个问题咨询软件客服徽9784099的挂在...
今日重磅消息“天府棋牌开挂器?... 您好:天府棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...