今日は、MySQL データベースと SQL 標準 (および他のデータベース) の UPDATE ステートメントの違いを紹介します。この問題に注意を払わないと、予期しない結果につながる可能性があります。 まず、簡単なサンプル テーブルを作成しましょう。 テーブルt1を作成します( id int、 列1 int, 列2 int ); t1 値 (1, 1, 1) に挿入します。 t1から*を選択します。 id|列1|列2| --|----|----| 1| 1| 1| ———————————————— 著作権声明: この記事は、CSDN ブロガー「髪を切らないトニー先生」によるオリジナル記事であり、CC 4.0 BY-SA 著作権契約に準拠しています。転載の際は、元のソース リンクとこの声明を添付してください。 オリジナルリンク: https://blog.csdn.net/horses/article/details/110238573CREATE TABLE t1( id int、 列1 int, 列2 int ); t1 値 (1, 1, 1) に挿入します。 t1から*を選択します。 id|列1|列2| --|----|----| 1| 1| 1| 次に、テーブル t1 のデータを更新します。 アップデート t1 SET col1 = col1 + 1、 列2 = 列1 ここで、id = 1; 列1、列2を選択 t1から; クエリ ステートメントによって返される col1 フィールドと col2 フィールドの結果は何ですか?
MySQL の場合、UPDATE ステートメントが式 (col2 = col1) で以前に更新された列 (col1) を使用する場合、元の値 (1) の代わりに列の更新された値 (2) が使用されます。 MySQL でのこの実装は SQL 標準とは異なることに注意してください。また、実装が SQL 標準に準拠している Oracle、Microsoft SQL Server、PostgreSQL、SQLite などの他のデータベースもテストしました。 MySQL で標準 SQL と同じ効果を実現したい場合は、UPDATE ステートメントで更新されるフィールドの順序を調整できます。例えば: アップデート t1 SET col2 = col1、 列1 = 列1 + 1 ここで、id = 1; この方法では、col1 の古い値 (1) を使用して、col2 列が col1 の前に更新され、結果は SQL 標準と一致します。 結論: 一般に、UPDATE ステートメントを記述する場合、複数のフィールドの更新順序を気にする必要はありません。ただし、MySQL の実装の問題により、文法の順序に注意する必要があります。 これで、MySQL UPDATE ステートメントの非標準実装に関するこの記事は終了です。MySQL UPDATE ステートメントに関連する非標準コンテンツの詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: シェルスクリプトは、Docker の半自動コンパイル、パッケージ化、およびリリースアプリケーション操作を構築します。
>>: Vue は無限ロードウォーターフォールフローを実装します
Docker コンテナは互いに分離されており、相互にアクセスできないことは誰もが知っていますが、依存...
Windows 10 で MySql データベースの解凍バージョンをインストールするステップ 1: ...
提案: コードをできるだけ手書きすると、学習の効率と深さを効果的に向上できます。デフォルトでは、&l...
1. 環境: MySQL-5.0.41-win32 Windows XP プロフェッショナル2. テ...
1. 行の形式は何ですか? MySQL の行形式の設定は次のように表示されます。 実際、MySQL ...
1いくつかの一般的な文字セットMySQL で最も一般的な文字セットには、ASCII 文字セット、ラテ...
Vim は Linux でよく使用されるテキスト エディターです。 Vim は、Sublime や ...
Fabric プロジェクトのソースコードを読み直してみたところ、Docker の部分でよくわからな...
1. app.jsonを使用してページを作成する私たちの通常の開発習慣によれば、新しいページを作成す...
Web 開発を行う際に、フラッシュがページ内の要素をブロックする状況に遭遇することがあります。フラ...
1. CSS の概念: (カスケーディング スタイル シート)利点: 1. コンテンツとプレゼンテ...
ここで、アンカー ポイントを制御するいくつかの状況をまとめてみましょう。 1. 同じページ <...
今日の画面解像度は、320 ピクセル (iPhone) ほど小さいものから、2560 ピクセル以上 ...
序文個人の実際の開発で使用した効果問題を、今後の開発やレビューに役立てるためにまとめています。他の人...
<br />ウェブサイトを科学的にデザインする: アイトラッキング研究から学ぶ 23 の...