首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >golang/pq:"pq:函数uniq(integer[])不存在“

golang/pq:"pq:函数uniq(integer[])不存在“
EN

Stack Overflow用户
提问于 2022-09-26 02:21:57
回答 1查看 53关注 0票数 1

这是我的代码(杜松子酒很好用)

代码语言:javascript
复制
query :=`
UPDATE posts SET liked_by = uniq(array_append(liked_by, $1))
WHERE id = $2
RETURNING liked_by`

return p.DB.Exec(query, userID, post.ID)

我所犯的错误

代码语言:javascript
复制
pq: function uniq(integer[]) does not exist

没有uniq(),我的代码工作得很好。但是数组采用的是重复值。我想确保我的数组只包含唯一的值。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-09-26 03:05:41

问题在于您的SQL (不是Go或lib/pq);您可以通过运行以下SQL来复制这个问题:

代码语言:javascript
复制
select uniq('{1,2,3,4}'::integer[])

有关潜在解决方案的讨论,请参见此this question,最简单的可能是:

代码语言:javascript
复制
select array_agg(distinct x) from unnest(array_append('{1,2,3,4}'::integer[], 4)) t(x)

将其集成到您的代码中可以得到如下(未经测试的!):

代码语言:javascript
复制
query :=`
UPDATE posts SET 
liked_by = (select array_agg(distinct x) from unnest(array_append(liked_by, $1)) t(x))
WHERE id = $2
RETURNING liked_by
`
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73849107

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档