この記事では主に、SQL 削除ステートメント DROP、TRUNCATE、および DELETE の違いを紹介し、SQL ステートメントをよりよく理解して学習できるようにします。興味のある方は、さらに詳しく知ることができます。 落とす: DROP TABLE テスト。 テスト テーブルを削除してスペースを解放し、テスト テーブル内のすべてのデータを削除します。 切り捨て: TRUNCATE テスト; テスト テーブルの内容を削除してスペースを解放しますが、テーブル定義は削除しないでください。テーブル構造はそのまま残ります。 消去: 1. 指定したデータを削除する テストテーブルから、年齢が30歳で国が米国のデータを削除します。 age=30 かつ country='US' の場合、test から削除します。 2. テーブル全体を削除する テスト テーブルのすべての内容を削除し、テーブル定義を保持し、スペースを解放しません。 DELETE FROM test または TRUNCATE test; truncate table コマンドは、テーブル内のすべてのレコードをすばやく削除しますが、テーブル構造は保持します。このクイック削除は、すべてのテーブル レコードを削除する delete from table コマンドとは異なります。delete コマンドによって削除されたデータは、システム ロールバック セグメントに保存されます。必要に応じて、データをロールバックして復元できますが、truncate コマンドによって削除されたデータは復元できません。 類似点 切り捨て、where 句なしの削除、およびドロップはテーブル内のデータを削除します。 違い: 1. 切り捨てと削除ではデータのみが削除され、テーブル構造 (定義) は削除されません。ドロップ ステートメントは、テーブル構造が依存する制約、トリガー、およびインデックスを削除します。テーブルに依存するストアド プロシージャ/関数は保持されますが、無効になります。 2. 削除文は DML 文です。この操作はロールバック セグメントに配置され、トランザクションがコミットされた後にのみ有効になります。対応するトリガーがある場合は、実行時にトリガーされます。切り捨てと削除は DDL 操作です。操作はすぐに有効になります。元のデータはロールバック セグメントに配置されず、ロールバックできません。 操作によってトリガーがトリガーされません。 3. 削除ステートメントはテーブルが占有する範囲に影響を与えず、高水準点は元の位置に残ります。 明らかに、drop ステートメントはテーブルによって占有されているすべてのスペースを解放します。デフォルトでは、再利用ストレージが使用されない限り、truncate ステートメントは、領域を minexents エクステントまで解放します。truncate は、最高水準点をリセットします (先頭に戻ります)。 4. 速度: 一般的には、ドロップ > 切り捨て > 削除の順になります。 5. 安全性: 特にバックアップがない場合は、ドロップと切り捨てを慎重に使用してください。そうでなければ泣くには遅すぎるでしょう。 使用時には、一部のデータ行を削除する場合は delete を使用し、必ず where 句を含めてください。 ロールバック セグメントは十分な大きさである必要があります。 テーブルを削除する場合は、もちろん drop を使用します。 テーブルは保持しますが、すべてのデータを削除します。トランザクションに関係がない場合は、切り捨てのみを使用します。 トランザクションに関連している場合、またはトリガーをトリガーする場合は、delete を使用します。 テーブルをデフラグする必要がある場合は、切り捨てを使用してからストレージを再利用し、データを再インポート/挿入することができます。 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
目次ネスティング親子コンポーネント通信ブラザーコンポーネント通信撤回するReact の Linked...
目次Matlab セントロイドアルゴリズムMatlab はクローズドな商用ソフトウェアであり、米国政...
前の記事で説明したフォームの自動入力の問題を解決した後、新しい問題が発生しました。ページの一部のスタ...
目次1. コマンド2. docker-compose.yml 3. Dockerファイル4. 直接変...
目次1. TypeScriptが古いVueプロジェクトに導入されるVue+Typescript プロ...
まずdockerコンテナを実行しますルートユーザーとしてコマンドを実行する sudo docker ...
製造手順を分析します。 1. リソースを準備してシーンを構築するオンラインでリソースを探すか、私のリ...
目次1. Vue2 構文2. Vue3の使用1. コンポーネントのref値を設定する2. コンポーネ...
序文:前回の記事では、さまざまな MySQL ステートメント構文の使用法とユーザー権限に関する知識を...
問題の説明私たちのプロジェクトでは、水平方向のテーブルが一般的ですが、必要に応じて垂直方向のテーブル...
<TR> タグの属性は、次の表に示すように、テーブル内の各行のプロパティを設定するために...
目次質問分析する解決するAlert() 関数を置き換えるsetTimeOut関数まとめ質問数日前、J...
この記事では、主にMACオペレーティングシステムでのMySQL5.7とMySQLWorkbenchの...
最近、Rich Harris の <Rethinking Reactivity> ビデオ...
序文Linux 上で jar パッケージを実行する方法は誰もが知っています。なぜ別々に話したいのでし...