[本篇论文由上帝论文网为您收集整理,上帝论文网http://paper.5var.com将为您整理更多优秀的免费论文,谢谢您的支持]摘要 文章对Solaris平台下,开发基于Oracle数据库的C程序的两种方法——PRO*C和OCI进行了研究,详细分析了这两种方法的开发流程,给出了较为具体的应用程序例子,并对两者的性能进行了比较。 关键词 Solaris,Oracle,PRO*C,OCI 1引言 数据库在软件开发中的应用越来越广泛,其中,Oracle可说是性能最强大、最稳定的数据库之一,大量的软件开发选择了Oracle。在开发语言的选择上,C语言以其灵活、高效吸引了大批的软件开发人员。这两者的强强联合也必具有较高的性能,在实际中有广泛的应用。这就是PRO*C和OCI程序设计。 Oracle常常应用在服务器中,Solaris又是服务器的首选平台,因此,本文主要介绍PRO*C和OCI程序设计在Solaris平台上的应用和实现,对在Windows平台和Linux平台上的应用和实现也可作为参考。本文所采用的开发环境为Solaris2.8、Oracle8.1.7。 2 PRO*C程序设计 PRO*C是Oracle提供的应用程序专用开发工具,它以C语言为宿主语言,能在C程序中嵌入SQL语句,进行数据库操作。这种嵌入式的SQL语句容易掌握,适合初学者。 2.1设置开发环境 (1)C编译器 Solaris系统中常用的C语言编译器是GCC,是GNU组织的免费C编译器,一般Linux版本中缺省都安装有GCC,UNIX系统中有的并不自带,因此需要手动安装,本文所采用的GCC版本为3.2。 (2)PRO*C预编译器 PRO*C使用预编译技术,预编译器将源程序中的SQL语句转换为标准的Oracle库函数调用,从而生成C源程序,再经C编译器编译、链接后生成可执行文件。这个预编译器是Oracle自带的。 (3)C语言头文件和函数库。 Oracle安装程序将这些文件安装在$ORACLE_HOME/precomp目录下。 2.2开发PRO*C程序 (1)说明SQL通讯区 SQL通讯区用来记录执行每一个嵌入SQL语句的状态信息,通过在函数体外使用下列语句实现: #include 或者 EXEC SQL INCLUDE sqlca; (2)声明宿主变量,即C变量 这些变量是应用程序与Oracle通信的桥梁,应用程序的输入数据通过C变量传递给Oracle,反之,Oracle的输出数据又通过C变量传递给应用程序。举例如下: EXEC SQL BEGIN DECLARE SECTION; char szUsername[16]; VARCHAR varPassword[16]; char *szStmt1="CREATE TABLE USERS (USERNAME VARCHAR2(15) NOT NULL,PASSWORD VARCHAR2(15) NOT NULL)"; char *szStmt2= "SELECT PASSWORD FROM USERS WHERE USERNAME=’chen’"; EXEC SQL END DECLARE SECTION; 值得注意的是:在SQL语句中使用C变量时,前面需加冒号,例如上面的变量应表示为:szUsername。其中,VARCHAR为C扩展数据类型,预编译时,PRO*C预编译器将它扩展为一个C结构类型struct{ unsigned short len; unsigned char arr[16]; }varNo; 在SQL语句中使用VARCHAR类型变量时,只需指出结构名称varPassword就可,但在C语句中使用VARCHAR类型变量时,必须具体说明所操作变量的结构元素名称是varPassword.len还是varPassword.arr。另外,如果用VARCHAR类型变量做函数参数的话,只能用指针形式。 (3)连接数据库 EXEC SQL CONNECT :username/password@DBname; 通过sqlca.sqlcode的值来判断连接数据库成是否功。 (4)执行SQL语句(分为静态SQL语句和动态SQL语句) 静态SQL语句是在开发应用程序时就已经明确了的数据库操作,如: EXEC SQL SELECT password INTO :szPassword FROM USERS WHERE username=:szUsername; 动态SQL语句是在运行时由外部数据提供的,不能直接在C程序中嵌入SQL 语句,但可以调用放在一个字符串变量里的SQL语句,最简单的方法是:EXEC SQL EXECUTE IMMEDIATE :szStmt1;但这样执行的SQL语句不能实现查询,实现查询可用下列方法: EXEC SQL PREPARE select_stmt FROM :szStmt2; EXEC SQL EXECUTE select_stmt INTO :szPassword; 如果不再需要已准备好的语句,应释放:EXEC SQL DEALLOCATE PREPARE select_stmt; (5)提交或回滚所做的数据库处理,并退出数据库 回滚:EXEC SQL ROLLBACK WORK RELEASE; 提交:EXEC SQL COMMIT WORK RELEASE; 注意语句中的RELEASE选项,它要求关闭所有打开的游标,之后断开与数据库服务器的连接。 2.3生成可执行文件 在Solaris平台下可通过命令方式对PRO*C源程序进行预编译,下列命令只列出了最常用的预编译选项:#proc iname=example.c INCLUDE=path CODE=ANSI_C MODE=ANSI CPP_SUFFIX=cc SQLCHECK=SEMANTICS USERID=username/password@DBname 预编译后的example.cc文件就可以当作普通的C源文件来进行处理了。 #gcc -o exampled –I. -I/oracle/product/8.1.7/precomp/public example.cc 最终生成的exampled文件就是我们的可执行文件。 3 OCI程序设计 OCI(Oracle Call Interface)是由头文件和库函数等组成的一套Oracle数据库应用程序编程接口工具,OCI程序实质上就是用高级语言写的程序,其特点是内部含有对OCI子函数库的调用。 OCI程序对开发环境的要求相对较低,只要有C语言的OCI开发工具包和C编译器就可以,程序设计相比PRO*C复杂了点。 3.1创建和初始化OCI环境 首先要在源程序中包含OCI头文件:#include OCI环境即OCI函数的工作环境,在调用其他函数之前必 [1] [2] [3] 下一页
Tags:
|