百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

一文讲懂SQL更新语句UPDATE

haoteby 2025-03-12 15:02 17 浏览

大家好,我是宁一。


今天是SQL课程的第九课。


讲讲UPDATE 更新语句,用来修改表中的一条或多条记录。


基本语法:

UPDATE <表名> SET <字段名=值> WHERE <筛选条件>;


1、更新单行


实例:将Students表中,学生编号Sid为1的学生姓名Sname改为:“喵宁一”



UPDATE Students
SET Sname="喵宁一"  
WHERE Sid=1;



这时很可能遇到这个错误:

You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column


解决方案:


出现错误是因为Workbench默认开启了Safe Updates功能,不允许随便修改删除记录,我们先关闭该功能。



MySQLWorkbench-Preferences-SQL Editor-将Safe Updates前面的勾去掉。再重启Workbench软件就可以了。



SET后面还可以是数学表达式。


实例:将Students表中,学生编号Sid为1的学生姓名对应的Tid加100。


UPDATE Students
SET Tid=Tid+100
WHERE Sid=1;



2、更新多行


让 WHERE条件包含更多记录,就会同时更改多条记录了


实例:将Students表中,性别Ssex为男的学生,学生编号Sid加200


UPDATE Students
SET Sid=Sid+200
WHERE Ssex="男";



3、UPDATE + 子查询


子查询是查询语句里面嵌套的查询语句,子查询的结果作为主查询的查询条件,完成更复杂数据检索。


我们来讲讲UPDATE语句怎样结合子查询来更改语句,本质上是将子查询与WHERE子句结合使用。


实例:将Students学生表中,班主任为李四的记录,学生性别Ssex更改为“女生”。


解析:因为学生表中只要班主任的Tid教师编号,没有姓名,所以要从教师表中查询李四的Tid。



UPDATE Students
SET Ssex="女生"
WHERE Tid = (
  SELECT Tid
  From Teachers
  WHERE Tname = "李四"
);



如果子查询返回的是多个数据时,就不能用等号而要用 IN 了。


作业:将Students学生表中,班主任为张三和李四的记录,学生性别Ssex更改为“男生”。


答案解析:因为子查询返回的Tid为(1,2),有两个,这个时候就不能用等号了,需要用Tid IN (子查询)。


第一步:先将子查询写好,查出张三和李四班主任对应的Tid。


SELECT Tid
From Teachers
WHERE Tname IN("李四","张三")



第二步,将子查询加入到WHERE条件中,将对应学生的学生性别更改为“男生”。


UPDATE Students
SET Ssex="男生"
WHERE Tid IN (
  SELECT Tid
  From Teachers
  WHERE Tname IN("李四","张三")
);



下节课我们来讲讲怎样从数据库中删除数据。


点击关注,更新课程第一时间通知哦~

相关推荐

BRICS continues to offer powerful alternative global vision

Leadersattendingtheplenarysessionof"PeaceandSecurityandReformofGlobalGovernance"ofthe...

China&#39;s role in shaping global growth takes the stage at Summer Davos

Guestsattendtheparallelsession"CheckingInontheEnergyTransition"duringthe2025SummerDav...

Shanghai blockchain park proves WAIC&#39;s worth

BySHEXiaochenThe2023WorldArtificialIntelligenceConferencekickedoffinShanghaionThursday...

Shopee新手指南:Shopee卖家中心用户界面介绍

1.Shopee各站点前台网页链接:2.Shopee各站点后台网页链接3.ShopeeAPP下载:安卓版下载链接:https://pan.baidu.com/s/1eSp8M1k#list/path...

打孩子犯法!日本拟立法禁止父母体罚孩子

日本虐童事件频发引发了社会的广泛关注。近日,日本打算对现行的儿童福利法案进行修订,禁止父母体罚子女,但也引发了网友对于体罚、虐待以及法律可行性的讨论。日本将禁止父母体罚子女ViaJapanTod...

新NAS到手后,你一定要学会的9个设置,威联通和群晖都是这样的。

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:小曹老师心念已久的NAS,终于到手了,期待着他能给我们数字化生活,带来更多的便捷和安心。...

苹果四大系统信息汇总(苹果手机系统分别有哪些)

【环球科技综合报道】据国外科技网站报道,苹果在6月13日举行全球开发者大会(WWDC),对iOS、MacOS、WatchOS、TVOS四大系统进行更新。MacOS:OSX系统将更名为“ma...

关于苹果iOS 10 系统 你需要了解的5个特点

【环球科技综合报道】据外媒5月10日报道,苹果公司将于今年6月举办全球开发者大会(WWDC)。在大会上,公司计划发布iOS10操作系统。该系统在iOS7操作系统的基础上进行了革新,具有里程碑式意义...

Win10用户:不要尝试安装Media Center

IT之家(www.ithome.com):Win10用户:不要尝试安装MediaCenter本月初,微软正式发布了Win10技术预览版。最近有部分用户尝试通过Win8.1的安装密钥,来为Window...

半年做到美妆Top主播,“成分测评师李某人”究竟何许人?

从毛毛姐到口红一哥李佳琦,男网红主播成为了一个趋势,也有越来越多的男生开始扎堆进入美妆行业,淘宝主播“成分测评师李某人”是其中之一。只是,他做主播的初衷,倒不是为了当网红,而是想给自己的美妆品牌打开一...

《经典怀旧手游》新手必看玩法,背景玩法详细介绍!

经典重温,武林再现,十年经典,再创江湖!备受玩家期待的《武林外传十年之约手游》即将来袭。本次版本主题为“江湖再现”,全新开放的梦境机关城将带来全新挑战!塑魂系统的全面升级,新增第二期空位和道具将大幅提...

17个问题,帮你判断咨询师是否适合自己

...

关于软考你想知道的都在这(软考有用吗 知乎)

软考相信学计算机的大家多多少少有过了解,就是全国计算机技术与软件专业技术资格(水平)考试,适用于大部分计算机同学和想转行IT行业的同学。这两天各省陆续出了报考的入口,大家可以积极报考!软考含金量较高,...

微软面向Linux平台放出4.3版本Skype

继日前微软针对iPhone平台放出5.0版本Skype,对用户界面进行多处调整之后软再次面向Linux平台放出了4.3.0.37版本Skype应用,带来了部分用户界面改善、全新的功能和系统后台性能优化...

Linux dd命令有多强大?(linux的dig命令)

请关注本头条号,每天坚持更新原创干货技术文章。如需学习视频,请在微信搜索公众号“智传网优”直接开始自助视频学习1.前言本文主要介绍Linuxdd命令的强大功能与日常的使用案例。Linux中的dd命...