قواعد البيانات SQLite والبايثون – كيف تُنشئ قاعدة بيانات وتتعامل معها
قواعد البيانات SQLite هي أحد أشهر أنواع قواعد البيانات، فهي تتمتع بالعديد من المزايا التي جعلتها مناسبة جدًا للعديد من الحالات. SQLite هي محرك قاعدة بيانات سهل الاستخدام وخفيف للغاية، ولا تحتاج لإعدادت سيرفر أو أي إعدادات أخرى فهي zero configuration. نُرحب بكم في هذا المقال الجديد من بايثونات والذي من خلاله نتطرق إلى كيفية التعامل مع هذا النوع من قواعد البيانات.
ما هي قاعدة البيانات SQLite ؟
في الكثير من الأحيان نحتاج لحفظ بيانات مُهيكلة Structured في ملف او مصدر تخزين بيانات. هذه الحالة تحدث مرارًا وتكرارًا، مثلا، عند حفظ بيانات تطبيق سطح مكتب، أو إعدادات نظام محلي أو تطبيق جوال والعديد من الحالات. تأتي SQLite كحل سهل وبسيط وغير مكلف لذلك.
SQLite هي أحد أشهر أنواع قواعد البيانات مفتوحة المصدر غير المعقدة والتي يتم حفظ جميع تفاصيلها (من تعريف الجداول وحتى البيانات) داخل ملف واحد. تم بناء قاعدة البيانات باستخدام لغة C مما يُفسر السرعة العالية في التعامل معها. يُمكنك تحميل SQLite من خلال الرابط التالي:
كما يُمكنك الإطلاع على الشيفرة البرمجية المفتوحة لها من خلال الرابط التالي:
الشيفرة المفتوحة لقاعدة بيانات SQLite
ولكن من المهم التنبيه أننا عند التعامل مع بايثون، لن نحتاج لتحميل SQLite، فهي مُضمنة تلقائيًا منذ الإصدار 2.5.
اقرأ أيضًا: لغة بايثون للمبتدئين – سلسلة بايثونات
مميزات SQLite
- خفيفة: يُمكن تضمينها واستخدامها في أجهزة الجوال، التلفزيونات الذكية، الأجهزة والقطع الالكترونية البيتية، الكاميرات الذكية وما إلى ذلك.
- أداء عالي: لديها سرعة عالية في القراءة والكتابة، فهي 35% أسرع من القراءة والكتابة من ملفات النظام العادية، كما أنها تُحمل البيانات فقط وقت الحاجة إليها.
- لا تحتاج عملية تثبيت: حيث لا تحتاج إلى إعدادات او عملية تثبيت، كُل ما هو مطلوب هو أن تُحمل الملفات الخاصة بها على جهازك الحاسوب وبعدها يُمكن استخدامها بكل سهولة.
- الاعتمادية: تقوم SQLit بتحديث البيانات أولًا بأول، وبذلك، قد تضيع بيانات قليلة عند حدوث فشل النظام وتعطله فجأة (وقد لا تفقد بيانات من الأساس).
- لغات برمجة عديدة: أغلب لغات البرمجة تُقدم الإمكانيات اللازمة للتعامل مع قاعدة بيانات SQLite.
كما يُوجد العديد من المميزات الأخرى التي نتركها لكم للتعرف عليها أثناء استخدامكم الفعلي لقاعدة بيانات SQLite.
ما الذي لا تقدمه SQLite ؟
SQLite مناسبة لبعض الحالات العملية، ولكنها غير مناسبة ولا يصلح استخدامها في بعض الحالات الأخرى. النقاط التالية تُوضح لك بعض العيوب:
- لا تدعم بعض خصائص قواعد البيانات العلائقية في SQL. يُمكنكم التعرف أكثر من خلال زيارة التوثيق الرسمي لقاعدة البيانات: مالخصائص التي لا تدعمها SQLite؟
- عندما تكون متصلًا بقاعدة البيانات SQLite لإجراء عمليات الكتابة، فإن قاعدة البيانات تكون مقفلة ولا يمكن الكتابة عليها. لا تسمح قاعدة بيانات SQLite بأكثر من اتصال واحد في الوقت الواحد، لذا فهي غير مناسبة للتطبيقات التي تتضمن أكثر من مستخدم متصل بها.
- لا تدعم SQLite بعض أنواع البيانات المتقدمة والمعروفة لدى لغات برمجة.
إنشاء قاعدة SQLite بيانات في البايثون
كما ذكرنا في البداية، فإن بايثون تتضمن مكتبة معيارية للتعامل مباشرة مع SQLite، وللتعامل معها، فإن أول شيء يجب علينا فعله هو استيراد المكتبة ثم انشاء عنصر يُمثل الاتصال مع قاعدة البيانات:
تعمل الدالة connect على إعادة عنصر من نوع Connection الذي يُمثل قناة الاتصال مع قاعدة البيانات، ويحتوي العديد من الخصائص والدوال التي نستخدمها في تعاملنا مع قاعدة البيانات. لإنشاء قاعدة البيانات، نُمرر للدالة connect المسار الخاص بقاعدة البيانات + الاسم، وعند استدعاءها سيتم انشاء قاعدة البيانات اذا لم تكن منشأة من قبل في المسار، واذا كانت موجودة من قبل، فسيتم فتح قناة الاتصال معها:
بعد تنفيذ السطر السابق، وبإفتراض أنه لا يُوجد ملف قاعدة بيانات باسم myDB.db في المسار الحالي، سيتم انشاء ملف قاعدة البيانات.
بعد أن أنشأنا قاعدة البيانات وفتحنا قناة الاتصال معها، سنعمل على تعريف جدول بداخلها. الأمر التالي هو الصيغة العامة لإنشاء جدول في قاعدة البيانات:
لتنفيذ أمر انشاء جدول جديد بداخل قاعدة البيانات التي أنشأنها باسم myDB.db، نٌعرف في البداية ما يُسمى cursor وهو الكائن المسؤول عن تنفيذ جُمل SQL والتعامل مع النتائج. يُوجد عدة دوال يُمكن استخدمها من خلال cursor لتنفيذ جُمل SQL والتعامل مع نتائجها.
المثال التالي يُوضح كيفية إنشاء قاعدة بيانات جديدة باسم Pythonat ثم إنشاء جدول باسم Article. بعد إنشاء الجدول، نستعلم عن الجداول الموجودة في قاعدة البيانات، للتأكد من وجود الجدول الجديد:
عند إنشاء قاعدة البيانات والجدول بدون أخطاء، ستكون نتيجة الشيفرة البرمجية السابقة كالتالي:
وبذلك يكون جدول Articles جاهزًا لإدخال البيانات فيه والتعديل عليه.
اقرأ أيضًا: مكتبات علم البيانات بالبايثون – أشهر 5 مكتبات
إجراء عمليات CRUD من خلال البايثون
المقصود بعمليات CRUD هي create, retrieve, update, delete وهي العمليات الأساسية المستخدمة في التعامل مع البيانات داخل قواعد البيانات.
اضافة سجل بيانات لجدول
لإضافة بيانات جديدة في جدول Article نستخدم جملة SQL المُسماة insert into table والصيغة العامة لها هي كالتالي:
المثال التالي يوضح أمر SQL لإضافة سجل جديد لجدول article:
لتنفيذ الأمر السابق في البايثون، نُسند صيغة الأمر كنوع نصي لمتغير، ثم نُمرر المتغير للدالة execute كما يلي:
لتأكيد عملية الإضافة، نُنفذ الدالة commit الموجودة في كائن الإتصال. أوامر commit و rollback هي أوامر SQL للتحكم بـ transaction التي يتم تنفيذها واجراؤها في قاعدة البيانات.
اضافة مجموعة سجلات
أحد الطُرق التي يُمكن استخدامها في اضافة سجلات لجدول ما دفعةً واحدة، هي تكرار جُملة الإضافة لكل سجل داخل حلقة تكرارية، ولكن على ما يبدو أن تلك هي طريقة لا يُحبذها الكثير من المبرمجين، لما قد تُسببه من ارهاق في الكتابة وفهم الشيفرة البرمجية او بسبب عدم الكفاءة. تُقدم الوحدة المعيارية في بايثون sqlite3 خيار تنفيذ جُملة SQL أكثر من مرة بواسطة دالة واحدة واستدعاء واحد وهي دالة executemany. في المثال التالي، نُنشئ قائمة تحتوي سجلات نريد أن نضيفها لجدول Article من خلال دالة executemany:
تعديل سجل بيانات في جدول
نستخدم لتعديل سجلات جدول ما في SQL جملة update table. الصيغة العامة للجملة كما يلي:
للتطبيق مثلًا، نريد أم نُعدل عمود article_txt بحيث يُصبح قيمته ‘dummy dummy dummy’ للسجل الذي له article_id يساوي 3. في المثال التالي نحفظ جملة SQL في متغير اسمه update_command ثم نُنفذ الجُملة باستخدام دالة execute:
حذف سجل بيانات من جدول
الصيغة العامة لأمر الحذف في SQL هي كالتالي:
في مثالنا، لحذف السجل الذي يمتلك article_id بقيمة 5 مثلًا، نكتب الشيفرة البرمجية التالية:
الإستعلام عن البيانات في SQLite
يُمكن الاستعلام عن محتويات قاعدة البيانات بكل سهولة من خلال جُملة الاستعلام المشهورة في SQL والمُسماة SELECT. لقد فعلنا ذلك في بداية المقال عندما أردنا التأكد من إنشاء الجدول الذي عرَّفناه.
هنا نُضيف مجموعة أخرى من الأمثلة التي تُوضح طريقة الإستعلام عن البيانات في جدول Article بأكثر من طريقة:
فتح قاعدة البيانات واستكشافها من خلال DB Browser
لتسهيل العمل، وللتعامل مع مجموعة من قواعد البيانات واستكشاف هيكليتها والتعديل عليها وعلى بياناتها، يُمكنك استخدام الأداة DB Browser For SQLite لذلك.
اقرأ أيضًا: البرمجة البايثونية – كيف تكتب شيفرة برمجية بالبايثون بطريقة سليمة
إلى هنا ننتهي من مقالنا الذي نتمنى أن نكون وفقنا فيه. تعلمنا من خلال المقال كيفية التعامل مع قاعدة البيانات من نوع SQLite وطريقة انشاءها وتعريف جدول فيها وإجراء عمليات الإضافة والاستعلام والتعديل والحذف. نسعد بمشاركتكم وتفاعلكم من خلال الأسئلة والتعليقات ومشاركة المقال في وسائل التواصل الإجتماعي.
[…] اقرأ أيضًا: قواعد البيانات SQLite والبايثون – كيف تُنشئ قاعدة بيانات … […]