SQL 在部分字符串上加入 table

SQL join table on partial string

我在 Postgres 数据库中有两个表:

Table答:

**Middle_name**
John
Joe
Fred
Jim Bob
Paul-John

Table乙:

**Full_name**
Fred, Joe, Bobda
Jason, Fred, Anderson
Tom, John, Jefferson
Jackson, Jim Bob, Sager
Michael, Paul-John, Jensen

有时中间名有连字符或中间有 space。但中间名中从来没有逗号。如果是连字符或两个中间名,条目在 Table A 和 Table B 中仍然相同。

我想参加 Middle_nameFull_name 的比赛。困难的部分是连接必须只检查 Full_name 中逗号之间的值。否则它可能会意外匹配名字。

我一直在使用下面的查询,但我刚刚意识到没有什么可以阻止它意外地将中间名与名字匹配。

SELECT Full_name, Middle_name
FROM B
JOIN A
ON POSITION(Middle_name IN Full_name)>0

我想知道如何重构此查询以仅匹配中间名(假设它们都以相同的格式出现)。

使用 split_part('Fred, Joe, Bobda', ',', 2) 其中 returns 中间名 joe

SELECT Full_name, Middle_name
FROM B
JOIN A
ON split_part(B.Full_name, ',', 2)=A.Middle_name

demo for returning middle name

如果逗号后 always 恰好有一个 space,并且 everybody 都有一个像您的示例数据一样的中间名建议,space 可以只是 split_part():

中分隔符的一部分
SELECT full_name, middle_name
FROM   A
JOIN   B ON split_part(B.full_name, ', ', 2) = A.middle_name;

相关:

  • Split comma separated column data into additional columns