摘要:我们可以ORDER BY parent_id = id DESC
在教义中做吗?
我们有一个Category
包含分层文章类别的数据库表。该表如下所示:
CREATE TABLE IF NOT EXISTS `Category` (
`id` int(11) NOT NULL auto_increment,
`parent_id` int(11) default NULL,
`name` varchar(255) collate utf8_unicode_ci NOT NULL,
`sort` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `IDX_FF3A7B97727ACA70` (`parent_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=22 ;
层次结构只有一层深,顶层与它们parent_id
相同id
。
我们想使用 Doctrine QueryBuilder 获取所有行(DQL 也可以),以便连续列出所有类别,类别的父级是第一个,子级紧随其后。像这样:
id parent_id sort name
-----------------------------------
1 1 1 Animals
5 1 1 Cat
10 1 3 Dog
9 1 2 Walrus
2 2 2 Fruits
13 2 3 Apple
12 2 2 Pear
11 2 1 Melon
3 3 3 Vehicles
15 3 2 Car
6 3 3 Train
14 3 1 Paraglider
使用这个本机 MySQL 查询,我们能够按照我们想要的顺序获取项目:
select * from Category order by parent_id asc, parent_id = id desc;
但是,我们不知道如何在 QueryBuilder 或 DQL 中执行此操作。问题是parent_id = id
导致 DQL 错误的排序条件:[Syntax Error] line 0, col 109: Error: Expected end of string, got '='
我们有一个解决方法,$em->createNativeQuery()
但我们真的很想找到一个合适的方法来做这个 ORM 方式。