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

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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c++深拷贝和浅拷贝[通俗易懂]

    c++深拷贝和浅拷贝[通俗易懂]C++中类的拷贝有两种:深拷贝,浅拷贝当出现类的等号赋值时,会调用拷贝函数在未定义显示拷贝构造函数的情况下,系统会调用默认的拷贝函数——即浅拷贝,它能够完成成员的一一复制。当数据成员中没有指针时,浅拷贝是可行的。但当数据成员中有指针时,如果采用简单的浅拷贝,则两类中的两个指针将指向同一个地址,当对象快结束时,会调用两次析构函数,而导致指针悬挂现象。所以,这时,必须采用深拷贝。深拷贝与浅拷贝

    2022年10月1日
    2
  • 博客大巴,自动登录,并发布信息开发小计。

    博客大巴,自动登录,并发布信息开发小计。工具准备:Fiddler相关网页:登录页面:http://passport.blogbus.com/login信息发布信息:http://www.blogbus.com/user/?blogid=49

    2022年6月30日
    25
  • varargin_epoll是什么意思

    varargin_epoll是什么意思matlab中varargin简介varargin可以看做“Variablelengthinputargumentlist”的缩写。在matlab中,varargin提供了一种函数可变参数列表机制。就是说,使用了“可变参数列表机制”的函数允许调用者调用该函数时根据需要来改变输入参数的个数。matlab中很多内建函数和工具箱函数都使用了这种机制。比如图像处理工具箱中的imsh

    2025年8月22日
    6
  • linux下mysql命令

    linux下mysql命令1.linux下启动mysql的命令:mysqladminstart/ect/init.d/mysqlstart(前面为mysql的安装路径)2.linux下重启mysql的命令:mys

    2022年7月2日
    25
  • android studio的问题整理

    今天打算尝试使用android stutio,试试效果如何,遇到的问题就在这里整理出来 刚才遇到的:Android studio无法启动,错误信息: “Files in E:\Android\android-studio\system\caches are locked. Android Studio will not be able to start up.”尝试使用管理员权

    2022年3月10日
    64
  • mac datagrip激活教程_最新在线免费激活

    (mac datagrip激活教程)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/ide…

    2022年3月31日
    83

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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