oracle 更新 拼接,Oracle 用拼接字符串更新表 测试

oracle 更新 拼接,Oracle 用拼接字符串更新表 测试先看我们的数据:SQL>selectcount(1)fromdavewherecust_tellike’0551%’;https://www.cndba.cn/Dave/article/1485COUNT(1)———-2723在我们的Dave表里,cust_tel电话以0551开头的有2723条记录,现在我们把这些记录换成0556.我们使用如下方法测试一下:S…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

先看我们的数据:

SQL> select count(1) from dave where cust_tel like ‘0551%’;

https://www.cndba.cn/Dave/article/1485

COUNT(1)

———-

2723

在我们的Dave表里,cust_tel 电话以0551 开头的有2723条记录,现在我们把这些记录换成0556.

我们使用如下方法测试一下:

SQL> select * from v$version; BANNER———————————————————————-Oracle Database 11g Enterprise EditionRelease 11.2.0.1.0 – ProductionPL/SQL Release 11.2.0.1.0 – ProductionCORE 11.2.0.1.0 ProductionTNS for 32-bit Windows: Version 11.2.0.1.0- ProductionNLSRTL Version 11.2.0.1.0 – Production SQL> UPDATE dave SET cust_tel = ‘0556’|| SUBSTR (cust_tel, 5) WHERE cust_tellike ‘0551%’;2723 rows updated. SQL> rollback;Rollback complete. SQL> UPDATE dave SET cust_tel = ‘0556’|| SUBSTR (cust_tel, 5) WHERE cust_telin (select cust_tel from dave where cust_tel like ‘0551%’);2723 rows updated. SQL> rollback;Rollback complete.

写法很多,关键要注意效率问题,尤其是要更新的数据量比较大时。

https://www.cndba.cn/Dave/article/1485

另测试发现Oracle10g 和11g 在语法支持上的一些区别:

https://www.cndba.cn/Dave/article/1485

在Oracle 10g上可以使用如下语法:

BEGIN FOR cl IN (SELECT object_name from d1 WHEREobject_type=’TABLE’) LOOP UPDATE d1 SET object_name = ‘D’ || SUBSTR (object_name, 2) WHERE object_name = cl.object_name; END LOOP;END;

https://www.cndba.cn/Dave/article/1485

但如果在Oracle 11g中使用如下语法:

BEGIN FOR cl IN (SELECT id from dave WHERE cust_tel LIKE ‘0551%’) LOOP UPDATE dave SET cust_tel = ‘0556’ || SUBSTR (cust_tel, 5) WHERE id = cl.id; END LOOP;END;

则会一致处于等待状态。

https://www.cndba.cn/Dave/article/1485

但是在Oracle 11g中,可以使用如下的游标来处理,这种方法也是我们之前的提高的根据rowid 来完成大量的Update操作:

DECLARE CURSOR cur IS SELECT rowid as ROW_ID from dave WHEREcust_tel LIKE ‘0551%’ ORDER BY ROWID; —如果表的数据量不是很大,可以不用 order by rowid V_COUNTER NUMBER;BEGIN V_COUNTER := 0; FOR row IN cur LOOP UPDATE dave SET cust_tel = ‘0556’ || SUBSTR (cust_tel, 5) WHERE ROWID = row.ROW_ID; V_COUNTER := V_COUNTER + 1; IF (V_COUNTER>= 1000) THEN COMMIT; V_COUNTER := 0; END IF; END LOOP; COMMIT;END;

有关这种方法的具体说明参考:

https://www.cndba.cn/Dave/article/1485

——————————————————————————————————-

版权所有,文章允许转载,但必须以链接方式注明源地址,否则追究法律责任!

Blog:   http://blog.csdn.net/tianlesoftware

https://www.cndba.cn/Dave/article/1485

Weibo:            http://weibo.com/tianlesoftware

Skype:            tianlesoftware

——-加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请—-

DBA1 群:62697716(满);   DBA2 群:62697977(满)  DBA3 群:62697850(满)

DBA 超级群:63306533(满);  DBA4 群:83829929   DBA5群: 142216823 https://www.cndba.cn/Dave/article/1485

DBA6 群:158654907    DBA7 群:172855474  DBA8群:102954821

版权声明:本文为博主原创文章,未经博主允许不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/192757.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • CSS 颜色代码大全 CSS颜色对照表[通俗易懂]

    CSS 颜色代码大全 CSS颜色对照表[通俗易懂]转载地址:https://blog.csdn.net/u012117917/article/details/41604711HTML及CSS常用颜色英文词汇  黑色 银色 灰色 白色 茶色 红色 紫色 紫红 black silver gray white maroon …

  • Java工程师书单(初级、中级、高级)

    Java工程师书单(初级、中级、高级)简介怎样学习才能从一名Java初级程序员成长为一名合格的架构师,或者说一名合格的架构师应该有怎样的技术知识体系,这是不仅一个刚刚踏入职场的初级程序员也是工作一两年之后开始迷茫的程序员经常会问到的问题笔者完全从自身的自学经历出发,以初学者的视角挑选出如下的这些图书。初级书单《编写高质量代码——改善Java程序的151个建议》这是一本值得入门java的人

  • postman使用教程1

    postman使用教程1  在我们平时开发中,特别是需要与接口打交道时,无论是写接口还是用接口,拿到接口后肯定都得提前测试一下,这样的话就非常需要有一个比较给力的Http请求模拟工具,现在流行的这种工具也挺多的,像火狐浏览器插件-RESTClient,Chrome浏览器插件-Postman等等。这里主要介绍一下Postman。 一、Postman说明  Postman是一种网页调试与发送网页http请求的chrome插件…

  • 深入浅出JMS(一)——JMS简单介绍

    深入浅出JMS(一)——JMS简单介绍

    2021年11月24日
  • 大一下学期微积分期末预习(3):定积分的应用-求旋转体的体积

    大一下学期微积分期末预习(3):定积分的应用-求旋转体的体积下面这个是柱壳法,不是注,别问,问就是字写错了。

  • Lua语言_lua基本语法

    Lua语言_lua基本语法1、Lua简介1.1Lua是什么1.2特性1.3应用场景2、Lua的安装3、入门程序4、Lua的基础语法4.1注释4.2定义变量4.3Lua中的数据类型4.4流程控制4.5循环4.6函数4.7表4.8模块1、Lua简介1.1Lua是什么Lua[1]是一个小巧的脚本语言。它是巴西里约热内卢天主教大学(PontificalCatholicUniversityofRiodeJaneiro)里的一个由RobertoIerusalimschy、WaldemarCele.

    2022年10月22日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号