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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • idea激活吗【2021免费激活】「建议收藏」

    (idea激活吗)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月29日
    52
  • JS高程读书笔记–第三章基本概念

    JS高程读书笔记–第三章基本概念

    2021年9月16日
    51
  • 如何安装wget_ubuntu安装unzip命令

    如何安装wget_ubuntu安装unzip命令今天给服务器安装新LNMP环境时,wget时提示-bash:wgetcommandnotfound,很明显没有安装wget软件包。一般linux最小化安装时,wget不会默认被安装。可以通过以下两种方法来安装:1、rpm安装rpm下载源地址:http://mirrors.163.com/centos/6.2/os/x86_64/Packages/下载wget的RPM包:htt…

    2022年10月17日
    8
  • ubuntu下rabbitvcs安装后无右键菜单解决办法

    ubuntu下rabbitvcs安装后无右键菜单解决办法1、sudorabbitvcs2、rabbitvcs3、nautilus-q4、ls-ldxxx/RabbitVCS.logsudochown-R’currentuser’xxx/RabbitVCS.log

    2022年7月18日
    16
  • JavaScript数组方法详解

    JavaScript数组方法详解JavaScript数组方法详解JavaScript中数组的方法种类众多,在ES3-ES7不同版本时期都有新方法;并且数组的方法还有原型方法和从object继承的方法,这里我们只介绍数组在每个版本中

    2022年7月2日
    29
  • 什么是Platform SDK?

    什么是Platform SDK?microsoft每推出一个windows版本,就会发布与其相应的开发工具包,这就是platformSDK.platform是平台的意思,SDK是SoftwareDevelopmentKit的缩写(即“软件开发工具包”)它里面有大量的例子,API函数讲解等等各种各样的文档,它可以解决开发者的大部分问题.可以说是开发者的必备.比.net2003自带的msdn还要好用,不过,它是英文的,

    2022年5月4日
    38

发表回复

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

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