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

كيفية فرز أعمدة السلسلة مع الأرقام المضمنة في SQL؟

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

How to Sort String Columns with Embedded Numbers in SQL?

فرز أعمدة السلسلة مع الأرقام المضمنة في SQL

في SQL، من الممكن فرز أعمدة السلسلة التي تحتوي على أرقام باستخدام تقنيات محددة. يمكن أن يكون هذا مفيدًا عندما لا تنتج خوارزمية الفرز الطبيعية لقواعد البيانات مثل MySQL النتائج المرجوة.

لتحقيق فرز مخصص لأعمدة السلسلة بالأرقام، يمكن استخدام عدة طرق:

استخدام الإرسال والسلسلة الفرعية:

SELECT *
FROM table
ORDER BY CAST(SUBSTRING(column,LOCATE(' ',column) 1) AS SIGNED)
تقسم هذه التقنية العمود إلى جزأين: البادئة قبل المسافة والرقم الذي يليها. يتم بعد ذلك تحويل الرقم إلى نوع رقمي (في هذه الحالة، SIGNED) للمقارنة.

باستخدام SUBSTRING_INDEX:

ORDER BY SUBSTRING_INDEX(st, " ", 1) ASC, CAST(SUBSTRING_INDEX(st, " ", -1) AS SIGNED)
يستخدم هذا الأسلوب الدالة SUBSTRING_INDEX لاستخراج مكونات البادئة والأرقام. ثم يقوم بالفرز أولاً حسب البادئة ثم حسب الرقم المحول.

ملاحظة: إذا كان نمط العمود يختلف عن "WORD_space_NUMBER"، فقد يكون من الضروري اتباع نهج مختلف.

أمثلة:

عينة البياناتالفرز الطبيعيالفرز المخصصأ 1، أ 12، أ 6، أ 11 أ 1، أ 12، أ 2، أ 3 أ 1، أ 2، أ 3، أ 12 ب 1، ب 12، ب 6، ب 11 ب 1، ب 12، ب 2، ب 3 b 1, b 2, b 3, b 12 من خلال استخدام هذه التقنيات، من الممكن فرز أعمدة السلسلة بأرقام مضمنة بطريقة مخصصة، مما يضمن أن تتوافق النتائج مع متطلبات التطبيق المحددة.
أحدث البرنامج التعليمي أكثر>

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

Copyright© 2022 湘ICP备2022001581号-3