"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > كيفية إجراء التحديثات الشرطية في INSERT الخاص بـ MySQL ... عند تحديث المفتاح المكرر؟

كيفية إجراء التحديثات الشرطية في INSERT الخاص بـ MySQL ... عند تحديث المفتاح المكرر؟

تم النشر بتاريخ 2024-11-17
تصفح:482

How to Perform Conditional Updates in MySQL\'s INSERT ... ON DUPLICATE KEY UPDATE?

التحديث المشروط في INSERT ... ON DUPLICATE KEY UPDATE

في MySQL، تسمح صيغة INSERT ... ON DUPLICATE KEY UPDATE بـ التحديث التلقائي لبيانات الجدول عند مواجهة مفتاح مكرر أثناء عملية الإدراج. ومع ذلك، فإن جزء UPDATE من الاستعلام لا يدعم استخدام جملة WHERE لتحديد التحديثات الشرطية.

الحل البديل باستخدام IF()

للتغلب على هذا القيد، يمكن للمرء استخدام الدالة IF() لتنفيذ التحديثات الشرطية ضمن جملة ON DUPLICATE KEY UPDATE. تقوم الدالة IF() بتقييم الشرط وإرجاع قيمة مختلفة بناءً على النتيجة.

على سبيل المثال، ضع في اعتبارك عبارة INSERT ... ON DUPLICATE KEY UPDATE التالية:

INSERT INTO daily_events (created_on, last_event_id, last_event_created_at)
VALUES ('2010-01-19', 23, '2010-01-19 10:23:11')
ON DUPLICATE KEY UPDATE
  last_event_id = IF(last_event_created_at 

في هذا البيان، تتحقق الدالة IF() مما إذا كانت قيمة العمود last_event_created_at في جدول قاعدة البيانات أقل من القيمة التي يتم إدراجها (VALUES(last_event_created_at)). إذا كان صحيحًا، فإنه يقوم بتحديث العمود last_event_id بالقيمة الجديدة من عبارة الإدراج. بخلاف ذلك، فإنه يترك القيمة الموجودة دون تغيير.

يسمح هذا الحل البديل بالتحديثات الشرطية في عبارات INSERT... ON DUPLICATE KEY UPDATE دون اللجوء إلى مجموعات من استعلامات INSERT/UPDATE/SELECT، والتي قد لا تكون مناسبة للنسخ المتماثل السيناريوهات.

أحدث البرنامج التعليمي أكثر>

تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.

Copyright© 2022 湘ICP备2022001581号-3