数据库更新两张相关联的表

在SQL Server中,更新两张相关联的表是经常需要的操作,以下是一些更新两张表的不同写法示例:

假设我们有两张表 Employees 和 SalaryUpdates,我们想要根据 SalaryUpdates 中的新工资来更新 Employees 表中的工资。

  1. 使用内连接(INNER JOIN)更新

这是目前最标准的写法

sql 复制代码
UPDATE a
SET a.Salary = b.NewSalary
FROM Employees a
INNER JOIN SalaryUpdates b ON a.EmployeeID = b.EmployeeID;
  1. 使用子查询更新
    你也可以使用子查询来找出需要更新的值。
    很拗口,不知道好处在哪里。
sql 复制代码
UPDATE Employees
SET Salary = (SELECT NewSalary FROM SalaryUpdates WHERE SalaryUpdates.EmployeeID = Employees.EmployeeID)
WHERE EXISTS (
    SELECT 1 FROM SalaryUpdates WHERE SalaryUpdates.EmployeeID = Employees.EmployeeID
);
  1. 使用CASE语句更新
    如果你需要根据某些条件来决定如何更新目标表,可以使用CASE语句。
    这种写法可以适应很多场景
sql 复制代码
UPDATE Employees
SET Salary = CASE
    WHEN Salary < (SELECT AVG(Salary) FROM Employees) THEN Salary * 1.10
    WHEN Salary > (SELECT AVG(Salary) FROM Employees) THEN Salary * 0.90
    ELSE Salary
END
WHERE EXISTS (
    SELECT 1 FROM SalaryUpdates WHERE SalaryUpdates.EmployeeID = Employees.EmployeeID
);
  1. 使用事务确保数据一致性
    如果更新操作需要保证数据的一致性,可以使用事务。
    语法可以与上面的差不多,可以加入容错等功能
sql 复制代码
BEGIN TRANSACTION;

UPDATE Employees
SET Salary = (SELECT NewSalary FROM SalaryUpdates WHERE SalaryUpdates.EmployeeID = Employees.EmployeeID)
WHERE EXISTS (
    SELECT 1 FROM SalaryUpdates WHERE SalaryUpdates.EmployeeID = Employees.EmployeeID
);

-- 假设还有其他更新操作

-- ...

sql 复制代码
IF @@ERROR = 0
BEGIN
    COMMIT TRANSACTION;
    PRINT 'Updates were committed.';
END
ELSE
BEGIN
    ROLLBACK TRANSACTION;
    PRINT 'Updates were rolled back due to an error.';
END
  1. 传统的where 语句
    这种写法应该适用于多种数据库,不知道是否有人可验证?
sql 复制代码
UPDATE Employees
SET Salary = NewSalary 
FROM Employees a, SalaryUpdates b 
WHERE a.EmployeeID = b.EmployeeID

操作后,验证数据以确保更新正确无误。

相关推荐
Re.不晚19 分钟前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构
老邓计算机毕设28 分钟前
SSM智慧社区信息化服务平台4v5hv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·智慧社区、·信息化平台
麦聪聊数据1 小时前
为何通用堡垒机无法在数据库运维中实现精准风控?
数据库·sql·安全·低代码·架构
2301_790300961 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
m0_736919101 小时前
用Pandas处理时间序列数据(Time Series)
jvm·数据库·python
亓才孓1 小时前
[JDBC]PreparedStatement替代Statement
java·数据库
m0_466525292 小时前
绿盟科技风云卫AI安全能力平台成果重磅发布
大数据·数据库·人工智能·安全
爱学习的阿磊2 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
枷锁—sha2 小时前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞3 小时前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle