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

كيفية نسخ وظيفة GROUP_CONCAT الخاصة بـ MySQL في جانغو؟

تم النشر بتاريخ 2025-01-21
تصفح:572

How to Replicate MySQL\'s GROUP_CONCAT Function in Django?

Django يعادل GROUP_CONCAT في MySQL

في مشروع Django، يمكنك تنفيذ استعلام لاسترداد عدد من الأنواع المختلفة والفاصلة- قائمة محددة بأسمائهم. بينما يقدم MySQL الدالة GROUP_CONCAT لهذه المهمة، فإن العثور على ما يعادلها من Django قد يكون أمرًا صعبًا.

لنفترض أن هناك جدولًا باسم 'الفواكه':

01ماك2برتقاليالسرةال الناتج المطلوب هو:
المعرفالاسم
تفاحةفوجي
أبل

النوع الاسم 2"فوجي، ماك"برتقالي1"السرة"مخصص وظيفة التجميعلتحقيق ذلك بدون استعلامات SQL الأولية، قم بإنشاء وظيفة تجميعية مخصصة في Django.
تفاحة
أضف الكود التالي إلى مشروعك:

من Django. db.models استيراد التجميعي فئة كونكات (المجموع): الوظيفة = "GROUP_CONCAT" القالب = '%(وظيفة)s(%(متميز)s%(تعبيرات)s)' def __init__(self, Expression, Different=False, **extra): سوبر (كونكات، النفس).__init__( تعبير، متميز = 'مميز ' إذا كان مميزًا آخر ''، output_field=CharField(), **إضافي)

Usage

استخدم الوظيفة التجميعية المخصصة مثل هذا:
from django.db.models import Aggregate

class Concat(Aggregate):
    function = 'GROUP_CONCAT'
    template = '%(function)s(%(distinct)s%(expressions)s)'

    def __init__(self, expression, distinct=False, **extra):
        super(Concat, self).__init__(
            expression,
            distinct='DISTINCT ' if distinct else '',
            output_field=CharField(),
            **extra)
query_set = Fruits.objects.values('type'). علق( العد = العد ('النوع')، الاسم = كونكات ('الاسم') ).order_by('-count')

سيعود هذا الاستعلام إلى QuerySet بالمخرجات المطلوبة.

مثال للإخراج

from django.db.models import Aggregate

class Concat(Aggregate):
    function = 'GROUP_CONCAT'
    template = '%(function)s(%(distinct)s%(expressions)s)'

    def __init__(self, expression, distinct=False, **extra):
        super(Concat, self).__init__(
            expression,
            distinct='DISTINCT ' if distinct else '',
            output_field=CharField(),
            **extra)
بالنسبة لـ 'الفواكه' '، فإن مجموعة الاستعلام ستحتوي على:

{ "النوع": "تفاحة"، "العد": 2، 'اسم': 'فوجي، ماك' }, { "النوع": "برتقالي"، "العدد": 1، "الاسم": "السرة" },

الاستنتاج

من خلال إنشاء وظيفة مجمعة مخصصة، يمكنك بسهولة تحقيق وظيفة تشبه GROUP_CONCAT في Django، مما يجعل من الممكن استرداد عدد من القيم المختلفة و قائمة مفصولة بفواصل بالأسماء أو القيم ذات الصلة من جدول قاعدة البيانات.
            
أحدث البرنامج التعليمي أكثر>

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

Copyright© 2022 湘ICP备2022001581号-3