当前位置: 首页 > news >正文

MySQL 和 SQL Server 中的连表更新 UPDATE JOIN 写法比较

MySQL 和 SQL Server 中的连表更新 UPDATE JOIN 写法比较

  • 一、前言
    • 1. MySQL 写法
      • 1.1 解释
    • 2. SQL Server 写法
      • 2.1 解释
  • 二、总结


一、前言

在关系型数据库管理系统(RDBMS)中,使用 UPDATE 语句进行表格更新是非常常见的操作。特别是当需要根据另一个表格的数据来更新目标表格时,使用 JOIN 是一种有效的方法。本文将比较 MySQL 和 SQL Server 中使用 UPDATE JOIN 的写法,并详细说明它们的语法和用法。

1. MySQL 写法

MySQL 使用 UPDATE ... JOIN ... SET ... 语法来实现表格联接更新。以下是一个示例:

UPDATE ladder_control t1
JOIN hga_mpwh t2 ON t1.fjh = t2.mpbm
SET t1.room_number = t2.id
WHERE t1.room_number IS NULL;

1.1 解释

  • ladder_controlhga_mpwh 是两个表格。
  • UPDATE ladder_control t1 指定要更新的目标表格,并用 t1 作为别名。
  • JOIN hga_mpwh t2 ON t1.fjh = t2.mpbm 使用 INNER JOIN 将 ladder_control 表格和 hga_mpwh 表格联接,条件是 t1.fjh = t2.mpbm
  • SET t1.room_number = t2.id 指定了更新操作,将 ladder_control 表格中的 room_number 列更新为 hga_mpwh 表格中对应的 id 列。
  • WHERE t1.room_number IS NULL 是一个过滤条件,仅当 ladder_control 表格中的 room_number 为空时才执行更新操作。

2. SQL Server 写法

SQL Server 使用 UPDATE ... FROM ... SET ... WHERE ... 语法来实现表格联接更新。以下是相应的示例:

UPDATE t1
SET t1.room_number = t2.id
FROM ladder_control t1
JOIN hga_mpwh t2 ON t1.fjh = t2.mpbm
WHERE t1.room_number IS NULL;

2.1 解释

  • ladder_controlhga_mpwh 同样是两个表格。
  • UPDATE t1 指定要更新的目标表格 t1,这里不需要使用别名。
  • FROM ladder_control t1 JOIN hga_mpwh t2 ON t1.fjh = t2.mpbm 使用 INNER JOIN 将 ladder_control 表格和 hga_mpwh 表格联接,条件是 t1.fjh = t2.mpbm
  • SET t1.room_number = t2.id 指定了更新操作,将 ladder_control 表格中的 room_number 列更新为 hga_mpwh 表格中对应的 id 列。
  • WHERE t1.room_number IS NULL 是一个过滤条件,仅当 ladder_control 表格中的 room_number 为空时才执行更新操作。

二、总结

无论是在 MySQL 还是 SQL Server 中,通过使用 JOIN 可以有效地根据另一个表格的数据更新目标表格的内容。虽然两者的语法有细微差别,但基本的操作逻辑和语义是相似的。熟悉这些语法和用法将帮助你更加灵活地操作数据库,并有效地处理数据更新任务。

希望本文能够帮助你理解 MySQL 和 SQL Server 中 UPDATE JOIN 的写法和用法!

http://www.lryc.cn/news/408701.html

相关文章:

  • 手把手教你FL Studio 24.1.1.4234中文破解安装激活图文激活教程
  • 使用Spring Boot与Spire.Doc实现Word文档的多样化操作
  • 从食堂采购系统源码到成品:打造供应链采购管理平台实战详解
  • 在window将Redis注册为服务
  • PHP商城案例
  • Linux:bash在被调用时会读取哪些启动文件?
  • 帆软FineReport之替换函数
  • Redis的应用场景及类型
  • 【图像处理】不智能的目标识别
  • 《500 Lines or Less》(5)异步爬虫
  • Transformer!自注意力机制的高层级理解Attention Is All You Need!
  • 关于使用Postman在请求https网址没有响应,但是用浏览器有响应的问题解决
  • 【React 】开发环境搭建详细指南
  • 结构体笔记
  • Elasticsearch:Golang ECS 日志记录 - zerolog
  • Ip2region - 基于xdb离线库的Java IP查询工具提供给脚本调用
  • 研发管理革命:探索顶尖的工时系统选择
  • 微服务-MybatisPlus下
  • 【python_将一个列表中的几个字典改成二维列表,并删除不需要的列】
  • IDEA的pom.xml显示ignored 的解决办法
  • 2. 卷积神经网络无法绕开的神——LeNet
  • 【区块链】JavaScript连接web3钱包,实现测试网络中的 Sepolia ETH余额查询、转账功能
  • 关于珞石机器人二次开发SDK的posture函数的算法RX RY RZ纠正 C#
  • 【Three.js基础学习】17.imported-models
  • Spring Bean - xml 配置文件创建对象
  • uniapp map组件自定义markers标记点
  • Windows:批处理脚本学习
  • Dav_笔记10:Using SQL Plan Management之4
  • 通过json传递请求参数,如何处理动态参数和接口依赖
  • [240727] Qt Creator 14 发布 | AMD 推迟 Ryzen 9000芯片发布