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

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash