MySQL 8.0.3 RCがリリースされようとしています。変更点を見てみましょう。

MySQL 8.0.3 RCがリリースされようとしています。変更点を見てみましょう。

MySQL 8.0.3がリリースされます。新機能を見てみましょう

MySQL 8.0.3 は RC バージョンをリリースしようとしており、これはバージョン 8.0 が GA に近づいていることを意味します。

バージョン 8.0.3 の重要な新機能と変更点は次のとおりです。

1. クエリキャッシュを直接廃止する(入り口を閉じるだけです。ソースコードを自分でコンパイルすれば、再度有効にすることができます)

2. クエリ オプティマイザーは、次のような SET_VAR HINT 構文を使用して、特定のセッション レベルのオプションを SQL で直接変更することをサポートしています。

- SELECT /*+ SET_VAR (sort_buffer_size = 16M) */ name FROM people ORDER BY name;

- INSERT /*+ SET_VAR (foreign_key_checks=OFF) */ INTO t2 VALUES (2);

(この機能は非常に実用的です。別の SQL を記述したり、他の人への影響を心配したりすることなく、SQL で直接変更できます)

3. クエリ オプティマイザーは、実行プランの構築を容易にするために、各列の統計結果のヒストグラムを column_statistics データ ディクショナリに保存できるようになりました。このヒストグラムを使用すると、列を定数と比較できます。

4. 実行プランの構築時に非表示のインデックスを考慮するかどうかを制御するために、新しいフラグ use_invisible_indexes がクエリ オプティマイザーに追加されました。

5. InnoDB はバックアップ ロックを追加します。以前は、InnoDB テーブルのオンライン ホット バックアップ中に DML が同時に実行されると、InnoDB ファイルのスナップショットが不整合になる可能性がありました。このバックアップ ロックを使用すると、この問題を心配する必要がなくなります。バックアップ ロックの使用方法は、LOCK INSTANCE FOR BACKUP、UNLO​​CK INSTANCE であり、BACKUP_ADMIN 権限が必要です。

6. InnoDB はテーブル DDL のアトミック性をサポートするようになりました。つまり、InnoDB テーブル上の DDL はトランザクションの整合性も実現でき、失敗した場合はロールバックするか、正常にコミットするかのいずれかが可能になるため、DDL の部分的な成功の問題は発生しません。さらに、クラッシュセーフ機能もサポートしています (この機能は素晴らしいです)

7. グループ レプリケーション (GR) が遅く初期化された場合、つまりシングル プライマリ モードの場合、非同期レプリケーション チャネルを介してセカンダリ ノードにデータが書き込まれる可能性があります。これは、グループ レプリケーション プラグインが正常に初期化されたときには許可されません (バグ #26314756、これは内部バグ ID であり、私たちには表示されません。気にしないでください。ただし、万能の github もあり、関連する説明もここで確認できます。https://github.com/mysql/mysql-server/commit/acbf1d13ecd1d89557f8ca62116f06e8633dc90d を参照してください)。

8. システム ライブラリ INFORMATION_SCHEMA の FILES、PARTITIONS、REFERENTIAL_CONSTRAINTS などのいくつかのビューが再実装されました (これはあまり具体的ではありませんが、すべての DDL が InnoDB に配置され、FRM ファイルが DDL 情報の保存に使用されなくなったという事実に関連している可能性があります)

9. 外部キー制約ロック機能の変更により、外部キー制約を含む親テーブルの列名変更機能が一時的に無効になります(数回のマイナーバージョンアップ後には正常に使用できるようになる見込みです)

10. InnoDB 一般テーブルスペースの新しい名前変更構文: ALTER TABLESPACE ... RENAME TO (MySQL DBA として、一般テーブルスペースを使用する人はほとんどいないようです。Oracle DBA から切り替えた後、より慣れているのかもしれません)

11. MySQLレプリケーションのスレーブノードで、log_slave_updatesオプションのデフォルト値をONに変更します(これも非常に実用的で、スレーブをリレーノードとして直接使用するのに便利です)

12. オプション sql_log_bin のグローバル スコープがセッション スコープに変更されました。つまり、このオプションを変更すると、このセッションにのみ影響し、グローバル スコープには影響しなくなります (このオプションは通常、セッション レベルで使用されます)。

13. オプション max_allowed_pa​​cket のデフォルト値が 4M から 64M に増加されました (より現実的になったようです)

14. オプションevent_schedulerのデフォルト値をOFFからONに変更し、イベントスケジューラ機能がデフォルトで有効になるようにしました(イベント機能は非常に優れていると思いますが、イベントを使用する人は少ないようです)

15. オプション max_error_count のデフォルト値が 64 から 1024 に増加されました (そうは思えません)

16. 最後に、utf8mb4 文字セットにロシア語のチェックサムが追加されました (2 つの新しい照合セット: utf8mb4_ru_0900_ai_ci と utf8mb4_ru_0900_as_cs)

8.0.3のリリースを楽しみにしましょう!

以下もご興味があるかもしれません:
  • MySQL Community Server 8.0.12 のインストールと設定方法のグラフィックチュートリアル
  • MySQL Community Server 8.0.11 のインストールと設定方法のグラフィックチュートリアル
  • Ubuntu Server 16.04 MySQL 8.0 のインストールと設定のグラフィックチュートリアル
  • MySQL 8.0.2 オフラインインストールと設定方法のグラフィックチュートリアル
  • MySQL 8.0.12 のインストールと設定方法のグラフィックチュートリアル
  • mysql インストーラ コミュニティ 8.0.12.0 インストール グラフィック チュートリアル
  • MySQL 8.0.12 解凍バージョンのインストールチュートリアル
  • MySQL 8.0.12 クイックインストールチュートリアル
  • MySQL 8.0.12 インストール設定方法とパスワード変更
  • MySQL Server 8.0.3 のインストールと設定方法のグラフィックチュートリアル

<<:  「fsck」を使用して Linux のファイルシステムエラーを修正する方法

>>:  最も単純な ErrorBoundary コンポーネントをカプセル化して、React 例外を処理する

推薦する

Vue ElementUI フォームのフォーム検証

フォーム検証は、フロントエンド開発プロセスで最もよく使用される機能の 1 つです。私の個人的な仕事経...

Vueのdiffアルゴリズムについての簡単な説明

目次概要バーチャルドム原理実装プロセスパッチ方式sameVnode関数patchVnode関数upd...

MySQL innodb_autoinc_lock_mode について

innodb_autoinc_lock_mode パラメータは、auto_increment 列を持...

DockerでのinfluxDB分散時系列データベースのインストールと関連操作について簡単に説明します。

influxDB の紹介influxDB は分散型時系列データベースです。 cAdvisor はリ...

JavaScriptの知識ポイントの詳しい説明

目次1. JavaScriptの基礎2. 基本的なJavaScript構文3. JavaScript...

divコンテナ内の背景色または画像は、サイズが大きくなるにつれて大きくなります。

コードをコピーコードは次のとおりです。高さ:自動 !重要;高さ:550px;最小高さ:550px; ...

React NativeのstartReactApplicationメソッドの簡単な分析

今回は、 RNの起動処理を整理しました。最後のstartReactApplication比較的複雑で...

Vue のループフォーム項目例の詳細な説明

場合によっては、ユーザーがボタンをクリックして同様のフォームを追加し、クリックごとに 1 回追加でき...

Vue フロントエンド開発における階層的にネストされたコンポーネント間の通信の詳細な説明

目次序文例まとめ序文Vue の親子コンポーネントは、props を通じて親コンポーネントの値を子コン...

Nginx で WordPress 擬似静的を設定する方法の例

Baidu の擬似静的の説明を引用します。擬似静的は、実際の静的に相対的です。通常、検索エンジンの使...

データベースミドルウェアMyCatの紹介

1. Mycatの適用シナリオMycat は幅広いシナリオに合わせて開発されており、新しいユーザーが...

反応ジャンプ後にルートが変更されてもページが更新されない場合の解決策

目次質問解決質問この問題には多くの理由があるようです。私の問題は、パラメータ付きのURLを更新できな...

JavaScript での AOP プログラミングの基本実装

AOP の紹介AOP (アスペクト指向プログラミング) の主な機能は、コアビジネスロジックモジュール...

HTMLでカスタムタグを使用する方法

カスタム タグは XML ファイルと HTML ファイルで自由に使用できますが、いくつか注意すべき点...

JavaScriptプロトタイプチェーンを理解する

目次1. プロトタイプとプロトタイプチェーンの平等関係を理解する2: プロトタイプとプロトタイプ チ...