gpt4 book ai didi

sql - 按名字和姓氏搜索的 Postgresql 查询,我应该创建哪些索引?

转载 作者:行者123 更新时间:2023-12-05 02:48:49 27 4
gpt4 key购买 nike

我正在使用此查询按“名字和姓氏”或“姓氏和名字”进行搜索:

SELECT
"id",
"firstname",
"lastname"
FROM
"plyers"
WHERE
lower( REPLACE ( CONCAT ( lastname, firstname ), ' ', '' ) ) LIKE '%joh%'
OR
lower( REPLACE ( CONCAT ( firstname, lastname ), ' ', '' ) ) LIKE '%joh%'
ORDER BY "id" DESC

鉴于此

  1. 我正在使用 Postgresql 13

  2. 用户可以搜索“John Belushi”或“Belushi John”或“lushi”或“lushi乔

  3. 搜索文本(在本例中为 joh)始终是 lowered() 并清除每个空格:每个单词之前、期间和之后。例如。如果我写“ lushi JO ”,最终的搜索文本是:“lushijo

  4. 此查询经常用于搜索列表中的玩家以及自动完成某些选择

问题

  1. 您认为这是一个很好的查询吗?

  2. 你认为有什么方法可以避免 CONCAT(lastname,firstname)CONCAT(firstname,lastname) 吗?

  3. 我应该创建什么索引?我读到这个:https://stackoverflow.com/a/2709967/10088259但我不太明白如何使用它。

最佳答案

使用generated columns , 并在上面加上索引。

ALTER TABLE test
ADD COLUMN first_last text GENERATED ALWAYS AS (lower(REPLACE(first || last, ' ', ''))) STORED;

CREATE INDEX IF NOT EXISTS players_first_last_idx ON test USING gin (first_last gin_trgm_ops);

ALTER TABLE test
ADD COLUMN last_first text GENERATED ALWAYS AS (lower(REPLACE(last || first, ' ', ''))) STORED;

CREATE INDEX IF NOT EXISTS players_first_last_idx ON test USING gin (last_first gin_trgm_ops);

现在 WHERE 子句将能够使用索引:

SELECT
"id",
"firstname",
"lastname"
FROM
"plyers"
WHERE
first_last LIKE '%joh%'
OR
last_first LIKE '%joh%'
ORDER BY "id" DESC

LIKE 查询创建索引的很好的解释:https://niallburkley.com/blog/index-columns-for-like-in-postgres/

关于sql - 按名字和姓氏搜索的 Postgresql 查询,我应该创建哪些索引?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64295130/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com