OCI(Oracle Call Interface)接口编程(oracle)

OCI(Oracle Call Interface)是ORACLE公司开发的一个应用程序开发工具,是一个通过访问Oracle数据库的服务器,控制各类SQL语句的执行,进而创建应用程序的的应用程序接口(API)。它支持SQL所有的数据定义,数据操作,查询,事务管理等操作,支持C和C++的数据类型,调用,语法和语义。它提供了一组可对Oracle数据库进行存取的接口子例程(函数)。 OCI程序实质上就是用高级语言写的程序,其特点是内部含有对OCI子函数库的调用,通过在第三代程序设计语言(如C语言)中进行调用可达到存取ORACLE数据库的目的。 OCI基本编程流程如图所示: 1,创建和初始化OCI环境。OCI环境即OCI函数的工作环境,在调用其他函数之前必须先调用OCIInitialize()和OCIEnvInit()函数创建和初始化OCI环境,其他OCI函数要在这个环境中才能执行。 swordOCIEnvInit(OCIEnv**envhpp,ub4mode,size_txtramemsz,dvoid**usrmempp); 参数: envhp:环境句柄的指针 mode:初始化模式,OCI_DEFAULT,OCI_THREADED等 xtramemsz:在应用程序中需要分配的内存的大小 usrmempp:返回指向刚分配的用户内存的指针 2,申请句柄 句柄是指向OCI库所分配的内存区域的指针,该内存区域中的数据由OCI库维护,应用程序可通过句柄访问其中的数据。 一个句柄可以用来存放上下文或连接信息(如环境或服务上下文句柄).它是由链接库管理,可以简化编程。利用OCIAtrrtGet()和OCIAtrrSet()这些获取或设置属性的OCI接口可以访问到句柄中存放信息。 需要申请的句柄一般有以下几类: 服务器句柄OCIServer,句柄类型OCI_HTYPE_SERVER 错误句柄OCIError,用于捕获OCI错误信息,句柄类型OCI_HTYPE_ERROR 事务句柄OCISession,句柄类型OCI_HTYPE_SESSION 上下文句柄OCISvcCtx,句柄类型OCI_HTYPE_SVCCTX SQL语句句柄OCIStmt,句柄类型OCI_HTYPE_STMT 需要设置的句柄属性: 服务器实例: 句柄类型OCI_HTYPE_SVCCTX,属性类型OCI_ATTR_SERVER 连接数据的用户名: 句柄类型OCI_HTYPE_SESSION,属性类型OCI_ATTR_USERNAME 用户密码: 句柄类型OCI_HTYPE_SESSION,属性类型OCI_ATTR_PASSWORD 事务: 句柄类型OCI_HTYPE_SVCCTX,属性类型OCI_ATTR_SESSION OCIHandleAlloc()——分配句柄,返回刚初始化的句柄指针 swordOCIHandleAlloc(CONSTdvoid*parenth,dvoid**hndlpp,ub4type,size_txtramem_sz,dvoid**usrmempp); 参数: parenth:新申请句柄的父句柄,一般为OCI环境句柄 hndlpp:申请的新句柄 type:OCI句柄类型 xtramem_sz:为句柄分配内存的大小 usrmempp:申请到的内存块指针 3,连接服务器,建立会话 OCIServerAttach(m_srvhp,m_errhp,(text*)"",strlen(""),OCI_DEFAULT);建立与指定服务器的连接 参数: text*:类型变量为空,表示连接默认数据库服务 OCI_DEFAUL:表示应用程序的操作模式为阻塞模式,在这种方式下,只有当OCI调用完成后才将控制权返回给客户端应用程序。 这里,只介绍单用户,单连接的情况: OCILogon(envhp,errhp,&svchp,(text*)"hr",nameLen,(text*)"hr",passwdLen,(text*)"oracledb",dbnameLen); 使用了这种方法之后,servicecontext,server,andusersessionhandles都是只读的,不能通过OCIAttrSet()对其属性进行改写。 使用OCILogon()后,在程序结束时,必须使用OCILogoff()来终止它。 4,执行SQL语句并处理数据 5,结束会话断开数据库连接 使用OCISessionEnd()删除每一个用户会话。 OCILogoff(m_svchp,m_errhp); 6,断开与数据源的连接,释放句柄 OCIServerDetach()断开与数据源的连接: OCIServerDetach(m_srvhp,m_errhp,OCI_DEFAULT); OCIHandleFree()释放所有已分配的句柄 OCIHandleFree――释放句柄 swordOCIHandleFree(dvoid*hndlp,ub4type); 参数: *hndlp:要释放的句柄 ub4type:句柄类型
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值