MySQL の条件付き INSERT ステートメント
質問: INSERT 操作を条件付きで実行することは可能ですか。 IF ステートメント?
詳細:
製品 ID 2 のアイテムを 20 個注文する必要があるとします。十分な在庫を確保するために、まず手元の数量を確認します。 :
SELECT IF( ( SELECT SUM(qty) FROM orders WHERE product_id = 2 ) 20結果が true の場合、INSERT クエリを実行します。ただし、このアプローチは同時実行性の問題の影響を受けやすくなります。複数の同時注文は売り過ぎになる可能性があります。
答え:
はい、次の構文を使用して条件付き INSERT ステートメントが可能です:
INSERT INTO TABLE SELECT value_for_column1, value_for_column2, ... FROM wherever WHERE your_special_conditionSELECT ステートメントが行を返さない場合 (つまり、特殊条件が false)、挿入は行われません。
例:
For指定されたスキーマ:
products: id, qty_on_hand orders: id, product_id, qtyinsert into orders (product_id, qty) select 2, 20 where (SELECT qty_on_hand FROM products WHERE id = 2) > 20;このクエリは、十分な在庫がある場合にのみ行を挿入します。それ以外の場合、挿入は実行されません。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3