mysqlの大きなテーブルとは何ですか?大したこととは何ですか?どうやって対処すればいいのでしょうか?
この記事の内容は、mysql の大きなテーブルとは何ですか?大したこととは何ですか?どうやって対処すればいいのでしょうか?困っている友人は参考にしていただければ幸いです。
序文
相対的に言えば、データベース テーブルはどのような状況で「大きなテーブル」と言えるのでしょうか?
テーブル内のデータが数千万行を超えると、データベースに影響を及ぼします
テーブル データ ファイルが巨大なテーブル データ ファイルは 10G を超えています (データ値はハードウェアに関連しています)
大きなテーブルの影響
大きなテーブルがクエリに及ぼす影響クエリが遅い: 一定時間内にフィルタリングするのが難しい 必要なデータを取得する
(例: 表示順序、ソースが少ない、微分性が低い、ディスク IO が多い、ディスク効率が低下、クエリが遅い)
1。インデックスの作成に時間がかかります。長期的なリスク:
MYSQL バージョン 5.5 未満では、作成時にテーブルがロックされます。インデックス
MYSQLバージョン>= 5.5 テーブルはロックされませんが、マスター/スレーブ遅延が発生します#2。テーブル構造を変更するには、長時間テーブルをロックする必要があります
##。 # リスク:
マスターとスレーブの遅延が長くなります
通常のデータ操作に影響します 対処方法 データベース内の大きなテーブル1。大きなテーブルを複数の小さなテーブルに分割する
難易度:
分割テーブルの主キーの選択
テーブル分割後のパーティション間データのクエリと統計2.
利点:
フロントエンドとバックエンドのビジネスへの影響を軽減
アーカイブ時間 ポイントの選択
- トランザクションは、アトミック SQL ステートメントのセットです。または、独立した作業単位
- トランザクション要件は、アトミック性、一貫性、分離性、耐久性を遵守します
トランザクションのアトミック性
トランザクションは最小の作業単位を考慮する必要があります。トランザクション全体のすべての操作が成功するか、すべてが失敗するかのどちらかです。トランザクションの一部のみを実行することはできません。
1. 財務管理口座の残高が 2,000 元を超えているかどうかを確認します。
2 財務管理口座の残高から 2,000 元を差し引きます。アクティブな預金口座 2000 元トランザクション全体のすべての操作が正常に送信されるか、すべての操作が失敗してロールバックされます。トランザクションの一貫性
一貫性とは、トランザクションがデータベースをある一貫性状態から別の一貫性状態に変換することを意味し、トランザクションの開始前および終了後にデータベース内のデータの整合性が破壊されないことを意味します。
トランザクションの分離
分離では、トランザクションによるデータベース内のデータの変更が、送信が完了するまで他のトランザクションに表示されないようにする必要があります。
SQL 標準で定義されている 4 種類のレベル (分離性は低位から高位) (同時実行性は高位から低位)
READ UNCOMMITED
Committed Read (READ COMMITED)反復可能読み取り (REPEATABLE READ)
シリアル化可能 (SERIALIZABLE)トランザクションの永続性
トランザクションがコミットされると、その変更はデータベースに永久に保存されます。この時点でシステムがクラッシュしても、変更されたデータはデータベースに保存されます。提出されたものは失われることはありません。
大したことって何ですか?
実行に時間がかかり、大量のデータを操作するトランザクション
リスク:
ロックしすぎるデータにより、大量のブロックとロック タイムアウトが発生する
Return Rolling に時間がかかる実行時間が長く、マスタースレーブ間の遅延が発生しやすい
大規模なトランザクションをどのように処理するか?
一度に大量のデータを処理しないようにします
- トランザクション内の不要な SELECT 操作を削除します
以上がmysqlの大きなテーブルとは何ですか?大したこととは何ですか?どうやって対処すればいいのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









MySQLデータベースでは、ユーザーとデータベースの関係は、アクセス許可と表によって定義されます。ユーザーには、データベースにアクセスするためのユーザー名とパスワードがあります。許可は助成金コマンドを通じて付与され、テーブルはCreate Tableコマンドによって作成されます。ユーザーとデータベースの関係を確立するには、データベースを作成し、ユーザーを作成してから許可を付与する必要があります。

MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

NAVICAT自体はデータベースパスワードを保存せず、暗号化されたパスワードのみを取得できます。解決策:1。パスワードマネージャーを確認します。 2。NAVICATの「パスワードを記憶する」機能を確認します。 3.データベースパスワードをリセットします。 4.データベース管理者に連絡してください。

1.正しいインデックスを使用して、データの量を削減してデータ検索をスピードアップしました。テーブルの列を複数回検索する場合は、その列のインデックスを作成します。あなたまたはあなたのアプリが基準に従って複数の列からのデータが必要な場合、複合インデックス2を作成します2。選択した列のみを避けます。必要な列のすべてを選択すると、より多くのサーバーメモリを使用する場合にのみサーバーが遅くなり、たとえばテーブルにはcreated_atやupdated_atやupdated_atなどの列が含まれます。

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

MySQLでテーブルをコピーするには、新しいテーブルの作成、データの挿入、外部キーの設定、インデックスのコピー、トリガー、ストアドプロシージャ、および機能が必要です。特定の手順には、同じ構造を持つ新しいテーブルの作成が含まれます。元のテーブルからデータを新しいテーブルに挿入します。同じ外部キーの制約を設定します(元のテーブルに1つがある場合)。同じインデックスを作成します。同じトリガーを作成します(元のテーブルに1つがある場合)。同じストアドプロシージャまたは関数を作成します(元のテーブルが使用されている場合)。

Passwordが暗号化された形式で保存されているため、MariadbのNavicatはデータベースパスワードを直接表示できません。データベースのセキュリティを確保するには、パスワードをリセットするには3つの方法があります。NAVICATを介してパスワードをリセットし、複雑なパスワードを設定します。構成ファイルを表示します(推奨されていない、高リスク)。システムコマンドラインツールを使用します(推奨されません。コマンドラインツールに習熟する必要があります)。

次のコマンドでmysqlデータベースを表示します。サーバーに接続します:mysql -u username -pパスワードrun showデータベース。すべての既存のデータベースを取得するコマンド[データベース]を選択します。データベース名を使用します。テーブルを表示:表を表示します。テーブル構造を表示:テーブル名を説明してください。データを表示:[テーブル名]から[ *]を選択します。
