Solaris下PRO*C和OCI程序设计分析与比较

时间:2023-03-18 15:36:30 计算机毕业论文 我要投稿
  • 相关推荐

Solaris下PRO*C和OCI程序设计分析与比较

摘要文章对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。
2PRO*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或者EXECSQLINCLUDEsqlca;
(2)声明宿主变量,即C变量
这些变量是应用程序与Oracle通信的桥梁,应用程序的输入数据通过C变量传递给Oracle,反之,Oracle的输出数据又通过C变量传递给应用程序。举例如下:
EXECSQLBEGINDECLARESECTION;
charszUsername[16];
VARCHARvarPassword[16];
char*szStmt1="CREATETABLEUSERS(USERNAMEVARCHAR2(15)NOTNULL,PASSWORD
VARCHAR2(15)NOTNULL)";
char*szStmt2="SELECTPASSWORDFROMUSERSWHEREUSERNAME=’chen’";
EXECSQLENDDECLARESECTION;
值得注意的是:在SQL语句中使用C变量时,前面需加冒号,例如上面的变量应表示为:szUsername。其中,VARCHAR为C扩展数据类型,预编译时,PRO*C预编译器将它扩展为一个C结构类型struct{
unsignedshortlen;
unsignedchararr[16];
}varNo;
在SQL语句中使用VARCHAR类型变量时,只需指出结构名称varPassword就可,但在C语句中使用VARCHAR类型变量时,必须具体说明所操作变量的结构元素名称是varPassword.len还是varPassword.arr。另外,如果用VARCHAR类型变量做函数参数的话,只能用指针形式。
(3)连接数据库
EXECSQLCONNECT:username/password@DBname;
通过sqlca.sqlcode的值来判断连接数据库成是否功。
(4)执行SQL语句(分为静态SQL语句和动态SQL语句)
静态SQL语句是在开发应用程序时就已经明确了的数据库操作,如:
EXECSQLSELECTpasswordINTO:szPasswordFROMUSERSWHEREusername=:szUsername;
动态SQL语句是在运行时由外部数据提供的,不能直接在C程序中嵌入SQL语句,但可以调用放在一个字符串变量里的SQL语句,最简单的方法是:EXECSQLEXECUTEIMMEDIATE:szStmt1;但这样执行的SQL语句不能实现查询,实现查询可用下列方法:
EXECSQLPREPAREselect_stmtFROM:szStmt2;
EXECSQLEXECUTEselect_stmtINTO:szPassword;
如果不再需要已准备好的语句,应释放:EXECSQLDEALLOCATEPREPAREselect_stmt;
(5)提交或回滚所做的数据库处理,并退出数据库
回滚:EXECSQLROLLBACKWORKRELEASE;
提交:EXECSQLCOMMITWORKRELEASE;
注意语句中的RELEASE选项,它要求关闭所有打开的游标,之后断开与数据库服务器的连接。
2.3生成可执行文件
在Solaris平台下可通过命令方式对PRO*C源程序进行预编译,下列命令只列出了最常用的预编译选项:#prociname=example.cINCLUDE=pathCODE=ANSI_CMODE=ANSICPP_SUFFIX=cc
SQLCHECK=SEMANTICSUSERID=username/password@DBname
预编译后的example.cc文件就可以当作普通的C源文件来进行处理了。
#gcc-oexampled–I.-I/oracle/product/8.1.7/precomp/publicexample.cc
最终生成的exampled文件就是我们的可执行文件。

3OCI程序设计
OCI(OracleCallInterface)是由头文件和库函数等组成的一套Oracle数据库应用

【Solaris下PRO*C和OCI程序设计分析与比较】相关文章:

C语言程序设计 (一)05-11

我国居民人力资本投资行为比较分析05-11

现代企业制度下的成本控制分析08-27

艺术本质角度下我国当代油画艺术分析06-09

关于中美两国证券的监管制度比较分析论文09-23

涓生和子君人物形象之比较02-27

浅谈常用的英语教学法比较与分析论文(通用10篇)09-27

当当欲将B2C与C2C融合 打造综合网上商城05-09

视唱练耳对声乐技巧的作用和影响分析01-08

锁骨下静脉置管的临床应用及并发症的分析与处理06-11