openGauss学习笔记-69 openGauss 数据库管理-创建和管理普通表-更新表中数据

2023-09-14 22:14:23

openGauss学习笔记-69 openGauss 数据库管理-创建和管理普通表-更新表中数据

修改已经存储在数据库中数据的行为叫做更新。用户可以更新单独一行、所有行或者指定的部分行。还可以独立更新某个字段,而其他字段则不受影响。

使用UPDATE命令更新现有行,需要提供以下三种信息:

  • 表的名称和要更新的字段名
  • 字段的新值
  • 要更新哪些行

SQL通常不会为数据行提供唯一标识,因此无法直接声明需要更新哪一行。但是可以通过声明一个被更新的行必须满足的条件来更新数据行。只有在表里存在主键的时候,才可以通过主键指定一个独立的行。

建立表和插入数据的步骤请参考创建表向表中插入数据

需要将表customer_t1中c_customer_sk为9527的地域重新定义为9876:

openGauss=# UPDATE customer_t1 SET c_customer_sk = 9876 WHERE c_customer_sk = 9527;

这里的表名称也可以使用模式名修饰,否则会从默认的模式路径找到这个表。SET后面紧跟字段和新的字段值。新的字段值不仅可以是常量,也可以是变量表达式。

比如,把所有c_customer_sk的值增加100:

openGauss=# UPDATE customer_t1 SET c_customer_sk = c_customer_sk + 100;

在这里省略了WHERE子句,表示表中的所有行都要被更新。如果出现了WHERE子句,那么只有匹配其条件的行才会被更新。

在SET子句中的等号是一个赋值,而在WHERE子句中的等号是比较。WHERE条件不一定是相等测试,许多其他的操作符也可以使用。

用户可以在一个UPDATE命令中更新更多的字段,方法是在SET子句中列出更多赋值,比如:

openGauss=# UPDATE customer_t1 SET  c_customer_id = 'Admin', c_first_name = 'Local' WHERE c_customer_sk = 4421; 

批量更新或删除数据后,会在数据文件中产生大量的删除标记,查询过程中标记删除的数据也是需要扫描的。故多次批量更新/删除后,标记删除的数据量过大会严重影响查询的性能。建议在批量更新/删除业务会反复执行的场景下,定期执行VACUUM FULL以保持查询性能。

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

图片

更多推荐

java学习--day18(TreeSet底层&内部类)

文章目录1.二叉树的了解2.使用比较器将数据存储到TreeSet中3.匿名内部类3.1基于抽象类的匿名内部类3.2基于接口的匿名内部类4.内部类4.1成员内部类昨天总结:ArrayList:就是单纯的addLinkedList:也是单纯的addHashSet:不单纯得重写equals和hashCode方法TreeSet

本地搭建CFimagehost私人图床——“cpolar内网穿透”

文章目录1.前言2.CFImagehost网站搭建2.1CFImagehost下载和安装2.2CFImagehost网页测试2.3cpolar的安装和注册3.本地网页发布3.1Cpolar临时数据隧道3.2Cpolar稳定隧道(云端设置)3.3.Cpolar稳定隧道(本地设置)4.公网访问测试5.结语1.前言图片服务器

Docker ~ 从入门到入坑。

Docker~从入门到入坑。文章目录Docker~从入门到入坑。Docker实用篇。0.学习目标。1.初识Docker。1.1.什么是Docker。1.1.1.应用部署的环境问题。1.1.2.Docker解决依赖兼容问题。1.1.3.Docker解决操作系统环境差异。1.1.4.小结。1.2.Docker和虚拟机的区别

2023/9/20总结

mavenmaven本质是一个项目管理工具将项目开发和管理过程抽象成一个项目对象模型(POM)POM(ProjectObjectModel)项目对象模型作用项目构建提供标准的自动化项目构建方式依赖管理方便快捷的管理项目依赖的资源(jar包),避免资源间的版本冲突问题统一开发结构提供标准的、统一的项目结构安装Maven–

二、链表(linked-list)

文章目录一、定义二、经典例题(一)[21.合并两个有序链表](https://leetcode.cn/problems/merge-two-sorted-lists/description/)1.思路2.复杂度分析3.注意4.代码(二)[86.分割链表](https://leetcode.cn/problems/par

【错误记录】Android Studio 中最新的 Gradle 配置中设置插件依赖 ( 2023 年 8 月 24 日 | 最新 Gradle 中配置插件依赖的变化 | 增加 Maven 仓库源 )

文章目录一、最新Gradle中配置插件依赖的变化二、报错信息三、增加Maven仓库源五、使用老版本方式导入插件一、最新Gradle中配置插件依赖的变化当前最新的AndroidStudio开发环境,生成的Gradle配置脚本使用了最新API,用起来不太习惯;根目录下的build.gradle构建脚本变成了下面的样式,单纯

【错误记录】Android Studio 创建 Module 模块报错 ( Cannot resolve external dependency org.jetbrains.kotlin:kotl )

文章目录一、报错信息二、解决方案目前使用的是最新的Gradle配置,创建Module生成的源码与Gradle配置出现了冲突,导致的问题;解决此类问题,要仔细检查Gradle构建脚本,排查每个依赖库的来源;本次错误就是AS系统自动成的Module修改了Gradle构建脚本,导致依赖下载失败;一、报错信息在AndroidS

亚马逊云科技打造SAP核心业务系统上云最佳实践,加快业务转型和价值实现

数字化转型步入深水区,企业竞争日益激烈,乘云而上、快速进行现代化转型和创新,才能不断紧跟趋势变化,实现「高质量发展」。作为亚马逊云科技全球战略合作伙伴,SAP和亚马逊云科技的联合创新已超过15年,双方共同为SAP客户的关键业务型工作负载提供支持,持续助力企业数字化转型。如今,全球有数以千计的企业将SAP核心业务系统运行

前端工程师路上的宝藏:不可错过的进阶必读文章!

JavaScript《javascript高级程序设计》核心知识总结必要性:⭐️⭐️⭐️⭐️难度:⭐️⭐️⭐️⭐️谏言:建议初学者先读一两遍红宝石书(即JavaScript高级程序设计),犀牛书可以暂时不看(读起来有点累)ES6入门教程必要性:⭐️⭐️⭐️⭐️⭐️难度:⭐️⭐️⭐️⭐️⭐️谏言:阮大佬的开源精品,强推!

如何在Ubuntu中挂载新硬盘

参考:如何在Ubuntu中挂载新硬盘_笔记大全_设计学院ubuntu将大于2T硬盘挂载到/home目录并使其永久生效的详细操作步骤_ubuntu挂载硬盘到home目录_菲玛的博客-CSDN博客win10+ubuntu18.04home目录扩容方法_ubuntu增加home空间_cfreeze的博客-CSDN博客1、检测

【二分法查找】

使用二分法查找需要注意的点:使用二分法的前提:数组为有序数组,同时题目还强调数组中无重复元素。二分法经常写乱,主要是因为对区间的定义没有想清楚,区间的定义就是不变量。要在二分查找的过程中,保持不变量,就是在while寻找中每一次边界的处理都要坚持根据区间的定义来操作,这就是循环不变量规则。写二分法,区间的定义一般为两种

热文推荐