oracle 批量更新之update case when then
oracle 批量更新之update case when then
CreationTime--2018年8月7日15点51分
Author:Marydon
1.情景描述
根据表中同一字段不同情况下的值修改为对应的内容,如何实现?
使用case when then else end语句。
2.错误用法
没有else语句,将会导致全表更新
证实:
结果展示:
说明:更新的是全表记录,而不是更新的只是符合上面三种情况的记录;
不在情况范围内的,执行的是将该字段值置空,sql语句相当于:
UPDATE BASE_AC_MODULE_BAK T
SET T.MODULEICON = CASE
WHEN T.MODULEICON = '/commons/images/img/add.gif' THEN
'/commons/images/img/add.png'
WHEN T.MODULEICON = '/commons/images/img/edit.gif' THEN
'/commons/images/img/update.png'
WHEN T.MODULEICON = '/commons/images/img/delete.gif' THEN
'/commons/images/img/delete.png'
ELSE
NULL
END
3.case when then else end语法
用法一:简单case语句
CASE SEX
WHEN '1' THEN '男'
WHEN '2' THEN '女'
ELSE '其他' END
用法二:case搜索语句
CASE WHEN SEX = '1' THEN '男'
WHEN SEX = '2' THEN '女'
ELSE '其他' END
用法说明:
与java的switch语句不同是,如果不声明ELSE语句,oracle会自动添加ELSE语句(ELSE NULL),当数据出现与case的情况都不匹配时,
显示的不是原数据,而是空值;
必须有END关键词声明结束CASE语句;
另外,需特别注意的是:使用CASE语句,无论是查询还是修改语句,在不加限制条件的情况下,默认是对全表进行操作!
4.正确用法
方法一
UPDATE BASE_AC_MODULE_bak T
SET T.MODULEICON = CASE
WHEN T.MODULEICON = '/commons/images/img/add.gif' THEN
'/commons/images/img/add.png'
WHEN T.MODULEICON = '/commons/images/img/edit.gif' THEN
'/commons/images/img/update.png'
WHEN T.MODULEICON = '/commons/images/img/delete.gif' THEN
'/commons/images/img/delete.png'
ELSE
T.MODULEICON
END
WHERE (T.MODULEICON = '/commons/images/img/add.gif' OR
T.MODULEICON = '/commons/images/img/delete.gif' OR
T.MODULEICON = '/commons/images/img/edit.gif')
else为什么可以省略?
更新加上限制条件后,只有16条数据符合要求并进行修改,不存在else的情况。
方法二:限制条件加在where后,多个条件之间使用or
UPDATE BASE_AC_MODULE_BAK T
SET T.MODULEICON = DECODE(T.MODULEICON,
'/commons/images/img/add.gif',
'/commons/images/img/add.png',
'/commons/images/img/edit.gif',
'/commons/images/img/update.png',
'/commons/images/img/delete.gif',
'/commons/images/img/delete.png')
WHERE (T.MODULEICON = '/commons/images/img/add.gif' OR
T.MODULEICON = '/commons/images/img/delete.gif' OR
T.MODULEICON = '/commons/images/img/edit.gif')
oracle 批量更新之update case when then的更多相关文章
- oracle批量更新之使用游标进行分批次更新的5种方式及速度比对
1.情景展示 一共有22w条数据, 需要将A表的主键更新至B表的指定字段,如何快速完成更新? 2.解决方案 声明: 解决方案不只一种,该文章只介绍快速游标法及代码实现: 两张表的ID和ID_CAR ...
- oracle 批量更新表字段
(一) 将数字替换成汉字 第一步,去重查询 使用distinct关键字先对该字段值进行去重查询,看共有几种情况 --查询指定区间内表停诊字段的值 SELECT DISTINCT T.CLOSE_T ...
- oracle 批量更新之将一个表的数据批量更新至另一个表
oracle 批量更新之将一个表的数据批量更新至另一个表 CreationTime--2018年7月3日17点38分 Author:Marydon Oracle 将一个表的指定字段的值更新至另一个 ...
- mybatis执行批量更新batch update 的方法
1.数据库连接必须配置:&allowMultiQueries=true 我的配置如下:jdbc:mysql://10.20.13.16:3306/CALENDAR?useUnicode=tru ...
- oracle批量更新
oracle批量更新 学习了:http://blog.csdn.net/zkcharge/article/details/50855755 statement.addBatch(); statemen ...
- Mybatis在oracle批量更新
最近公司业务中为了提高效率要做mybatis批量更新,但是到了oracle数据库中做了好几次都没成功,后来发现mybatis最后少了个分号,可能是Mybatis内部做了异常try catche 处 ...
- Oracle批量更新数据,使用begin end
/* 使用begin end批量更新 注意end后面必须使用;结束 并且每条update语句都要用;来结束 所以close为;END; 是为了补全语法 */ <foreach collectio ...
- Oracle批量、大量Update方法总结
一.业务场景: (1)主从两个表,主表Student,有字段id.name.sex,从表Boy,有字段id.name,主从表同一对象id相同 (2)从表Boy的name属性被业务修改,定时批量处理主表 ...
- oracle 同时更新(update)多个字段多个值
--创建表A,B: create table A (a1 varchar2(33),a2 varchar2(33),a3 varchar2(33)); create table B (b1 varch ...
随机推荐
- C#中的IDisposable模式
当谈到垃圾回收,在C#中,托管资源的垃圾回收是通过CLR的Garbage Collection来实现的,Garbage Collection会调用堆栈上对象的析构函数完成对象的释放工作:而对于一些非托 ...
- Spring事务传播机制与隔离级别(转)
Spring事务传播机制与隔离级别 博客分类: Spring 转自:http://blog.csdn.net/edward0830ly/article/details/7569954 (写的不错) ...
- java多台
多 态★★★★★(面向对象特征之一):函数本身就具备多态性,某一种事物有不同的具体的体现. 体现:父类引用或者接口的引用指向了自己的子类对象.//Animal a = new Cat();父类可以调用 ...
- python文本 单独处理每个字符的方法汇总
python文本 单独处理字符串每个字符的方法汇总 场景: 用每次处理一个字符的方式处理字符串 方法: 1.使用list(str) >>> a='abcdefg' >&g ...
- quartz 中JobExecutionContext的使用
假如execute方法中需要一些额外的数据怎么办?比如说execute 中希望发送一封邮件,但是我需要知道邮件的发送者.接收者等信息? 存在两种解决方案: 1.JobDataMap类: 每个Jo ...
- [翻译] AGPhotoBrowser 好用的图片浏览器
AGPhotoBrowser 好用的图片浏览器 https://github.com/andreagiavatto/AGPhotoBrowser A photo browser for iOS6 a ...
- hadoop安装入门
1.jdk安装和配置 1.1下载最新jdk文件 http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-18802 ...
- 快速近似最近邻搜索库 FLANN - Fast Library for Approximate Nearest Neighbors
What is FLANN? FLANN is a library for performing fast approximate nearest neighbor searches in high ...
- 【BZOJ】【2694】Lcm
数论/莫比乌斯反演/线性筛 题解:http://www.cnblogs.com/zyfzyf/p/4218176.html JZPTAB的加强版?感觉线性筛好像还是不怎么会啊……sad 题目记下来,回 ...
- [转]一键安装藏隐患,phpStudy批量入侵的分析与溯源
一.前言 近日,腾讯安全云鼎实验室监测到大量主机被入侵并添加了一个名为“vusr_dx$”的隐藏帐号:同时,云鼎实验室还监测到此类帐号被大量创建的同时存在对应帐号异地登录的情况. Windows 的帐 ...