ساختار بانک اطلاعاتی (دیتابیس) جوملا 1.6   

از دانشنامه جوملا فارسی - مامبو فارسی
پرش به: ناوبری، جستجو

محتویات

مقدمه

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

استفاده از کلاس جدید JDatabaseQuery در جوملا 1.6

در راستای گسترش امکانات و پشتیبانی جوملا از سایر پایگاه‌های داده مانند MongoDB, MSSQL جوملا 1.6 اقدام به معرفی کلاس جدید پرس و جو (query) ساز کرده است. این کلاس به شما اجازه می‌دهد تا پرس و جوهای خود را به صورت قابل درک‌تری بنویسید.

در زیر نمونه‌ای از پرس و جو در جوملا 1.5 و جوملا 1.6 را می‌توانید ببینید :

پرس و جو در جوملا 1.5

<source lang="php"> /* (...) */

$db = JFactory::getDbo(); $db->setQuery(

'SELECT *'.
' FROM #__articles'.
' WHERE state = '.(int) $published.
'  AND catid = '.(int) $categoryId.
' ORDER BY created DESC'

); /* (...) */ </source>

پرس و جو در جوملا 1.6

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__articles')
->where('state = '.(int) $published)
->where('catid = '.(int) $categoryId)
->order('created DESC');

$db->setQuery($query); /* (...) */ </source>

تغییرات در ساختار بانک اطلاعاتی جوملا 1.6 برای نصب افزونه

یکی از مواردی که در گذشته کار گسترش دهنده‌های افزونه‌های جوملا را با مشکل مواجه می‌کرد ذخیره اطلاعات در جداول اطلاعاتی مختلف بود. اکثر گسترش دهنده‌ها ازساختار بد jos_components که کامپوننت‌های نصب شده را لیست می‌کرد آگاه بودند حال اینکه برای ماژول، قالب و سایر بخش‌ها حتی این لیست هم وجود نداشت. این مشکل در جوملا 1.6 با جدول jos_extensions حل شد. جدول فوق جایگزین جداول jos_components و jos_plugins شده و در آن اطلاعات تمامی افزونه‌هایی که در جوملا نصب می‌شوند نگهداری می‌شود. در ادامه چند پرس و جوی نمونه را برای آشنایی بیشتر شما با ساختار این جدول بر اساس کلاس جدید JDatabaseQuery نوشته‌ایم:

اطلاعات در مورد کامپوننت‌ها

لیست همه کامپوننت‌های جوملا 1.6

<source lang="php"> /* (...) */

$db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('components'))
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با یک کامپوننت خاص

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('components'))
->where('element = '.$db->quote('com_content'))
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با زبان‌ها

لیست همه زبان‌های نصب شده در جوملا 1.6

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('language'))

// Use client_id = 1 for backend packs

->where('client_id = 0')
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با یک زبان خاص

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('language'))
->where('element = '.$db->quote('en-GB'))

// Use client_id = 1 for backend packs

->where('client_id = 0)
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با کتابخانه‌ها

لیست همه کتابخانه‌های جوملا 1.6

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('library'))
->order('ordering');

/* (...) */ </source>

اطلاعات در مورد یک کتابخانه خاص

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('library'))
->where('element = '.$db->quote('simplepie'))
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با ماژول‌ها

لیست همه ماژول‌های بخش کاربری جوملا 1.6

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('modules'))

// Use client_id = 1 for backend modules.

->where('client_id = 0')
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با یک ماژول خاص

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('module'))
->where('element = '.$db->quote('mod_menu'))

// Use client_id = 1 for backend modules.

->where('client_id = 0');
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با پلاگین‌ها

لیست همه پلاگین‌های جوملا 1.6

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('plugin'))
->where('folder = '.$db->quote('system'))
->order('ordering');

اطلاعات در رابطه با یک پلاگین خاص

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('plugin'))
->where('folder = '.$db->quote('system'))
->where('element = '.$db->quote('redirect'))
->order('ordering');

/* (...) */ </source>

اطلاعات در رابطه با قالب‌ها

لیست همه قالب‌های نصب شده بخش کاربری جوملا 1.6

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('template'))

// Use client_id = 1 for backend templates.

->where('client_id = 0')
->order('ordering');

/* (...) */ </source>

اطلاعات در مورد یک قالب خاص

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('*')

->from('#__extensions')
->where('type = '.$db->quote('template'))
->where('element = '.$db->quote('com_content'))

// Use client_id = 1 for backend templates.

->where('client_id = 0')
->order('ordering');

/* (...) */ </source>

تغییرات در ساختار بانک اطلاعاتی جوملا 1.6 برای کاربران و گروه‌های کاربری

در راستای ایجاد امکان کنترل سطح دسترسی در جوملا 1.6 تغییراتی در ساختار بانک اطلاعاتی صورت گرفت. از مامبو 4.5.0 تا جوملا 1.5 این بخش بر اساس phpGACL کار می‌کرد. وقتی این موضوع را با عمق بیشتری بررسی کردیم متوجه شدیم که باید روند را تغییر دهیم. در جوملا 1.6 دسترسی "مشاهده" و "فعالیت" را جدا کردیم. در این نسخه از جدول‌های jos_assets, jos_users, jos_usergroups, jos_usergroup_map, jos_viewlevels برای بخش جدید کنترل سطح دسترسی استفاده شده است. برای مشاهده تغییرات در این رابطه پرس و جوی زیر را ببینید و مقایسه کنید.

گروه کاربری در جوملا 1.5

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $db->setQuery(

'SELECT g.value AS group_name'.
' FROM #__core_acl_groups AS g'.
' LEFT JOIN jos_core_acl_groups_aro_map AS grpMap ON grpMap.group_id = g.id'.
' LEFT JOIN jos_core_acl_aro AS aro ON aro.id = grpMap.aro_id'.
' WHERE aro.value = '.(int) $userId

); /* (...) */ </source>

گروه کاربری در جوملا 1.6

<source lang="php"> /* (...) */ $db = JFactory::getDbo(); $query = $db->getQuery(true); $query->select('g.title AS group_name')

->from('#__usergroups AS g')
->leftJoin('jos_user_usergroup_map AS map ON map.group_id = g.id')
->where('map.user_id = '.(int) $userId)

$db->setQuery($query); /* (...) */ </source>



نویسنده: محسن فیروزمندان

8.pngاستفاده از مطالب دانشنامه جوملا فارسی - مامبو فارسی با ذکر منبع ( دانشنامه جوملا فارسی ) و لینک مستقیم به http://docs.joomlafarsi.com بلامانع است.