在线客服系统

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

时间:2015-08-31 09:50 来源:发表吧 作者:发表吧编辑 点击:
  【摘要】文章对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<sqlca.h>或者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数据库应用程序编程接口工具,OCI程序实质上就是用高级语言写的程序,其特点是内部含有对OCI子函数库的调用。
  OCI程序对开发环境的要求相对较低,只要有C语言的OCI开发工具包和C编译器就可以,程序设计相比PRO*C复杂了点。
  3.1创建和初始化OCI环境
  首先要在源程序中包含OCI头文件:#include<oci.h>
  OCI环境即OCI函数的工作环境,在调用其他函数之前必须先调用OCIInitialize()和OCIEnvInit()函数创建和初始化OCI环境,其他OCI函数要在这个环境中才能执行。
  先定义变量:OCIEnv**m_envhp;
  OCIError*m_errhp;
  OCIServer*m_srvhp;
  OCISvcCtx*m_svchp;
  OCIStmt*m_stmthp;
  OCIInitialize((ub4)OCI_DEFAULT,(dvoid*)0,(dvoid*(*)(dvoid*,size_t))0,
  (dvoid*(*)(dvoid*,dvoid*,size_t))0,(void(*)(dvoid*,dvoid*))0);
  OCIEnvInit((OCIEnv**)&m_envhp,OCI_DEFAULT,(size_t)0,(dvoid**)0);
  其中m_envhp为输出参数,是一个指向OCI环境句柄的指针,OCI_DEFAULT是OCI环境的初始化模式。OCIEnvInit()函数中的size_t类型变量为分配给用户的内存数量,dvoid**类型变量指向用户的内存区域,该区域的大小等于size_t类型变量。
  OCI函数中,大量使用OCI定义的数据类型和宏,其定义可参考$ORACLE_HOME/rdbms/demo目录下的oci.h头文件。

www.fabiaoba.com),是一个专门从事期刊推广期刊发表、投稿辅导、发表期刊的网站。
  本站提供如何投稿辅导、发表期刊,寻求论文刊登合作,快速投稿辅导,投稿辅导格式指导等解决方案:省级论文刊登/国家级论文刊登/ CSSCI核心/医学投稿辅导/职称投稿辅导。

投稿邮箱:fabiaoba365@126.com
 在线咨询: 投稿辅导275774677投稿辅导1003180928
 在线咨询: 投稿辅导610071587投稿辅导1003160816
 联系电话:13775259981

联系方式
李老师QQ:发表吧客服610071587 陈老师QQ:发表吧客服275774677 刘老师QQ:发表吧客服1003160816 张老师QQ:发表吧客服1003180928 联系电话:18796993035 投稿邮箱:fabiaoba365@126.com
期刊鉴别
  • 刊物名称:
  • 检索网站:
热门期刊
发表吧友情提醒

近来发现有些作者论文投稿存在大量剽窃、抄袭行为,“发表吧”对此类存在大量剽窃、抄袭的论文已经停止编辑、推荐。同时我们也提醒您,当您向“发表吧”投稿时请您一定要保证论文的原创性、唯一性,这既是对您自己负责,更是对他人的尊敬。

此类投稿的论文如果发表之后,对您今后的人生和事业将造成很大的麻烦,后果不堪设想,请您一定要慎重,三思而后行。

如因版权问题引起争议或任何其他原因,“发表吧”不承担任何法律责任,侵权法律责任概由剽窃、抄袭者本人承担。

 
QQ在线咨询
陈老师:275774677
张老师:1003180928
李老师:610071587
刘老师:1003160816
论文刊登热线:
137-7525-9981
微信号咨询:
fabiaoba-com

友情链接

申请链接