我在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
我想知道如何重构这个查询以只匹配中间名(假设它们都以相同的格式出现)。
最佳答案
使用split_part
('Fred, Joe, Bobda', ',', 2)
返回中间名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
关于sql - SQL连接表上的部分字符串,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/55268200/