MySQL ステートメントベースレプリケーションが使えないケース
スポンサーリンク
ステートメントベースレプリケーションが使えないケース
すべての UPDATE (アップデート) ステートメントがレプリケーションすることができるわけではありません。
非決定な振る舞いを(たとえば、SQLステートメントでランダム関数を利用するときです)するときに、ステートメントベースレプリケーションを使ってレプリケーションすることは困難です。非決定なユーザ定義関数(UDF: user-defined function)を使うステートメントは、ステートメントベースレプリケーションを使ってレプリケーションすることは不可能です。このような場合には、ユーザ定義関数(UDF)によって返される結果を行ベースレプリケーションでレプリケーションしましょう。
下記の関数を使うステートメントは、レプリケーションすることができません。
INSERT ... SELECTは、行ベースレプリケーションのときよりも、たくさんの行レベルロックを必要とします。
テーブルスキャン(WHERE句でインデックスが使われない場合)が必要なUPDATE ステートメントは、行ベースレプリケーションよりもたくさんロックしなければなりません。
InnoDBにおいて、 AUTO_INCREMENT を使う INSERT ステートメントは、 他の INSERT ステートメントと衝突しないためにブロックします。
complex queries
複合クエリは、行がアップデートや挿入される前に、スレーブでステートメントが評価や実行されなければなりません。行ベースレプリケーションでは、スレーブでは、変更を適用するステートメントのみが実行され、完全なクエリではありません。
組み込み関数(stored function: ストアドファンクション)(ストアドプロシージャではありません)は、同じNOW()値として実行されるでしょう。
MySQL関連記事
[2008-08-04-1] MySQL 行ベースバイナリロギング Row-based binary logging
[2008-08-03-2] MySQL 5.1に追加された新機能
[2008-08-03-1] MySQL テーブルにカラムを追加する方法
[2008-08-02-2] Windowsでコマンドでmysqldの起動・停止する方法
[2008-08-02-1] WindowsでApacheとPHPとMySQLを動かす
[2008-08-01-2] MySQL データベースからデータベースとテーブルを作成する文を方法
[2008-08-01-1] MySQL テーブルのcreate文をテーブルから生成する方法
[2008-07-27-2] MySQLのデータファイルを移動する方法
[2008-07-27-1] MySQLのエラー MySQL General error 1114 The table foo is full
[2008-07-22-2] 気付けばレプリケーションが止まっていたMySQL
すべての UPDATE (アップデート) ステートメントがレプリケーションすることができるわけではありません。
非決定な振る舞いを(たとえば、SQLステートメントでランダム関数を利用するときです)するときに、ステートメントベースレプリケーションを使ってレプリケーションすることは困難です。非決定なユーザ定義関数(UDF: user-defined function)を使うステートメントは、ステートメントベースレプリケーションを使ってレプリケーションすることは不可能です。このような場合には、ユーザ定義関数(UDF)によって返される結果を行ベースレプリケーションでレプリケーションしましょう。
下記の関数を使うステートメントは、レプリケーションすることができません。
- LOAD_FILE()
- UUID(), UUID_SHORT()
- USER()
- FOUND_ROWS()
- SYSDATE()
INSERT ... SELECTは、行ベースレプリケーションのときよりも、たくさんの行レベルロックを必要とします。
テーブルスキャン(WHERE句でインデックスが使われない場合)が必要なUPDATE ステートメントは、行ベースレプリケーションよりもたくさんロックしなければなりません。
InnoDBにおいて、 AUTO_INCREMENT を使う INSERT ステートメントは、 他の INSERT ステートメントと衝突しないためにブロックします。
complex queries
複合クエリは、行がアップデートや挿入される前に、スレーブでステートメントが評価や実行されなければなりません。行ベースレプリケーションでは、スレーブでは、変更を適用するステートメントのみが実行され、完全なクエリではありません。
組み込み関数(stored function: ストアドファンクション)(ストアドプロシージャではありません)は、同じNOW()値として実行されるでしょう。
MySQL関連記事
[2008-08-04-1] MySQL 行ベースバイナリロギング Row-based binary logging
[2008-08-03-2] MySQL 5.1に追加された新機能
[2008-08-03-1] MySQL テーブルにカラムを追加する方法
[2008-08-02-2] Windowsでコマンドでmysqldの起動・停止する方法
[2008-08-02-1] WindowsでApacheとPHPとMySQLを動かす
[2008-08-01-2] MySQL データベースからデータベースとテーブルを作成する文を方法
[2008-08-01-1] MySQL テーブルのcreate文をテーブルから生成する方法
[2008-07-27-2] MySQLのデータファイルを移動する方法
[2008-07-27-1] MySQLのエラー MySQL General error 1114 The table foo is full
[2008-07-22-2] 気付けばレプリケーションが止まっていたMySQL
参照しているページ (サイト内): [2008-08-10-2] [2008-08-10-1] [2008-08-09-2] [2008-08-08-2] [2008-08-08-1] [2008-08-07-2] [2008-08-07-1] [2008-08-05-2] [2008-08-05-1]
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12