01 シナリオ分析今日の午後、開発仲間がオンラインでいくつかのデータレコードを削除するという要件を提案しました。データ分布をざっと見たところ、データテーブル内の2,700万件以上のレコードを削除する必要があると推定されました。データテーブル内のレコードの総数は2,800万件を超えており、削除対象のレコードがレコード総数の大部分を占めていることを意味します。2,700万件以上のデータレコードを削除すると、それらを使用するのに長い時間がかかり、オンラインビジネスに間違いなく影響します。ここでは、実際のアプリケーション ケースを次の方法で単純に再構築します。 mysql> test.tbl_a から date,count(*) を選択し、日付でグループ化します。 +----------+-----------+ | 日付 | カウント(*) | +----------+-----------+ | | 63103 | | 20190118 | | | | 125916 | | 20190120 | | | | 129198 | | 20190122 | | | | 5191247 | +----------+-----------+ セット内の行数 (13.21 秒) 上記は再構築されたテーブルの構造です。テストデータベースのテーブル tbl_b を日付別にグループ化すると、各グループのデータ量は少なくないことがわかります。要件は、日付が 20190118 と 20190123 のレコードを削除することです。この 2 種類のレコードは 2,000 万件以上あり、テーブル内のデータの大部分を占めていることがわかります。これらを直接削除すると、オンラインビジネスは間違いなくブロックされます。 操作方法は以下の通りです。なお、以下の操作方法を適用する前提は以下のとおりです。 削除されるデータは、データ テーブルの大部分を占めます。 02 操作方法分析により、残りのテーブル データはテーブル全体のごく一部であることがわかります。この操作は 4 つのステップに分かれています。 1. まず残りのデータを別のデータベース test1 に保存します。 テーブルtest1.tbl_b_newを作成します test.tbl_b から * を選択 日付は(,,,,); この操作には約 3 秒しかかかりません。 2. test1 データベースに同じ名前のテーブル tbl_b を作成します。その構造は、テスト データベースの tbl_b データ構造と一致します。 test.tbl_b のようなテーブル test1.tbl_b を作成します。 3. 次に、データベースの名前変更操作を使用して、テーブル test のテーブル tbl_b を test1 のテーブル tbl_b と交換します。これは、テスト データベースのテーブル内のすべてのデータをクリアすることと同じです。 テーブル名をtest.tbl_bからtest1.tbl_b_bakに変更します。 test1.tbl_b から test.tbl_b へ、 test1.tbl_b_bak を test1.tbl_b へコピーします。 4. 次に、最初の手順で保存した残りのデータを次のように新しいテーブルに入力します。 test.tbl_b に挿入します。test1.tbl_b_new から * を選択します。 03 結果分析問題を複雑にしてしまったようです。直接削除にいくつかの手順を追加しました。しかし、そうではありません。この一連の操作により、数分間の節約が可能になり、オンライン ビジネスへの影響も少なくなります。その理由は次のとおりです。
2 番目の機能は、私たちにアイデアを提供します。非常に緊急の業務では、テーブルを使用する必要がある場合、テーブルをバックアップする時間が十分にないことがよくあります。大きなテーブルのデータを削除し、関連するバックアップを作成する必要がある場合は、名前変更操作を通じてすばやく処理し、名前変更後にテーブルをバックアップする方法を見つけることができます。 上記の例では、テーブルを複製する 2 つの方法 (create table as と create table like) を使用しています。注意すべき点がいくつかあります。 create table のようなメソッドはテーブル構造を完全に複製しますが、データは挿入しません。データを個別にロードするには、insert into または load data メソッドを使用する必要があります。 興味があれば、実験を行って検証してみるのも良いでしょう。 上記は、MySQLオンラインデータベースのデータをクリーニングする方法の詳細な内容です。MySQLオンラインデータベースのデータをクリーニングする方法の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: jquery+springbootでファイルアップロード機能を実現
1. MySQL 8.0.12 バージョンのインストール手順。 1. ダウンロードhttps://d...
1. 各関数はオブジェクトであり、メモリを占有します。メモリ内のオブジェクトが増えるほど、パフォーマ...
目次事前準備実施方法: 1. 単一のデータを挿入する2. マージデータ挿入3. MySqlBulkL...
目次1. データの簡単な取得2. データの並べ替えと取得2.1. 基本構文2.2. ソート方向を指定...
UNIONの使用ほとんどの SQL クエリは、1 つ以上のテーブルからデータを返す単一の SELEC...
React プロジェクトで要素フレームワークを使用するのは今回が初めてです。非常に単純な問題に遭遇し...
Windows Server 2012 と Windows Server 2008 では、デスクトッ...
この問題に関して、オンライン リソースをたくさん見つけました。ここにいくつかの方法を示します。コード...
以下のコードをDreamweaverのコードエリアにコピーすると、プレビュー時に以下の画像が表示され...
1. ポート2375を開くdocker.serviceを編集する vim /lib/systemd/...
目次問題の概要問題の再現問題の拡大結論は問題の概要今日、仕事中に、DBA が突然、SQL に暗黙的な...
3ウェイハンドシェイクフェーズクライアントSYNパケットの再試行回数sysctl -w net.ip...
序文ご存知のとおり、nginx 構成ファイルは add_header ディレクティブを使用して応答ヘ...
次のコードは、私の test.html にあります。ビデオは、c:\test.html などの絶対パ...
目次導入1. MySQLデータベースの全体的なアーキテクチャSQL インターフェースパーサーオプティ...