SQL Server条件连接

3
我有三个表 Table1Table2Table3。我需要对它们执行一些操作,并将结果存储在 Table4 中。

Table1:

ID       t1col2     t1col3  
``````   ``````     ``````
123      Fname1     Lname1
456      Fname2     Lname2  
789      Fname3     LnameAA  

表格2:
ID        t2col2     t2col3     t2col4
`````     ``````     ``````     ``````
122       Fname1     Lname1     String1
466       Fname2     Lname2     String2
789       Fname3     Lname3     String3  

表格3:
ID       t3col2       
``````   ``````      
122      querty     
789      asdfgh 

如何执行条件连接以检查以下条件:
  • t1col3 中搜索子字符串 AA。
  • 如果找到,则仅当 Table1IDTable2ID 相等时,将 Table1t1col3 值替换为 Table2t2col3 值。
  • 从上述结果中,在Table3中搜索匹配的 ID
  • 如果找到,则按如下所述显示 Table4 中的内容。
期望输出:

Table4:

ID         t1col2     t2col3     t2col4     t3col2  
```````    ```````    ```````    ```````    ```````  
789        Fname3     Lname3     String3    asdfgh

3
除非我漏掉了什么,否则这对我来说听起来像是一种常见的内连接。 - Sean Lange
3个回答

2

首先将它们插入到Table4中。

然后根据Table4纠正Table1。

DELETE FROM Table4;

INSERT INTO Table4 (ID, t1col2, t2col3, t2col4, t3col2)
SELECT t2.ID, t1.t1col2, t2.t2col3, t2.t2col4, t3.t3col2
FROM Table2 t2
JOIN Table1 t1 ON t1.ID = t2.ID AND t1.t1col3 LIKE '%AA%'
JOIN Table3 t3 ON t3.ID = t1.ID;

UPDATE t1
SET t1col3 = t4.t2col3
FROM Table1 t1
JOIN Table4 t4 ON t4.ID = t1.ID
WHERE t1.t1col3 != t4.t2col3;

SELECT * 
FROM Table4 
ORDER BY ID;

在这里测试 db<>fiddle (点击此处)

结果:

ID      t1col2      t2col3      t2col4      t3col2
----    --------    --------    --------    --------
789     Fname3      Lname3      String3     asdfgh

1

你能试试这个吗?

SELECT T1.ID , T1COL2, T2COL3, T2COL4, T3COL2
FROM TABLE2 AS T2
INNER JOIN TABLE1 AS T1 
  ON T2.ID = T1.ID AND T1.T1COL3 LIKE '%AA' 
INNER JOIN TABLE3 AS T3
  ON T3.ID = T2.ID

演示链接


0
Select Table1.ID, Table1.T1col2, Table2.T2col3, Table2.T2col4, Table3.T3col2
From Table1
Inner join Table2 on Table1.ID = Table2.ID AND Table1. t1col3 like%AA%Inner join Table3 on Table1.ID = Table3.ID 

抱歉,我不明白你所要求的:「如果找到,则仅在 Table1 ID 和 Table2 ID 相同时才用 Table2 的 t2col3 值替换 Table1 的 t1col3 值。」 你是想在 Table1 上更新值吗?

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接