OCI编程高级篇(十九) 创建和使用OCI连接池

2024-09-05 07:04

本文主要是介绍OCI编程高级篇(十九) 创建和使用OCI连接池,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一节介绍了连接池的概念和使用连接池的步骤,这一节看看具体的操作是怎样的,先看一下用到的函数原型和参数。

创建连接池函数OCIConnectionPoolCreate(),原型和参数如下。

sword OCIConnectionPoolCreate ( OCIEnv *envhp,
    OCIError          *errhp,
    OCICPool        *poolhp,
    OraText            **poolName,
    sb4                   *poolNameLen,
    const OraText  *dblink,
    sb4                   dblinkLen,
    ub4                   connMin,
    ub4                   connMax,
    ub4                   connIncr,
    const OraText  *poolUsername,
    sb4                   poolUserLen,
    const OraText  *poolPassword,
    sb4                   poolPassLen,
    ub4                   mode );

envhp是一个输入参数,OCI环境句柄。

errhp是一个输入/输出参数,错误句柄,返回错误码和错误信息文本。

poolhp是一个输入参数,连接池句柄,调用函数前要先分配一个,父句柄是envhp。

poolName是一个输出参数,返回连接池的名称,后面的函数会用到。

poolNameLen是一个输出参数,返回连接池名称的长度,后面的函数会用到。

dblink是一个输入参数,连接数据库的连接字符串,可以是TNS名称。

dblinkLen是一个输入参数,连接字符串的长度。

connMin是一个输入参数,与后面的两个参数一起决定连接池到数据库的连接个数,这个是连接池创建时与数据库建立的最小连接数,最小可以是0,有用户请求时再创建。

connMax是一个输入参数,限制连接池与数据库的最大连接数。

connIncr是一个输入参数,表示连接达到最小值,有新连接请求时每次增长的连接个数。

poolUsername是一个输入参数,连接池会隐含的开启一个与数据库的会话,这是会话认证时的用户名称。

poolUserLen是一个输入参数,认证用户名称的长度。

poolPassword是一个输入参数,认证用户的密码。

poolPassLen是一个输入参数,密码长度。

mode是一个输入参数,一般选择OCI_DEFAULT。

获取连接池的会话函数,有两个可用一个是OCILogon2(),另一个是OCISessionGet()。先看第一个。

sword OCILogon2 ( OCIEnv *envhp,
    OCIError         *errhp,
    OCISvcCtx      **svchp,
    const OraText  *username,
    ub4                  uname_len,
    const OraText  *password,
    ub4                  passwd_len,
    const OraText  *dbname,
    ub4                  dbname_len );
    ub4                  mode );

envhp是一个输入参数,OCI环境句柄。

errhp是一个输入/输出参数,错误句柄,返回错误码和错误信息文本。

svchp是一个输入/输出参数,服务上下文句柄。这个句柄不需要分配,OCI会自动分配这个句柄,函数还会自动分配一个服务器句柄和开启一个会话句柄,并且把这两个句柄设置到服务上下文句柄的属性中。

username是一个输入参数,用于会话认证的用户名。

uname_len是一个输入参数,认证用户的长度。

password是一个输入参数,认证用户的密码。

passwd_len是一个输入参数,认证密码长度。

dbname是一个输入参数,在这里要输入连接池的名称。

dbname_len是一个输入参数,连接池名称的长度。

mode是一个输入参数,这里要选择OCI_LOGON2_CPOOL。

另一个函数是OCISessionGet(),这个函数传入一个认证信息句柄,可以更细致的控制认证过程。

sword OCISessionGet ( OCIenv *envhp,
    OCIError          *errhp,
    OCISvcCtx      **svchp,
    OCIAuthInfo    *authInfop,
    OraText           *dbName,
    ub4                  dbName_len,
    const OraText *tagInfo,
    ub4                  tagInfo_len,
    OraText           **retTagInfo,
    ub4                  *retTagInfo_len,
    boolean           *found,
    ub4                  mode );

envhp是一个输入/输出参数,OCI环境句柄。

errhp是一个输入/输出参数,错误句柄,返回错误码和错误信息文本。

svchp是一个输入参数,服务上下文句柄。这个句柄不需要分配,OCI会自动分配这个句柄,函数还会自动分配一个服务器句柄和开启一个会话句柄,并且把这两个句柄设置到服务上下文句柄的属性中。

authInfop是一个输入参数,认证信息句柄,要预先分配,父句柄是envhp,使用OCI_HTYPE_AUTHINFO类型,分配句柄后要设置认证用户和密码的属性。

dbName是一个输入参数,连接池名称,创建连接池时返回。

dbName_len是一个输入参数,连接池名称长度。

tagInfo是一个输入参数,会话标签信息,只用于会话池的参数,设置为NULL。

tagInfo_len是一个输入参数,会话标签信息长度。

retTagInfo是一个输出参数,返回的会话标签信息,指示会话的类型,只用于会话池的参数,设置为NULL。

retTagInfo_len是一个输出参数,返回的会话标签信息长度。

found是一个输出参数。用于会话池的参数,设置为NULL。

mode是一个输入参数,取值OCI_SESSGET_CPOOL。

前面是创建连接池和获取会话的函数,中间可以通过会话执行数据库操作的其他OCI函数。后面是释放会话和删除连接池的函数。

如果前面用了OCILogon2()函数来取得会话,那么要用OCILogoff()函数来释放会话。

sword OCILogoff ( OCISvcCtx *svchp, OCIError *errhp );

svchp是一个输入参数,服务上下文句柄,从OCILogon2()函数中返回的句柄。

errhp是一个输入/输出参数,错误句柄,返回错误码和错误信息文本。

如果前面使用了OCISessionGet()函数来获取会话,那么要用OCISessionRelease()函数来释放会话。

sword OCISessionRelease ( OCISvcCtx *svchp,
    OCIError  *errhp,
    OraText   *tag,
    ub4          tag_len,
    ub4          mode );

svchp是一个输入参数,服务上下文句柄,从OCISessionGet()函数中返回的句柄。

errhp是一个输入/输出参数,错误句柄,返回错误码和错误信息文本。

tag是一个输入参数,只用于会话池的参数,设置为NULL。

tag_len是一个输入参数,只用于会话池的参数,设置为0。

mode是一个输入参数,取值OCI_DEFAULT。

删除掉连接池,函数为OCIConnectionPoolDestroy(),原型和参数如下。

sword OCIConnectionPoolDestroy ( OCICPool *poolhp,
    OCIError *errhp,
    ub4         mode );

poolhp是一个输入参数,连接池句柄,与创建时的一致。

errhp是一个输入/输出参数,错误句柄,返回错误码和错误信息文本。

mode是一个输入参数,取值OCI_DEFAULT。

上面这些就是使用连接池时用到的函数,其他一些分配句柄函数OCIHandleAlloc()和设置属性函数OCIAttrSet()已经在前面介绍过了,这里从略。

下一节我们写一段代码,来看看使用连接池的整个过程。

这篇关于OCI编程高级篇(十九) 创建和使用OCI连接池的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138271

相关文章

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.