我是相当新的锂PHP框架但我知道如何使用基本的数据库抽象方法。我正在使用一个插件来构建菜单树,它工作的很好,虽然我想使用Lithium的抽象层来实现这些功能。我被困在此:锂框架MySQL的原始查询
public function get_menuItems($menu_id) {
// retrieve the left and right value of the $root node
$result = $this->database->query("SELECT * FROM ".$this->tbl_menu_items." WHERE menu_id = '$menu_id'");
if ($this->database->num_rows($result)) {
$right = array();
$result = $this->database->query("SELECT node.title, node.type, node.class_name, node.content, node.id AS id, node.lft AS lft, node.rgt AS rgt, (COUNT(parent.title) - 1) AS depth FROM ".$this->tbl_menu_items." AS node CROSS JOIN ".$this->tbl_menu_items." AS parent WHERE node.menu_id = '$menu_id' AND parent.menu_id = '$menu_id' AND node.lft BETWEEN parent.lft AND parent.rgt GROUP BY node.id ORDER BY node.lft");
$tree = array();
while ($row = mysql_fetch_assoc($result)) {
$tree[] = $row;
}
} else {
$tree = false;
}
return $tree;
}
更是如此$result
部分。我不知道锂是如何处理所有“AS”和什么的。我尝试了几种不同的方式来执行查询,但没有运气。
任何帮助将不胜感激,我希望我解释的不够好。
这是一个模型方法? – Oerd
这是由模型处理,是的。我不知道如何请求字符串来使用Lithium的抽象层。 – keithp