gpt4 book ai didi

postgresql - 如何在 text[] 列数据类型上使用 in operator?

转载 作者:行者123 更新时间:2023-11-29 11:44:08 24 4
gpt4 key购买 nike

我正在尝试在 text[] 列中使用 IN 运算符。但我收到此错误消息:

错误:运算符不存在:text = text[] 提示:没有运算符匹配给定的名称和参数类型。您可能需要添加显式类型转换

是否可以在这种情况下使用 IN 运算符?如果不是,我应该使用什么?

我已经尝试转换为 json/jsonb,使用 ANY 或 @> 运算符但没有成功

可重现的例子:

CREATE TABLE visitor (name varchar(255), hobbies text[]);
CREATE TABLE hobbies(name varchar(255), id text);

INSERT INTO visitor (name, hobbies) VALUES ('sanghin', '{ida}');
INSERT INTO hobbies (name, id) VALUES ('sql', 'ida');

SELECT name FROM hobbies WHERE id IN (SELECT hobbies FROM visitor WHERE visitor.name = 'sanghin');

最佳答案

demo:db<>fiddle

SELECT name 
FROM hobbies
WHERE id IN
(SELECT unnest(hobbies) FROM visitor WHERE visitor.name = 'sanghin');

您的子查询返回一组数组。然后你试图将文本与集合的元素进行比较。因此,您正在尝试将类型 text 与类型 text[] 进行比较,但这是行不通的。取消嵌套数组将为您提供一组文本值。比较有效。

关于postgresql - 如何在 text[] 列数据类型上使用 in operator?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58391097/

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