版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Solaris下PROC和OCI程序设计分析与比较
摘要文章对Solaris平台下,开发基于Oracle数据库的C程序的两种方法——PRO*C和OCI进行了研究,详细分析了这两种方法的开发流程,给出了较为具体的应用程序例子,并对两者的性能进行了比较。关键词Solaris,Oracle,PRO*C,OCI1引言数据库在软件开发中的应用越来越广泛,其中,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,PASSWORDVARCHAR2(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=ccSQLCHECK=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头文件。3.2申请句柄句柄是指向OCI库所分配的内存区域的指针,该内存区域中的数据由OCI库维护,应用程序可通过句柄访问其中的数据。下面是应用程序中最常用的几个句柄:
OCIHandleAlloc((dvoid*)m_envhp,(dvoid**)&m_errhp,OCI_HTYPE_ERROR,(size_t)0,(dvoid**)0);OCIHandleAlloc((dvoid*)m_envhp,(dvoid**)&m_srvhp,OCI_HTYPE_SERVER,
(size_t)0,(dvoid**)0);OCIHandleAlloc((dvoid*)m_envhp,(dvoid**)&m_svchp,OCI_HTYPE_SVCCTX,
(size_t)0,(dvoid**)0);OCIHandleAlloc((dvoid*)m_envhp,(dvoid**)&m_stmthp,OCI_HTYPE_STMT,
(size_t)0,(dvoid**)0);其中m_errhp为新申请的句柄,m_envhp为它的父环境句柄,OCI_HTYPE_ERROR为句柄类型,表示这是一个错误报告句柄,OCI_HTYPE_SERVER表示服务器句柄,OCI_HTYPE_SVCCTX表示服务环境句柄,OCI_HTYPE_STMT表示语句句柄。存储在句柄中的数据称为句柄属性,所有OCI句柄都具有属性,可以调用OCIAttrGet()和OCIAttrSet()函数来读取、设置句柄属性。3.3连接服务器建立会话首先调用OCIServerAttach(m_srvhp,m_errhp,(text*)"",strlen(""),OCI_DEFAULT);函数建立与指定服务器的连接,text*类型变量为空,表示连接默认数据库服务,OCI_DEFAULT表示应用程序的操作模式为阻塞模式,在这种方式下,只有当OCI调用完成后才将控制权返回给客户端应用程序。然后调用OCILogon(m_envhp,m_errhp,&m_svchp,(text*)m_szUser,strlen(m_szUser),(text*)m_szPassword,strlen(m_szPassword),(text*)m_szDbName,strlen(m_szDbName));建立数据库会话。此函数隐含申请服务器句柄和用户会话句柄,登录后,句柄是只读的,不能再设置句柄属性。3.4执行SQL语句并处理数据将要执行的SQL语句copy到szSqlStr字符串中,snprintf(szSqlStr,sizeof(szSqlStr),"selectPASSWORDfromUSERSwhereUSERNAME=’chen’");执行下列语句:OCIStmtPrepare(m_stmthp,m_errhp,(text*)szSqlStr,(ub4)strlen(szSqlStr),(ub4)OCI_NTV_SYNTAX,(ub4)OCI_DEFAULT);
//准备SQL语句OCIDefine*defnp0=(OCIDefine*)0;
//定义输出变量OCIDefineByPos(m_stmthp,&defnp0,m_errhp,1,(dvoid*)szUSERNAME,100,SQLT_STR,(dvoid*)0,(ub2*)0,(ub2*)0,OCI_DEFAULT);
//绑定变量OCIStmtExecute(m_svchp,m_stmthp,m_errhp,(ub4)1,(ub4)0,(OCISnapshot*)NULL,(OCISnapshot*)NULL,(ub4)OCI_DEFAULT);
//执行SQL语句3.5结束会话断开数据库连接
OCILogoff(m_svchp,m_errhp);3.6断开与数据源的连接,释放句柄OCIServerDetach(m_srvhp,m_errhp,OCI_DEFAULT);
//断开与数据源的连接OCIHandleFree((dvoid*)m_stmthp,OCI_HTYPE_STMT);
//释放句柄OCIHandleFree((dvoid*)m_svchp,OCI_HTYPE_SVCCTX);OCIHandleFree((dvoid*)m_srvhp,OCI_HTYPE_SERVER);OCIHandleFree((dvoid*)m_errhp,OCI_HTYPE_ERROR)3.7生成可执行文件(两种方法)(1)同普通的C程序:#gcc-oexampled–I.–I$(ORACLE_HOME)/precomp/publicexample.c(2)利用Oracle自带的Make文件:首先将$ORACLE_HOME/rdbms/demo/demo_rdbms.mk文件copy到OCI源程序所在的目录,将源文件编译为目标文件:#gcc–cexample.o-I$(ORACLE_HOM
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 劳务废止后保密协议书(2篇)
- 二零二四年建筑工程ALC隔墙板分包项目验收合同
- 个人借款合同标准文本模板
- 临时用电工程招标须知
- 机器机电安装分包协议
- 锅炉招标文件的投标合同履行团队建设
- 小程序用户协议
- 夫妻忠诚协议书完整
- 合同权益转让的财务处理
- 文艺演出与拍摄服务协议
- 《人际关系处理》课件
- 2024版熔化焊接与热切割模拟测试题库含答案 全套
- 中国工会十八大精神知识答题(试题及答案)
- 灵敏素质(教案)人教版体育五年级上册
- 手术室手术器械遗失原因分析品管圈鱼骨图柏拉图对策拟定
- DLT817-2014 立式水轮发电机检修技术规程
- 电线电缆生产企业自查报告
- 建筑机械使用安全技术规程
- 排列与排列数-(课件)
- 适老化改造投标方案
- 英语听力技巧与应用(山东联盟)智慧树知到课后章节答案2023年下滨州学院
评论
0/150
提交评论