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

كيفية تحديث الصفوف والحصول على معرفات محدثة في MySQL بدون استعلام فرعي؟

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

How to Update Rows and Get Updated IDs in MySQL Without a Subquery?

الجمع بين استعلامات SELECT و UPDATE في MySQL

يمكن أن يكون الجمع بين استعلامات SELECT و UPDATE في عملية واحدة مفيدًا لتحسين أداء قاعدة البيانات. في هذه الحالة، يرغب المستخدم في دمج الاستعلامات التالية:

SELECT * FROM table WHERE group_id = 1013 and time > 100;
UPDATE table SET time = 0 WHERE group_id = 1013 and time > 100

على الرغم من أن أسلوب الاستعلام الفرعي قد لا يوفر النتائج المرجوة، إلا أن هناك حلًا يمكنه تحقيق الهدف بدون استعلام فرعي. يتضمن هذا الحل استخدام متغير محدد من قبل المستخدم (@uids) لتخزين معرفات الصفوف المحدثة:

UPDATE footable
   SET foo = 'bar'
 WHERE fooid > 5
   AND ( SELECT @uids := CONCAT_WS(',', fooid, @uids) );
SELECT @uids;```
أحدث البرنامج التعليمي أكثر>

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

Copyright© 2022 湘ICP备2022001581号-3