首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >PostgreSQL,取消数组到值的嵌套

PostgreSQL,取消数组到值的嵌套
EN

Stack Overflow用户
提问于 2019-03-01 21:05:35
回答 2查看 518关注 0票数 1

假设我有文本输入:

星期六购买,XXX送货,地址YYY,付款方式ZZZ

请给我们报价格和库存情况。

代码语言:javascript
运行
复制
К52-1Б - 68мкф/50в
К52-1 - 100мкф/63в

如何修改此查询,使其不需要手动分行?

代码语言:javascript
运行
复制
with long_string (ls) as (values
    ('Buying on Saturday, delivery by XXX, address YYY, payment method ZZZ'),
    ('Please quote us on prices and stock availability'),
    ('К52-1Б - 68мкф/50в'),
    ('К52-1 - 100мкф/63в')
)
select products.*, matches, similarity
from products
cross join long_string
cross join lateral
(select
    (name % ls)::int as matches,
    similarity(name, ls) as similarity
) m
where matches > 0 and similarity > 0.7
order by matches desc, similarity desc;

我试过了

代码语言:javascript
运行
复制
with long_string (ls) as (
    values
        unnest(string_to_array('Buying on Saturday, delivery by XXX, address YYY, payment method ZZZ 
        Please quote us on prices and stock availability
        К52-1Б - 68мкф/50в
        К52-1 - 100мкф/63в', '\n'))
    )
select products.*, matches, similarity
....

但是有一个错误ERROR: syntax error at or near "unnest"

EN

Stack Overflow用户

发布于 2019-03-01 21:21:05

或者你可以这样做:

代码语言:javascript
运行
复制
with long_string (ls) as (
    select
         trim(regexp_split_to_table('Buying on Saturday, delivery by XXX, address YYY, payment method ZZZ
        Please quote us on prices and stock availability
        К52-1Б - 68мкф/50в
        К52-1 - 100мкф/63в', '\n'))
    )
select *
from long_string
票数 1
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54945301

复制
相关文章

相似问题

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