Searching substring in PostgreSQL

前端 未结 3 2029

I have a POstgreSQL 8.4. I have a table and i want to find a string in one row (character varying datatype) of this table using substring (character varying datatype) returned b

相关标签:
3条回答
  • 2021-01-24 02:51

    Use like any :

    SELECT  uchastki.kadnum
    FROM  uchastki
    WHERE kadnum LIKE  ANY(
       SELECT str
       FROM test
    WHERE str IS NOT NULL)
    

    Or perhaps:

    SELECT  uchastki.kadnum
    FROM  uchastki
    WHERE kadnum LIKE  ANY(
       SELECT '%' || str || '%'
       FROM test
    WHERE str IS NOT NULL)
    

    this is a nice feature, You can use different operators, for example = any (select ... ), or <> all (select...).

    0 讨论(0)
  • 2021-01-24 02:55

    (Note: This answer was written before further discussion clarified the poster's actual intentions)

    It would appear highly likely that there is more than one str in test where str IS NOT NULL. That's why more than one row is returned by the subquery used as an expression, and, thus, why the statement fails.

    Run the subquery stand-alone to see what it returns and you'll see. Perhaps you intended it to be a correlated subquery but forgot the outer column-reference? Or perhaps there's a column also called str in the outer table and you meant to write:

    SELECT  uchastki.kadnum
    FROM  uchastki
    WHERE kadnum LIKE (
    SELECT test.str
    FROM test
    WHERE uchastki.str IS NOT NULL)
    

    ?

    (Hint: Consistently using table aliases on column references helps to avoid name-clash confusion).

    0 讨论(0)
  • 2021-01-24 02:59

    I'm going to take a wild stab in the dark and assume you mean that you want to match a string Sa from table A against one or more other strings S1 .. Sn from table B to find out if any of the other strings in S1 .. Sn is a substring of Sa.

    A simple example to show what I mean (hint, hint):

    Given:

    CREATE TABLE tableA (string_a text);
    INSERT INTO tableA(string_a) VALUES 
    ('the manual is great'), ('Chicken chicken chicken'), ('bork');
    
    CREATE TABLE tableB(candidate_str text);
    INSERT INTO tableB(candidate_str) VALUES
    ('man'),('great'),('chicken');
    

    I want the result set:

    the manual is great
    chicken chicken chicken
    

    because the manual is great has man and great in it; and because chicken chicken chicken has chicken in it. There is no need to show the substring(s) that matched. bork doesn't match any substring so it is not found.

    Here's a SQLFiddle with the sample data.

    If so, shamelessly stealing @maniek's excellent suggestion, you would use:

    SELECT string_a 
    FROM tableA 
    WHERE string_a LIKE ANY (SELECT '%'||candidate_str||'%' FROM tableB);
    

    (Vote for @maniek please, I'm just illustrating how to clearly explain - I hope - what you want to achieve, sample data, etc).

    0 讨论(0)
提交回复
热议问题