شروحات الكمبيوتر والإنترنت والموبايل

إنشاء جدول من جدول آخر باستخدام العمود الرئيسي فقط

كيفية إنشاء جدول جديد في Amazon Redshift باستخدام أعمدة المفاتيح الأساسية فقط من جدول آخر

في عالم قواعد البيانات، يواجه المطورون أحيانًا تحديات في إنشاء جداول جديدة بناءً على هيكل جداول موجودة، مع الحفاظ على أعمدة معينة فقط. في هذه الحالة، نتحدث عن إنشاء جدول من جدول آخر في Amazon Redshift، ولكن مع أعمدة المفاتيح الأساسية فقط. هذه العملية مهمة لتنظيم البيانات أو إنشاء نماذج أولية للجداول دون الحاجة إلى نقل البيانات كاملة. لكن كيف يمكن تحقيق ذلك؟ دعونا نتعمق في الحلول العملية.

الخطوة الأولى: استخراج أعمدة المفاتيح الأساسية

لإنشاء جدول جديد مع أعمدة المفاتيح الأساسية فقط، يجب أولاً تحديد أسماء هذه الأعمدة من الجدول الأصلي. يمكنك استخدام استعلام من information_schema لتحديد الأعمدة ذات المفتاح الأساسي، كما في المثال التالي:

SELECT column_name  
FROM information_schema.table_constraints tc  
JOIN information_schema.key_column_usage kcu  
    ON tc.constraint_name = kcu.constraint_name  
WHERE tc.table_schema = 'my_schema'  
    AND tc.table_name = 'my_table'  
    AND tc.constraint_type = 'PRIMARY KEY';  

هذا الاستعلام يُعيد قائمة بأسماء الأعمدة التي تحتوي على المفتاح الأساسي في الجدول المحدد. لكن التحدي يكمن في استخدام هذه النتائج ديناميكيًا لإنشاء الجدول الجديد، وهو ما سنشرحه في الخطوات التالية.


التحدي: دمج النتائج في دليل إنشاء الجدول

عند محاولة استخدام دالة مثل LISTAGG لدمج أسماء الأعمدة في سلسلة واحدة، قد تواجه خطأً في Amazon Redshift بسبب عدم دعم هذه الوظيفة لبعض أنواع البيانات (مثل smallint[]). على سبيل المثال، الاستعلام التالي:

SELECT LISTAGG(column_name, ',')  
FROM information_schema.table_constraints tc  
JOIN information_schema.key_column_usage kcu  
    ON tc.constraint_name = kcu.constraint_name  
WHERE tc.constraint_type = 'PRIMARY KEY';  

سيُسبب خطأً بسبب نوع البيانات غير المدعوم. لذلك، يجب اتباع طريقة بديلة لبناء جملة CREATE TABLE باستخدام النتائج المُستخرجة.


الحل الأمثل: استخدام الاستعلام كمصدر ديناميكي

بدلاً من استخدام LISTAGG، يمكنك بناء جملة CREATE TABLE بشكل ديناميكي عبر الخطوات التالية:

  1. استخرج أسماء الأعمدة إلى متغيرات أو سلسلة:
    يمكنك استخدام لغة البرمجة (مثل Python أو bash) لتنفيذ الاستعلام الأول، ثم جمع النتائج في سلسلة مُفصَّلة بفواصل.

  2. أنشئ الجدول باستخدام الجملة المُصمَّمة:
    استخدم النتائج المُجمعة لكتابة جملة CREATE TABLE مثل:

    CREATE TABLE my_new_schema.my_new_table (  
       <قائمة_الأعمدة>  
    );  

    حيث تُعوِّض <قائمة_الأعمدة> بأسماء الأعمدة المُستخرجة مع أنواعها.


مرادفات العملية:

  • إنشاء هيكل جدول جديد مع مفاتيح أساسية فقط في Redshift
  • استنساخ أعمدة المفاتيح من جدول إلى آخر في Amazon Redshift
  • إنشاء جدول فرعي يحتوي على مفتاح أساسي من جدول أصلي في Redshift

تفاصيل تنفيذية:

إذا كنت تفضل استخدام SQL النقي دون لغات برمجية، يمكنك اتباع هذه الخطوات:

  1. اكتب استعلامًا لإنشاء الجدول مع تحديد الأعمدة يدويًا بناءً على النتائج الأولية.
  2. إذا كانت الأعمدة ثابتة، يمكنك استخدام CREATE TABLE AS مع تحديد الأعمدة المطلوبة:
    CREATE TABLE my_new_table AS  
    SELECT column1, column2, ...  
    FROM old_table  
    WHERE 1=0;  -- لتجنب نقل البيانات  

لكن هذه الطريقة تحتاج إلى معرفة أسماء الأعمدة مسبقًا، بينما الحل الديناميكي يُعد أسرع مع تغيير هيكل الجدول الأصلي.


الاستنتاج: أتمتة العملية لتحسين الكفاءة

في النهاية، إنشاء جدول من جدول آخر في Amazon Redshift مع أعمدة المفاتيح الأساسية فقط يتطلب فهمًا عميقًا لโครง trúc البيانات واستخدام أدوات الاستعلام بشكل استراتيجي. سواء عبر لغات برمجية أو عبر كتابة استعلامات مُصمَّمة بدقة، يمكنك تحقيق هدفك بفعالية. تذكر أن Amazon Redshift يدعم مرونة كبيرة في إدارة الجداول، مما يجعل هذه العملية ممكنة مع القليل من التخطيط.


إذا كنت تبحث عن طريقة أكثر تقدمًا، يمكنك استخدام المacros أو الإجراءات المخزنة لتنفيذ هذه العملية تلقائيًا كلما تغير هيكل الجدول الأصلي. هذا يضمن أن جدولك الجديد يبقى مُحدثًا دائمًا مع أعمدة المفاتيح الأساسية.

فهد السلال

خبير تقني متخصص في شروحات الكمبيوتر والإنترنت والموبايل، يتمتع بخبرة واسعة في تقديم حلول تقنية مبتكرة ومبسطة. يهدف فهد إلى مساعدة المستخدمين على تحسين تجربتهم التقنية من خلال مقالات وأدلة عملية واضحة وسهلة الفهم.
زر الذهاب إلى الأعلى
Don`t copy text!