簡體   English   中英

PostgreSQL,將數組嵌套到值中

[英]PostgreSQL, unnest array into values

假設我有文字輸入:

周六購買,XXX交貨,地址YYY,付款方式ZZZ

請報價和現貨供應

К52-1Б - 68мкф/50в
К52-1 - 100мкф/63в

如何修改此查詢,因此不需要手動拆分行?

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;

我試過了

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"

如果這只是解析字符串,則:

with long_string (ls) as (
    select unnest(string_to_array(str, E'\n'))
    from (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в')
         ) v(str)
    )
select ls
from long_string;

是db <>小提琴。

或者您可以這樣做:

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM