OCILIB在Linux工程中的应用

2017-05-31 19:33徐英慧
软件导刊 2017年5期

徐英慧

摘要摘要:在Linux工程中,C/C++应用程序经常要访问Oracle数据库,并且对速度和效率要求很高。OCILIB是基于OCI的C语言开发库,具有访问速度快、易用、可靠等特点。探讨OCILIB的安装步骤以及通过OCILIB访问Oracle数据库的一般方法,并以查询和插入为例重点讨论批量操作的实现过程。对要求高效访问Oracle数据库的Linux工程具有一定的借鉴意义。

关键词关键词:OCILIB;Linux;Oracle;批量操作

DOIDOI:10.11907/rjdk.162731

中图分类号:TP319

文献标识码:A文章编号文章编号:16727800(2017)005011803

0引言

Linux以其稳定和多任务特性,在大型工程的服务器操作系统中应用广泛,而C/C++是Linux工程的首选编程语言,常用于编写后台程序及文件操作等应用。在工程应用中,数据库通常不可或缺,而Oracle数据库具有稳定性高、速度快、SQL扩展丰富等特点,得到广泛应用[1]。

C/C++连接Oracle数据库的主要方式通常有以下几种:ADO、ODBC、PRO*C、OCI。ADO和ODBC是通用方法,编程简单,但速度相对较慢。OCI和PRO*C是Oracle公司提供的专门开发工具,访问速度快,很适合实时要求较高的工程使用[2]。但是OCI编程复杂,接口众多,OCILIB为OCI的封装库,适合于快速编程,并且具有非常好的响应速度。本文将重点讨论OCI和OCILIB。

1OCI和OCILIB简介

OCI(Oracle Call Interface,即0racle調用接口)是Oracle公司提供的由头文件和库函数等组成的一个访问Oracle数据库的应用程序编程接口,它允许开发人员在第三代编程语言(包括C, C++, COBOL 与 FORTRAN)中通过SQL(Structure Query Language)来操纵Oracle数据库,而且OCI在一定程度上支持第三代编程语言的数据类型、语法等。OCI全面支持Oracle的面向对象技术,同时还具有即时可用性、企业级高性能、可伸缩性、强健的安全模型、基于Oracle平台可移植性高等特点[34]。

OCILIB是基于OCI的C语言开发库,能够快速、可靠地访问Oracle数据库。它提供了一套功能齐全、易于使用的API,是Linux下C/C++程序访问Oracle的最佳选择。OCILIB的主要特点如下:

①兼容32位和64位系统;

②支持版本>=8i的Oracle版本;

③支持全部SQL应用接口函数和对象;

④支持全部ORACLE数据类型,游标等;

⑤具有连接池和任务池;

⑥可以绑定数组;

⑦支持滚动结果集,方便访问前后的记录;

⑧提供用户线程和线程锁。

2OCILIB使用环境搭建

在Linux工程应用中,要搭建通过OCILIB访问Oracle数据库的使用环境,首先需要安装Oracle客户端,然后才能编译OCILIB库。这里使用的操作系统及各软件版本为:操作系统centos6.5、gcc 4.7、Oracle 11g、OCILIB 3.12。

2.1安装Oracle客户端

要编译OCILIB库,需要先安装Oracle的客户端Oracle-instantclient。它提供了客户端代码库(libclntsh.so.11.1)和Oracle C++调用接口库(libocci.so.11.1)。具体安装步骤如下。

6结语

OCILIB提供了一系列功能齐全、易于使用的API,从而能够快速、可靠地访问Oracle数据库,因而在Linux工程中得到了广泛应用。本文介绍了在C/C++中通过OCILIB访问Oracle数据库的基本步骤和方法,重点讨论了批量查询和批量插入的关键步骤和流程。批量处理是在使用Oracle 的大型工程中实现高效访问数据库的基本保证,本文介绍的批量处理流程对其它大型应用具有一定的借鉴意义。

参考文献参考文献:

[1]连晗.基于Linux的供应商电子商务管理系统的开发与实现[J].电子设计工程,2013(21):4951.

[2]楼建安,余建华.Oracle SQL&PL/SQL 基础教程[M].北京:科学出版社,2011.

[3]李培军,毕于慧,田仲,等.利用OCI封装类实现Oracle与国产数据库间的应用程序移植[J].微型机与应用,2016(8):7172,75.

[4]贺鹏程.基于Oracle的数据库性能优化研究[J].电子设计工程,2016(9):13.

[5]OCILIB (C Driver for Oracle) documentation[DB/OL].http://vrogier.github.io/ocilib/, 2013.

责任编辑(责任编辑:陈福时)