我有一个项目列表,每个项目都有一个类别代码:
id | name | category_code
---+------------+--------------
11 | 'Cookies' | '43040'
53 | 'Potatoes' | '43100'
这些类别代码按层次结构进行工作,例如,开始43
可能意味着食物,结束04
糕点或结束10
根蔬菜。
我还有一个代码名称表,如下所示:
code | name
--------+------------------------------------
'4304' | 'Food -> Pastery'
'43040' | 'Food -> Pastery -> Cookie'
'43100' | 'Food -> Root Vegetables -> Potato'
这些代码和系统不是我设计的,所以我无法影响它。就是这样。
现在问题是,我有关键字到代码的映射,例如:
id | key | code
---+-----------+--------
22 | 'cookie' | '43040'
23 | 'pastery' | '4304'
24 | 'cake' | '43042'
我需要根据这些关键字执行搜索。到目前为止我尝试了什么:
SELECT item.id, item.name, category.code, category.name
FROM item
LEFT JOIN category ON category.code = item.category_code
LEFT JOIN keyword ON keyword.code = category.code
WHERE LOWER(keyword.key) = ANY(ARRAY['pastery', 'root']);
但问题显示在中间,例如JOIN category ON category.code = item.category_code
,因为项目始终具有长度为5的完整代码,但代码的主要类别包括4304
和与之匹配的关键字。
我需要与LIKE
和%
进行联接,理想情况如下:
SELECT item.id, item.name, category.code, category.name
FROM item
LEFT JOIN category ON (category.code + '%') LIKE item.category_code
LEFT JOIN keyword ON keyword.code = category.code
WHERE LOWER(keyword.key) = ANY(ARRAY['pastery', 'root']);
但显然不支持(category.code + '%')
。我怎样才能以其他方式实现这一目标?
答案 0 :(得分:2)
我认为这就是你想要的。 like
的顺序错误:
SELECT i.id, i.name, c.code, c.name
FROM item i LEFT JOIN
category c
ON i.category_code like c.code || '%' LEFT JOIN
keyword k
ON k.code = c.code
WHERE LOWER(keyword.key) = ANY(ARRAY['pastery', 'root']);