如何在 joomla 中编写此查询
how to write this query in joomla
我想获取 child 类别的所有 parent 类别标题
所以在 mysql 我可以用这个代码
SELECT T2.id, T2.title
FROM (
SELECT
@r AS _id,
(SELECT @r := parent_id FROM `up8te_categories` WHERE id = _id) AS parent_id,
@l := @l + 1 AS lvl
FROM
(SELECT @r := 8, @l := 0) vars,
`up8te_categories` h
WHERE @r <> 0) T1
JOIN `up8te_categories` T2
ON T1._id = T2.id
ORDER BY T1.lvl DESC
但在 joomla 中我们有 API 用于查询
我想知道如何在 joomla 中使用它?
我知道是这样的:
$db = JFactory::getDbo();
$query = $db->getQuery(true);
$query->select($db->quoteName(array('title')))
->from(......??????......)
->join('INNER', $db->quoteName('#__categories', 'T2') . ' ON (T1._id = T2.id)')
->order('T1.lvl DESC');
$db->setQuery($query);
$rows = $db->loadObjectList();
但我不知道如何设置从我想再次 select 开始..
我能做什么?
亲切的问候。
我更喜欢将 $query 作为字符串使用,如下所示:
$db = JFactory::getDbo();
$query = 'SELECT T2.id, T2.title
FROM (
SELECT
@r AS _id,
(SELECT @r := parent_id FROM #__categories WHERE id = _id) AS parent_id,
@l := @l + 1 AS lvl
FROM
(SELECT @r := 8, @l := 0) vars,
#__categories h
WHERE @r <> 0) T1
JOIN #__categories T2
ON T1._id = T2.id
ORDER BY T1.lvl DESC';
$db->setQuery($query);
我想获取 child 类别的所有 parent 类别标题 所以在 mysql 我可以用这个代码
SELECT T2.id, T2.title
FROM (
SELECT
@r AS _id,
(SELECT @r := parent_id FROM `up8te_categories` WHERE id = _id) AS parent_id,
@l := @l + 1 AS lvl
FROM
(SELECT @r := 8, @l := 0) vars,
`up8te_categories` h
WHERE @r <> 0) T1
JOIN `up8te_categories` T2
ON T1._id = T2.id
ORDER BY T1.lvl DESC
但在 joomla 中我们有 API 用于查询 我想知道如何在 joomla 中使用它?
我知道是这样的:
$db = JFactory::getDbo();
$query = $db->getQuery(true);
$query->select($db->quoteName(array('title')))
->from(......??????......)
->join('INNER', $db->quoteName('#__categories', 'T2') . ' ON (T1._id = T2.id)')
->order('T1.lvl DESC');
$db->setQuery($query);
$rows = $db->loadObjectList();
但我不知道如何设置从我想再次 select 开始..
我能做什么?
亲切的问候。
我更喜欢将 $query 作为字符串使用,如下所示:
$db = JFactory::getDbo();
$query = 'SELECT T2.id, T2.title
FROM (
SELECT
@r AS _id,
(SELECT @r := parent_id FROM #__categories WHERE id = _id) AS parent_id,
@l := @l + 1 AS lvl
FROM
(SELECT @r := 8, @l := 0) vars,
#__categories h
WHERE @r <> 0) T1
JOIN #__categories T2
ON T1._id = T2.id
ORDER BY T1.lvl DESC';
$db->setQuery($query);