【发布时间】:2019-03-20 18:52:59
【问题描述】:
我在 Postgres 数据库中有两个表:
表 A:
**Middle_name**
John
Joe
Fred
Jim Bob
Paul-John
表 B:
**Full_name**
Fred, Joe, Bobda
Jason, Fred, Anderson
Tom, John, Jefferson
Jackson, Jim Bob, Sager
Michael, Paul-John, Jensen
有时中间名带有连字符或中间有空格。但是中间名中从来没有逗号。如果是连字符或两个中间名,则表 A 和表 B 中的条目仍然相同。
我想加入Middle_name 和Full_name 上的表格。困难的部分是连接必须只检查Full_name 中逗号之间的值。否则可能会意外匹配名字。
我一直在使用下面的查询,但我刚刚意识到没有什么可以阻止它意外地将中间名与名字匹配。
SELECT Full_name, Middle_name
FROM B
JOIN A
ON POSITION(Middle_name IN Full_name)>0
我想知道如何重构此查询以仅匹配中间名(假设它们都以相同的格式出现)。
【问题讨论】:
-
我没有中间名。只是说...
标签: sql postgresql string-parsing