【Sql Server】Update中的From语句,以及常见更新操作方式

news2025/1/11 14:27:13

欢迎来到《小5讲堂》,大家好,我是全栈小5。
这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解,
特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 前言
  • 常规更新
    • 分组查最大值
    • 编号更新
    • 查询更新
  • 常见更新方式
    • UPDATE 语句
    • 使用子查询更新数据
    • 使用 JOIN 更新数据
    • 使用临时表进行更新
    • 使用事务进行更新
    • 使用触发器进行更新
  • 常见场景
    • 批量修改数据场景
    • 需要注意的事项
  • 文章推荐

前言

最近在做数据修改,有时候太久没写sql语句,突然想通过子查询的方式去批量更新数据的时候,
还是有点不知所措,那就一步一步来吧,也写篇文章梳理和总结下,毕竟也是基本的操作加深印象。
上篇文章已经介绍分组查询方法,这篇文章将通过分析update更新有那些语句和方式方法。

常规更新

基于上篇文章的表数据,先查询同城市同区域同姓名存在等于2条的记录,
并将最大编号的那条记录代理商更新为"张三2",城市区县代理商三者分组查询

分组查最大值

select * from test_name
select city_name,area_name,agent_name,max(id) maxId
from test_name 
group by city_name,area_name,agent_name
having count(1)>1

在这里插入图片描述

编号更新

不管任何时候,进行更新操作,一定更要三思,问问自己加了where条件没有,切勿大意经验之谈

update test_name set agent_name='张三2' where id=2
select * from test_name

在这里插入图片描述

查询更新

通过子查询方式更新数据,将上面的数据更新还原,进行下面更新操作

update test_name set agent_name='张三_'+convert(varchar(50),t.maxId)
from(
    select city_name,area_name,agent_name,max(id) maxId
    from test_name 
    group by city_name,area_name,agent_name
    having count(1)>1
) t 
where test_name.id=t.maxId

select * from test_name

在这里插入图片描述

常见更新方式

在 SQL Server 中,更新数据是数据库管理中常见且重要的操作之一。

UPDATE 语句

使用 UPDATE 语句可以直接更新表中的数据。语法如下:
UPDATE table_name
SET column1 = value1, column2 = value2, …
WHERE condition;

这里的 table_name 是你要更新的表名,column1 = value1, column2 = value2, … 是需要更新的列和对应的值,WHERE condition 是更新的条件。

使用子查询更新数据

如前面提到的,可以使用子查询来更新表中的数据,例如将一个表中的列更新为另一个表中的计算结果。

使用 JOIN 更新数据

通过 JOIN 操作,可以根据两个或多个表之间的关系来更新数据。例如,可以使用 INNER JOIN、LEFT JOIN 或其他类型的 JOIN 来更新匹配的数据。

使用临时表进行更新

有时候,可以先将需要更新的数据存储在临时表中,然后再通过 JOIN 或其他方式将其更新回主表。

使用事务进行更新

在更新数据时,尤其是涉及多个表或复杂逻辑时,使用事务可以确保数据的一致性。通过启动事务、提交或回滚事务,可以有效地管理更新操作。

使用触发器进行更新

在某些情况下,可能希望在更新某个表时自动触发另一些操作,这时可以使用触发器来实现。
触发器可以在更新、插入或删除数据时自动执行相关的操作。

无论使用哪种更新数据的方式,都需要谨慎操作,确保更新的数据准确无误。在进行重要的数据更新操作前,务必备份数据以防止意外情况发生。经验之谈,慎之又慎。

常见场景

在 SQL Server 中,批量修改数据是常见的需求之一,特别是在需要同时更新多行记录时。

批量修改数据场景

1.大批量数据更新
当需要更新大量数据时,采用批量更新的方式可以提高效率,减少单独更新每行记录的开销。

2.根据条件批量更新
根据特定条件选择需要更新的数据,可以使用 WHERE 子句来筛选符合条件的记录进行批量更新。

3.使用临时表批量更新
将需要更新的数据存储在临时表中,然后利用临时表与目标表进行 JOIN 更新数据。

4.跨表关联批量更新
在更新数据时,可能需要跨表关联更新数据,可以使用 JOIN 操作或子查询来实现。

需要注意的事项

1.事务处理
在批量更新数据时,尤其是跨表更新或更新涉及到重要数据时,建议使用事务进行处理,以确保数据的一致性并能够回滚到之前的状态。

2.性能优化
在进行批量更新时,要注意数据库性能,避免锁表或对性能造成影响。可以考虑分批次更新数据、创建索引以提升查询效率等方式进行性能优化。

3.备份数据
在进行批量更新操作前,务必备份数据,以防操作失误或更新错误导致数据丢失。

4.避免影响其他操作
在更新大量数据时,可能会占用数据库资源,影响其他操作。建议在低负载时段执行批量更新操作,以减少对其他操作的影响。

5.注意更新条件
确保更新操作的条件准确,避免将不需要更新的数据一并更新。

文章推荐

【Sql server】假设有三个字段a,b,c 以a和b分组,如何查询a和b唯一,但是c不同的记录

【Sql Server】新手一分钟看懂在已有表基础上修改字段默认值和数据类型

【数据库】Sql Server数据迁移,处理自增字段赋值

【数据类型】C#和Sql Server、Mysql、Oracle等常见数据库的数据类型对应关系

总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1480642.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux信号【保存-处理】

目录 前言: 1、再次认识信号 1.1、概念 1.2、感性理解 1.3、在内核中的表示 1.4、sigset_t 信号集 2、信号集操作函数 2.1、增删改查 2.2、sigprocmask 2.3、sigpending 3.信号的处理机制 3.1处理情况 3.2合适时机 4用户态与内核态 4.1、概念 4.2、…

蓝桥杯练习系统(算法训练)ALGO-995 24点

资源限制 内存限制:256.0MB C/C时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s 问题描述 24点游戏是一个非常有意思的游戏,很流行,玩法很简单:给你4张牌,每张牌上有数…

【python】json转成成yaml中文编码异常显示成:\u5317\u4EAC\u8DEF123\u53F7

姊妹篇:【python】json转成成yaml json数据 {"name": "张三","age": 30,"isMarried": false,"children": [{"name": "小王","age": 5},{"name": "小李",&qu…

mysql查询用户操作日志

mysql查询用户操作日志 说明一、概述二、配置 说明 更新时间:2024/03/01 16:39 本文仅为记录学习轨迹,如有侵权,联系删除 一、概述 先简单介绍一下general log,这个日志主要的作用是记录MySQL所有的SQL语句,不管是查询语句&am…

每日一题 2369

2369. 检查数组是否存在有效划分 题目描述: 给你一个下标从 0 开始的整数数组 nums ,你必须将数组划分为一个或多个 连续 子数组。 如果获得的这些子数组中每个都能满足下述条件 之一 ,则可以称其为数组的一种 有效 划分: 子数…

Python实现PPT演示文稿中视频的添加、替换及提取

无论是在教室、会议室还是虚拟会议中,PowerPoint 演示文稿都已成为一种无处不在的工具,用于提供具有影响力的可视化内容。PowerPoint 提供了一系列增强演示的功能,在其中加入视频的功能可以大大提升整体体验。视频可以传达复杂的概念、演示产…

unity后期

unity|后处理篇 前言一、Post-Processing 1、 Post-Processing的使用2、Post-Processing后处理效果 抗锯齿①、Ambient Occlusion 环境光遮蔽②、Auto Exposure 自动曝光③、Bloom 辉光/泛光④、Chromatic Aberration | 色差⑤、Color Grading 色调/颜色分级⑥、Depth Of Fiel…

每次提出一个bug都让测试重现,描述得那么清楚,自己操作下不会吗?

一说到测试和开发的关系,你一定会想到一个词“冤家”。 开发的工作就是按照PM的设计将产品最终造出来,而测试则是在开发已完成的工作里纠错。so,测试的工作会让开发很不爽,人之常情,谁都不喜欢自己的劳动成果被别人挑…

解析馆藏文物预防性保护:监测平台与数据传输系统概述

1)文物预防性保护监测平台概述 文物预防性保护监测与调控系统是文物环境监测必不可少的关键组成部分之一,在项目实施中,将充分利用前沿物联网技术,如无线网络、低功耗设计、高精度传感器来实现文物保存环境的实时监测与数据分析。此外,还将通…

uniapp 安装安卓、IOS模拟器并调试

一、安装Android模拟器并调试 1.下载并安装Android Studio。 2.创建简单project。 3.安装模拟器。 完成安卓模拟器的安装。 4.启动模拟器。 5.hbuilderx选择模拟器、运行。 点击刷新按钮后出现模拟器,勾选并运行。 6.调试。 在 HBuilderX 中,项目启…

GCN 翻译 - 1

ABSTRACT 我们提出了一种可扩展的在以图结构为基础的数据上的半监督学习,这种方法直接作用在图数据上,可以看做是卷积神经网络的变种。我们选择了图谱理论里面的一阶近似作为我们的卷积结构。我们的模型能够随着图的规模线性伸缩,并且隐藏层…

将镜像上传到私有镜像仓库Harbor

首先你需要安装Harbor服务: https://blog.csdn.net/qq_50247813/article/details/136388229 客户端已经安装docker: https://docs.docker.com/engine/install/centos/ 在docker客户端登录 Harbor 我的Harbor 服务器地址: 192.168.44.161 账号…

抖店无货源违规频发,不能入驻?这个是真的吗?

我是电商珠珠 还没有踏入抖店这个电商行业的新手,单从别人的口中,听说了抖店无货源特别容易违规,还会被扣除全部的保证金,得不偿失之类的话。有的还专门劝诫新手不要做抖店,做了就会亏本之类的话,这搞得人…

首个美国大学宣布与OpenAI建立合作伙伴关系!全美本科AI强校大盘点!

美国亚利桑那州立大学(Arizona State University )在其官网宣布与OpenAI建立合作伙伴关系,该校也由此成为第一家与OpenAI合作的高等教育机构。 这一合作将ChatGPT Enterprise的先进功能引入亚利桑那州立大学,使教职员工能够探索生…

【Java】UWB高精度工业定位系统项目源代码

目录 UWB技术原理 优势 1. 高精度: 2. 抗干扰能力强: 3. 定位范围广: 4. 实时性强: 应用前景 定位系统源码功能介绍 实时定位: 轨迹回放: 区域管理: 巡检管理: 数据可视化分析&…

YOLOv9改进|加入AKConv模块!

专栏介绍:YOLOv9改进系列 | 包含深度学习最新创新,主力高效涨点!!! 一、改进点介绍 AKConv是一种具有任意数量的参数和任意采样形状的可变卷积核,对不规则特征有更好的提取效果。 论文速览:&am…

《TCP/IP详解 卷一》第9章 广播和组播

目录 9.1 引言 9.2 广播 9.2.1 使用广播地址 9.2.2 发送广播数据报 9.3 组播 9.3.1 将组播IP地址转换为组播MAC地址 9.3.2 例子 9.3.3 发送组播数据报 9.3.4 接收组播数据报 9.3.5 主机地址过滤 9.4 IGMP协议和MLD协议 9.4.1 组成员的IGMP和MLD处理 9.4.2 组播路由…

uniapp微信小程序开发踩坑日记:修改组件默认样式

使用uniapp官方组件的时候,我们常常要修改组件的默认样式,但是网上的很多修改组件默认样式的方法都是不生效的(因为我都试过了) 下面给大家介绍vue构建的uniapp小程序中能够生效的修改组件默认样式的方法 1、在编译后的代码文件…

华为HCIP Datacom H12-821 卷3

1.单选题 四台路由器运行 IS-IS 且已经建立邻接关系,区域号和路由器的等级如图中标记,则 R4到达 10.0.2.2/32 的的 Cost 值为多少? A、40 B、10 C、20 D、30 正确答案: D 解析: 由于没有配置路由渗透,所以R4会选择…

potplayer安装

官网 解压运行即可