MySQL加入问题

时间:2009-12-12 10:21:16

标签: mysql join

我想加入一个页面表和菜单表。

CREATE TABLE IF NOT EXISTS `pages` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL DEFAULT '',
  `keywords` varchar(255) NOT NULL DEFAULT '',
  `description` varchar(255) NOT NULL DEFAULT '',
  `path` varchar(255) NOT NULL DEFAULT '',
  `content` text NOT NULL,
  `status` enum('active','inactive') NOT NULL DEFAULT 'active',
  `category_id` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=21 ;



CREATE TABLE IF NOT EXISTS `menus` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `shortdesc` varchar(255) NOT NULL,
  `page_id` varchar(60) NOT NULL,
  `status` enum('active','inactive') NOT NULL,
  `parentid` int(11) NOT NULL,
  `order` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=79 ;

我在使用以下SQL时遇到错误。

function generateTree(&$tree, $parentid = 0) {
$res = $this->db->query('SELECT M.*, P.name AS PageName
    WHERE M.parentid = $parentid
    ORDER BY M.order asc, M.parentid asc
    FROM menus AS M
    LEFT JOIN pages AS P
    ON P.id = M.page_id');
...
...

你能说出我做错了吗?

提前致谢。

1 个答案:

答案 0 :(得分:1)

你的SQL语法混淆了

$res = $this->db->query('
SELECT 
 M.*, P.name AS PageName
FROM
 menus AS M 
 LEFT JOIN pages AS P ON P.id = M.page_id
WHERE 
 M.parentid = $parentid
ORDER BY 
 M.order asc, M.parentid asc
');
顺便说一下,你应该在SQL字符串中使用变量。改为使用参数化查询(mysyqli *)。