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

كيفية ربط جميع أعمدة MySQL ديناميكيًا؟

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

How to Dynamically Concatenate All MySQL Columns?

ربط جميع أعمدة MySQL ديناميكيًا

في MySQL، لا يتم دعم ربط جميع الأعمدة باستخدام أحرف البدل *. بدلاً من ذلك، تحتاج إلى تحديد اسم كل عمود بشكل صريح في وظائف CONCAT() أو GROUP_CONCAT().

تسلسل الأعمدة الصريح:

يمكنك استخدام CONCAT() وظيفة لتسلسل أعمدة محددة:

SELECT CONCAT(col1, col2, col3, ...)
FROM yourtable;

أو استخدم CONCAT_WS() لربط الأعمدة بفاصل محدد، وتخطي القيم الخالية:

SELECT CONCAT_WS(',', col1, col2, col3, ...)
FROM yourtable;

تسلسل الأعمدة الديناميكية:

لتجنب تحديد أسماء الأعمدة يدويًا، يمكنك استخدام استعلام ديناميكي لاسترداد جميع أسماء الأعمدة من جدول information_schema.columns:

SELECT `column_name`
FROM `information_schema`.`columns`
WHERE `table_schema` = DATABASE()
  AND `table_name` = 'yourtable';

ثم استخدم GROUP_CONCAT() لدمج أسماء الأعمدة هذه:

GROUP_CONCAT(CONCAT('`', column_name, '`'))

سيؤدي ذلك إلى قائمة مفصولة بفواصل بأسماء الأعمدة المقتبسة، مثل:

`col1`,`col2`,`col3`,`col4`,...

بهذا، يمكنك إنشاء استعلام ديناميكي لتسلسل جميع الأعمدة:

SET @sql = CONCAT(
  'SELECT CONCAT_WS(\'\',',
  GROUP_CONCAT(CONCAT('`', column_name, '`') ORDER BY column_name),
  ') AS all_columns FROM yourtable;'
);

أخيرًا، قم بتنفيذ الاستعلام الديناميكي:

PREPARE stmt FROM @sql;
EXECUTE stmt;
بيان الافراج أعيد طبع هذه المقالة على: 1729757658 في حالة وجود أي انتهاك، يرجى الاتصال بـ [email protected] لحذفها
أحدث البرنامج التعليمي أكثر>

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

Copyright© 2022 湘ICP备2022001581号-3