Oracle Proc编程性能优化经验
2019-12-01 16:01:03来源:博客园 阅读 ()
Oracle Proc编程性能优化经验
Proc 是Oracle提供的一种数据库操作的AP。它是基于ESql技术的,需要预编译后才可以变成普通c代码,非常不直观,使用起来不太方便,阅读也存在困难。
因为这些问题导致程序员平时开发中会出现一些Proc操作存在效率低下的情况,本文介绍一些Proc一些编译经验,希望能给大家提供参考。
下面以一个简单需求进行举例说明:
要求把DB1里面一张数据表tbl_hch_test的数据导出到DB2的同名表。
最快的方法当然是使用oracle的数据泵工具进行压缩导出再导入,但expdp/impdp对数据库环境有特别要求,所以我们需要使用Proc编程,先从DB1取出数据,再insert到Db2里面。
简单实现:
打开一个游标,从DB1循环FETCH数据出来,再使用sprintf拼装成insert语句,到DB2使用exec sql指令执行插入并提交数据库。
优化:
虽然上面的做法可以完成需求,但在效率上存在不优化空间。下面依次进行介绍:
1 使用绑定变量代替sprintf拼装sql
实践证明sprintf函数在对效率要求比较高的场景下容易成为性能瓶颈,使用绑定变量可以避免sprintf调用。
并且,由于数据库里面执行的sql是相同的,不需要每次重新分析sql生成执行计划,也能大大减轻数据库负担,提高执行效率。
2 对insert语句进行预编译,一次编译多次执行,避免使用隐性游标,每次都要重新编译。
同上,预编译是比较消耗cpu的操作。如果sql相同,可以复用游标,减少性能开支。
3 使用批量操作,每次取数和插入数据都使用数组进行绑定。
批量操作可以减少客户端与服务器之间交互次数,加快操作数据。
4 适当加大事务提交间隔(insert多行记录commit一次)
Oracle提交数据库事务时需要将日志从内存刷回磁盘并等待磁盘操作完成才返回,提高事务提交间隔可以减少等待消耗。
优化前后效率测试对比:
相同的操作,从23s降低到1.3s
其它提高效率措施:
以上是在编程上的一些优化,结合oracle一些特性,速度还能再提升,简单介绍几个优化技巧:
1 先删除目标表索引,insert完数据后再重建
2 关闭表的日志, 减少redo日志,alter table tbl_hch_test nologing。装载完数据再改回来。
3 使用append HINT,在高水位上面直接插入数据,加快插入速度。
4 使用并行(parallel)查询,或者使用分区查询(select * from tab parttion(par_name))加快查询速度。
5 如果可能,尽量在数据库服务器上执行程序,减少网络传输开销
关键代码参考:
另外,附上几个平时使用Proc容易出现误区。
1 使用char数组保存数据库varchar2类型字段的值
Proc的char数组对应的数据库类型是char,varchar结构体对应的类型才是varchar2。使用char数组保存数据库varchar2类型字段的值,会导致取出的数据像char类型一样,在末尾自动添加空格。
解决方法可以使用EXEC SQL VAR/ EXEC SQL TYPE同等化变量或者数据类型。或者在预编译时指定CHAR_MAP=string一劳永役
2 需要注意proc的一些命令是预编译命令,只在预编译期间生效,与C语言的宏十分相似。例如以下命令:。
EXEC SQL CONTEXT USE
ESEC SQL Whenever Sqlerror Do
下面举一个常见的错误进行说明:
要完全搞明白proc的原理,建议多分析.pc文件与porc预编译后生成的.c文件代码区别。
3 proc指针变量
Proc可以正确识别指针与普通变量,使用指针做为绑定变量与使用普通变量的方法一样,在变量前面加上冒号即可。
官方文档是这样说的:
有一些程序员不清楚怎么在proc使用指针,会使用memcpy把数据复制多一遍,增加无谓消耗。
4 proc与C语言宏
Proc能识别C语言的一些简单的宏,但如果有复杂的宏(如不定参数宏),proc在预编译时会报错。
此时可以考虑使用gcc –E先对.pc文件进行预处理,之后再使用proc进行预编译。
如果对于proc编程还有什么其它疑惑的地方,欢迎大家与我讨论,或者查阅官方帮助文档。《Oracle Proc官方文档.pdf》
原文链接:https://www.cnblogs.com/kingstarer/p/11968247.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- C代做 C++代做 C++编程代做 C++程序代做 2020-04-29
- 第七章 2.泛型编程(模板) 2020-04-04
- linux环境下的时间编程 2020-03-27
- C、C++ 标准输入重定向 & 万能头 - 编程技巧 2020-03-20
- C++ 常用编程--Swap函数有几种写法? 2020-02-26
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash