ذخیره آرایه با php در پایگاه داده

پایگاه‌داده‌های رابطه‌ای به صورت عمومی امکان ذخیره‌سازی داده‌های چند بعدی را ندارند و برای ذخیره‌سازی این اطلاعات می‌بایست از ردیف‌های متعدد یک یا چند جدول استفاده شود. ولی همیشه این روش برای ما مناسب نیست و ممکن است بخواهیم اطلاعات یک آرایه‌ی دو یا یا چندبعدی را در یک سلول ذخیره کنیم.

انجام این کار به صورت سنتی با استفاده از Serialization امکان‌پذیر است.

php

Serialization چیست ؟

تبدیل داده‌های ساخت‌یافته مثل آرایه‌ها یا اشیاء به یک رشته را Serialization می‌نامیم. برای انجام این کار روش‌ها و ابزارهای متعددی وجود دارد. زبان php برای انجام این کار سه ابزار عمده در اختیار ما قرار می‌دهد:

  1. تابع serialize که مخصوص به زبان php است.
  2. تابع json_encode که خروجی JSON و قابل پردازش توسط عمده‌ی زبان‌های برنامه‌نویسی ایجاد می‌کند.
  3. تبدیل داده‌ها به XML که بسته به دستورات و افزونه‌های استفاده شده می‌تواند ساده یا پیچیده باشد.

در این نوشته به دو روش اول که کاربرد بیشتری دارد و ساده‌تر است می‌پردازیم.

استفاده از تابع serialize

این تابع مخصوص به زبان php است و اطلاعات چندبعدی شامل آرایه‌ها و اشیاء مختلف را به رشته‌های قابل ذخیره در پایگاه داده تبدیل می‌کند. استفاده از این روش البته معایبی نیز به همراه دارد. مهم‌ترین اشکال استفاده از این تابع، عدم پشتیبانی زبان‌های برنامه‌نویسی دیگر و سیستم‌های پایگاه داده از پردازش این اطلاعات است. برای مثال اگر نیاز باشد تا به طور مستقیم، داده‌ها را جستجو یا تغییر دهیم، با مشکلات زیادی روبرو خواهیم شد.

ساده‌ترین مثال استفاده از این روش به صورت زیر است:

نمونه کد بالا یک آرایه‌ی تک بعدی را به یک رشته‌ی قابل ذخیره‌سازی در پایگاه داده تبدیل می‌کند. لازم به ذکر است که ذخیره‌سازی اطلاعات با حجم زیاد به صورت رشته در پایگاه داده خود می‌تواند باعث مشکلاتی شود.

خروجی مثال بالا به صورت زیر است:

برای تبدیل مجدد این رشته به آرایه به شکل زیر عمل می‌کنیم:

تبدیل آرایه‌ها با استفاده از این روش مشکل فنی خاصی به دنبال ندارد ولی برخی از اشیاء که داده‌های خارجی را نگهداری می‌کنند یا پر کردن اعضای آن‌ها به دستورالعمل‌های خاصی نیازمند است، می‌تواند با چالش‌هایی همراه باشد.

همچنین فراخوانی این تابع روی اطلاعاتی که از بیرون به اسکریپت ارسال شده‌اند می‌تواند خطرات امنیتی به دنبال داشته باشد، چون امکان اجرای کدهای php در هنگام ساخت مجدد کلاس بر اساس اطلاعات ناایمن وجود دارد.

استفاده از توابع JSON

توابع JSON در اغلب زبان‌های برنامه‌نویسی قابل استفاده هستند. همچنین سیستم‌های پایگاه داده مثل MySQL دستوراتی برای کنترل بیشتر روی سلول‌های رشته‌های حاوی JSON در اختیار شما قرار می‌دهند. به طور کلی استفاده از JSON به روش‌های دیگر برتری دارد مگر اینکه موانع فنی یا دلایل ویژه‌ای برای استفاده از روش‌های دیگر وجود داشته باشد.

استفاده از JSON به طور ساده در قطعه کد زیر قابل مشاهده است:

استفاده‌ی بهینه از توابع JSON و تنظیمات قابل ارسال به هر یک از توابع ورودی و خروجی نیز می‌تواند به بررسی‌های بیشتر وابسته باشد. برای مثال چون در این مثال قصد دارید، اطلاعات را در پایگاه داده ذخیره کنیم که از حروف یونیکد پشتیبانی می‌کند، برای کاهش حجم کدهای JSON از پارامتر «JSON_UNESCAPED_UNICODE» استفاده کردیم. این پارامتر باعث می‌شود تا حروف یونیکد به کدهای عددی تبدیل نشوند که هر یک چند برابر حروف عادی فضا اشغال می‌کنند. اگر هدف ذخیره‌سازی یا ارسال این اطلاعات در محلی باشد که از حروف یونیکد پشتیبانی نمی‌کند، تنظیمات دیگری مورد نیاز خواهد بود.

 

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *