Chinaunix首页 | 论坛 | 博客
  • 博客访问: 45125
  • 博文数量: 31
  • 博客积分: 2000
  • 博客等级: 大尉
  • 技术积分: 335
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-26 22:47
文章分类

全部博文(31)

文章存档

2011年(1)

2009年(30)

我的朋友

分类: C/C++

2009-06-23 21:48:24

      
 
 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:句柄
阅读(974) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~