इस डाटाबेस ERD कि मैं आवेदन में इस्तेमाल करते हैं। मैं कोहाना 3.2 का उपयोग कर रहा हूँ। मैं जो हासिल करना चाहता हूं वह वर्तमान में लॉग इन उपयोगकर्ता के लिए मेनू उत्पन्न करना है। प्रत्येक उपयोगकर्ता के पास कई भूमिकाएं हो सकती हैं, इसलिए उस उपयोगकर्ता के आधार पर मॉड्यूल के साथ पॉप्युलेट मेनू प्राप्त करना चाहिए (जो मेनू और उपयोगकर्ता के संबंध में हैं)।
मैंने कई foreach loops के माध्यम से इसे हासिल किया है। क्या ओआरएम का उपयोग करके ऐसा करना संभव है?
* तालिका 'मॉड्यूल' मेनू आइटम का प्रतिनिधित्व करता है।
संपादित करें: यह मेरा वर्तमान कोड है।
$conf_modules = Kohana::$config->load('modules');
$user_roles = $user->roles->find_all();
$result = array();
$array = array();
foreach($user_roles as $user_role)
{
$menus = $user_role->menus->find_all();
$modules = $user_role->modules->find_all();
}
foreach($menus as $menu)
{
$m = $menu->modules->find_all();
$result[]['name'] = $menu->name;
foreach ($m as $a)
{
foreach ($modules as $module)
{
if($a->name == $module->name)
{
foreach ($conf_modules as $key => $value)
{
if($module->name == $key)
{
$array = array(
'module_name' => $module->name,
'text' => $module->display_desc,
'url' => $value['url'],
);
}
}
}
}
array_push($result, $array);
}
}
पर्याप्त जानकारी नहीं है। आप किस तरह के जॉइन चाहते हैं? – biakaveron
उपयोगकर्ता के लिए मेनू/एस उत्पन्न किया जाना चाहिए। प्रत्येक मेनू में मॉड्यूल होते हैं (लेकिन केवल वे लोग जो एक ही समय में उपयोगकर्ता भूमिका और भूमिका मेनू से संबंधित होते हैं)। – dzeno
धन्यवाद। कृपया अपने "foreach loops" को दिखाएं जिन्हें आप ORM के साथ बदलना चाहते हैं – biakaveron