این مقاله یکی از قسمتهای سلسله مقالاتی برای آشنایی و آموزش زبان پایتون است. این مجموع پیش از این در ماهنامه شبکه منتشر شده اما به سایت جدید منتقل نشده بود. با توجه به اهمیت موضوع و درخواستهای مکرر خوانندگان، این مجموعه را به سایت مجله اضافه میکنیم و امیدواریم که مورد توجه علاقمندان قرار بگیرد.
برای مطالعه قسمتهای قبلی سلسله مقالات آموزش زبان برنامهنویسی پایتون اینجا کلیک کنید
یک داستان
روزی روزگاری بود که دنیا بهوسیله کاغذ ادارهمیشد. کاغذ، کاغذ و باز هم کاغذ. انسانها مجبور بودند، به فکر ایجاد مکانهای مناسبی برای نگهداری کاغذها باشند. این مکانها را بایگانی مینامیدند و بایگانی کسبوکارهای بزرگ برای ذخیره تمام کاغذها، معمولاً چندین اتاق را اشغال میکرد. در هر بایگانی قفسهها و کمدهایی وجود داشت که آنها نیز به نوبه خود پر از پوشههای مختلف بودند. هر یک از این پوشهها کاغذهای مربوط به یک موضوع خاص را نگهداری میکردند. اما پس از مدتی، ظرفیت همه آنها به اتمام میرسید یا در اثر مرور زمان و باز و بسته شدن زیاد فرسوده شده و ازهم میپاشیدند. استفاده درست از این سیستم بایگانی نیازمند مدارک دانشگاهی بود و گاه یافتن کل پروندهها و کاغذهای مربوط به یک موضوع به چندین روز زمان نیاز داشت. کسبوکارها و سازمانها از این وضعیت در عذاب بودند و آن دوران، دورانی تاریک در تاریخ بشریت محسوب میشد!
ناگهان روزی، فرشتهای دوستداشتنی با بالهایی طلایی از بلندای کوهی ظاهر شد. نام او «سیکوئل» بود. فرشته ادعا کرد، میتواند مشکل كلنجار رفتن با این قفسهها و پوشهها را حلکند، البته، به شرطی که مردم به او و کامپیوترها اعتماد کنند. او این جادوی جدید را «پایگاه داده» نامید و گفت که پایگاه داده میتواند جایگزین تمام آن سیستمهای بایگانی شود.
اما استفاده از این جادوی جدید، پیشنیازهایی داشت. مردم باید زبان جدیدی را میآموختند. البته، این زبان بسیار شبیه زبان عادی مردم بود و بیشتر به نوع متفاوتی از جملهبندی نیاز داشت و افراد باید پیش از به کار بردن این جملههاي جادویی به دقت فکر میکردند. آنها باید ابتدا طرحی از ارتباط میان دادهها و اطلاعات خود ترسیم میکردند. برخی از مردم حرفهای او را پذیرفتند و زندگی برای آنها بسیار لذتبخش و ساده شد و دیگرانی که او را به سخره گرفتند، در میان کوههای کاغذ مدفون شدند. پایان!
شروع
اگرچه این داستان چندان واقعی نبود، اما استفاده از پایگاههای داده و SQL (بخوانید سیکوئل) زندگی ما را سادهتر خواهد کرد. پایگاههای داده همانند قفسههای بایگانی داستان بالا هستند. در این پایگاههای داده، جدولها نقش پوشهها را بازی میکنند و هر رکورد یا سطر این جدولها در واقع حکم برگههای کاغذ در بایگانیهای سنتی را دارند. هر تکه از اطلاعات یک فیلد نامیدهمیشود. برای کار با این سیستم ما از SQL (سرنام Structured Query language) یا «زبان پرسوجوی ساختیافته» استفادهمیکنیم. اگرچه این زبان از ابتدا برای سادهکردن کار با پایگاههای داده طراحیشده است، اما عبارتهاي مورد استفاده در آن میتوانند بسیار پیچیده و طولانی شوند.
برای شروع بیایید به دستور پخت غذاهای مختلف فکر کنیم. این دستورهای پخت به فرمهای گوناگون و در محلهای مختلف نظیر کتابهایآشپزی، مجلهها، بستهبندی مواد غذایی و جاهای متنوع دیگر به چشم میخورند. اگرچه ظاهر آنها ممکن است با هم متفاوت باشد، اما قالب همه آنها یکسان است. در ابتدا نام غذا آورده شده است، پس از آن فهرست مواد لازم را خواهیم داشت و در انتها روش تهیه غذا توضیح داده شده است. پایگاه داده نمونه ما برای نگهداری این دستورالعملهای پخت غذا طراحی خواهد شد. ما از قالب کلی نوشتن این دستورالعملها برای طراحی جدولهای پایگاه داده استفاده کرده و در این قسمت مقاله پایگاهداده را ایجاد میکنیم. در قسمت بعدی کدهای مربوط به خواندن و نوشتن اطلاعات روی پایگاه داده را خواهیم نوشت. هرچند که ميتوانیم جزئیات این پایگاه داده را تا حد دلخواه افزایش دهیم، اما برای سادگی کار ما تنها از سه جدول استفاده خواهیمکرد. جدول نخست، اطلاعات ابتدایی و خام دستورالعملها را (نظیر نام غذا، تعداد افرادی که با آن غذا سیر میشوند و نویسنده دستورالعمل) در خود نگه خواهد داشت؛ جدول دوم اطلاعات مربوط به مواد لازم را در برخواهد داشت و در نهایت جدول سوم، حاوی دستورالعمل پخت غذاها خواهد بود.
ما ميتوانستیم کل پایگاه داده را با یک جدول نیز سروسامان دهیم، اما چنین جدولی بسیار بزرگ میشد و پر از اطلاعات تکراری میشد. جدولهای موردنظر ما شبیه شکل 1 خواهند بود.
همه این جدولها یک فیلد به نام pkID دارند که همان کلید اولیه منحصربهفرد است. وجود این فیلد بسیار مهم است، زیرا باعث میشود جدولهاي ما اطلاعات کاملاً تکراری نداشته باشند وهمچنين ارتباط بین آنها را فراهم میکند. این فیلد بهصورت خودکار توسط موتور SQLite پر خواهد شد. در جدول Recipes ما از این فیلد برای استخراج اطلاعات مناسب از جدولهای Instructions و Ingredients استفاده خواهیم کرد.
شکل 1- جدولهای مورد نياز و نحوه ارتباط آنها با يكديگر
جدول طرز تهیه (Instructions) به نسبت ساده است و حاوی متنهای طولانی و طرز تهیه غذاهای مختلف است. اما جدول مواد لازم (Ingredients) کمی پیچیدهتر است، زیرا که به همراه نام ماده لازم مقدار آنها نیز باید ذخیره شود.
برنامههای مورد نیاز
ابتدا مطمئن شوید، SQLite و APSW را نصب کردهاید. به خاطر داشته باشید، مخازن Canonical Partners و Independent باید در تنظیمات اوبونتو فعال شده باشند. در اینصورت برای نصب برنامههاي مورد نياز در اوبونتو کافی است دستور زیر را در خط فرمان وارد کنید:
sudo apt-get install sqlite , python-apsw
مزیت SQLite این است که این موتور پایگاه داده برای اجرا به سرورهای جداگانه نياز ندارد و به همین دلیل، برای برنامههای کوچک مناسبتر است. نکته مثبت دیگر این است که تعداد «انواع داده» یا Data Typeهای آن محدود و ساده است. این انواع عبارتند از Text (متن)، Numeric (عدد)، Blob (دادههای دودویی) و Integer Primary Key (کلیدهای اصلی که بعدها درباره آنها توضیح خواهیم داد). مواد لازم، نام غذا و طرز تهیه همه دادههايي از نوع Text خواهند بود. اما Blobها نوعی از داده است که میتواند شامل هر داده دیجیتالی نظیر عکس و... باشد كه ما در اين مثال با اين نوع كاري نخواهيم داشت. موتور SQLite بهصورت خودکار یک عدد صحيح منحصر به فرد را به انواع داده Integer Primary Key نسبت خواهد داد. کتابخانه APSW (سرنام Another Python SQLite Wrapper) نیز روشهایی ساده برای ارتباط با SQLite را فراهم خواهد آورد.
کمی SQL
پیش از شروع کار باید اندکی درباره کار با زبان SQL بیشتر بدانیم. در این زبان برای دریافت یک رکورد (یک سطر جدول) از یک پایگاه داده از دستور SELECT استفاده میکنیم. قالب اجرای این دستور به شکل زیر است:
SELECT [what] FROM [table] WHERE [constrains]
در این قالب کلی، تمام کلماتی که با حروف بزرگ نوشته شدهاند باید عیناً به همین فرم آورده شوند. عبارتهاي داخل کروشه به ترتیب تعیینکننده رکورد موردنظر (what)، جدولی یا جدولهایی که رکورد باید از آنها استخراج شود (table) و شرایط انتخاب (constrains) هستند. مثلاً اگر بخواهیم همه فیلدهای جدول دستورالعملها را بدون هیچ شرطی استخراج کنیم، باید از دستوری به فرم زیر استفاده کنیم:
SELECT * FROM Recipes
و اگر بخواهیم رکوردی را تنها براساس شماره منحصربهفرد آن (مثلاً رکوردی با شماره 2) استخراج کنیم، از عبارت زیر استفاده میکنیم:
SELECT * FROM Recipes WHERE pkID=2
یا به عنوان نمونهای دیگر اگر بخواهیم از تمام دستورالعملهای موجود فقط نام غذا و مواد لازم را استخراج کنیم، باید از دستوری به فرم زیر استفاده كنيم:
SELECT name , instructions FROM Recipes
برای درج یا افزودن رکوردی تازه در یک جدول باید از دستور INSERT INTO استفاده کنیم. قالب کلی این دستور مانند زیر است:
INSERT INTO [table name] (field list) VALUES (values to insert)
به عنوان نمونه برای واردکردن یک دستورالعمل جدید در جدول باید دستوری به فرم زیر را اجرا کرد:
INSERT INTO Recipes (name,servings,source) VALUES (“Tacos” , 4 , “Greg”)
برای پاککردن یک رکورد خاص هم میتوان از دستور DELETE با فرم زیر استفاده کرد:
DELETE FROM [table] WHERE [constrains]
کدنویسی
همانگونه كه پيشتر هم گفته شد، ما در پایگاه داده خودمان سه جدول داریم که میتوانند از طریق استفاده از فیلد recipeID در هر رکورد که خود به فیلد pkID در جدول اصلی دستورالعملها ارجاع دارد به هم مرتبط شوند و اکنون زمان آن رسیده تا کدهایی بنویسیم که پایگاهداده را ایجاد کرده، جدولها را بسازند و آنها را با دادههای نمونه پر کنند. اگرچه میتوانیم این کدها را در برنامه اصلی درج کنیم، اما ترجیح میدهیم آنها را بهصورت جداگانه بنویسیم تا بعدها نیز قابل استفاده باشند. فهرست1 را در ویرایشگر دلخواهتان وارد کرده و آن را با نام db1.py ذخیره و اجرا کنید.
در خط 1 ما ماجول apsw را import کردهایم تا بتوانیم از توابع فراهمشده توسط آن استفاده کنیم. در خط 3 یک اتصال یا کانکشن به پایگاه داده ساختهایم. این کار باعث میشود، اگر پایگاه داده موجود باشد، برنامه آن را برای اجرای عملیات بعدی باز کند و در صورتی که چنین پایگاه دادهای موجود نباشد، apsw آن را تولید خواهد کرد.
در مثال ما، چون این پایگاه داده وجود ندارد، apsw آن را در همان پوشه برنامه ایجاد خواهد کرد. پس از ایجاد پایگاه داده، ما به یک مکاننما (cursor) نیاز داریم. مکاننما شرایط و ابزار لازم را برای تعامل با پایگاه داده فراهم خواهد آورد. این مکاننما در خط 4 ایجاد شده است. پس از آن نوبت به ایجاد جدولها میرسد.
برای ایجاد جدول دستورالعملها، در خط 7 متغیری حاوي یک دستور SQL ایجاد کردهایم و پس از آن در خط بعدی این دستور را اجرا کردهایم. در خطوط بعدی سایر جدولها را نیز به همین طریق ایجاد کردهایم. پس از آن و در خطوط 21 تا 24 با دستور INSERT INTO تعدادی داده اولیه را در این جدول وارد کردهایم.
فهرست 1- كدهای ساخت نخستين پايگاه داده
فقط توجه داشته باشید که فیلد pkID بهصورت خودکار و توسط موتور SQLite پر خواهد شد. در پایگاههای داده، چون ما از نام فیلدها استفاده میکنیم، ترتیب وارد کردن آنها اهمیتی نخواهد داشت. هنگامی که ما یک داده را در جدول Recipes وارد میکنیم باید عدد pkID منحصربهفرد آن را نیز داشته باشیم تا در سایر جدولها نیز برای برقراری ارتباط از آن استفاده کنیم. این کار با دستور SQL زیر قابل انجام است:
SELECT last_insert_rowid()
اما این عملیات ساده، در برنامه ما در خطهای 27 تا 30 پیاده شده است. دلیل هم این است که ما مقادیر برگشتی جدول را از apsw دریافت میکنیم و apsw آنها را به صورت توپل به ما باز میگرداند و ما بايد عدد مورد نظر را از اين توپل استخراج كنيم. پس از بهدست آوردن pkID آخرین رکورد وارد شده از آن برای درج مقادیر سایر جدولها استفاده خواهیم کرد.
تا اینجا ما پایگاه داده و اطلاعات اولیه آن را وارد کردهایم. در قسمت بعدی، به معرفی نحوه کار با این پایگاه داده خواهیم پرداخت.
ماهنامه شبکه را از کجا تهیه کنیم؟
ماهنامه شبکه را میتوانید از کتابخانههای عمومی سراسر کشور و نیز از دکههای روزنامهفروشی تهیه نمائید.
ثبت اشتراک نسخه کاغذی ماهنامه شبکه
ثبت اشتراک نسخه آنلاین
کتاب الکترونیک +Network راهنمای شبکهها
- برای دانلود تنها کتاب کامل ترجمه فارسی +Network اینجا کلیک کنید.
کتاب الکترونیک دوره مقدماتی آموزش پایتون
- اگر قصد یادگیری برنامهنویسی را دارید ولی هیچ پیشزمینهای ندارید اینجا کلیک کنید.
نظر شما چیست؟