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

相关文章

Mac备忘录怎么导出/备份和云同步? Mac备忘录使用技巧

《Mac备忘录怎么导出/备份和云同步?Mac备忘录使用技巧》备忘录作为iOS里简单而又不可或缺的一个系统应用,上手容易,可以满足我们日常生活中各种记录的需求,今天我们就来看看Mac备忘录的导出、... 「备忘录」是 MAC 上的一款常用应用,它可以帮助我们捕捉灵感、记录待办事项或保存重要信息。为了便于在不同

如何Python使用设置word的页边距

《如何Python使用设置word的页边距》在编写或处理Word文档的过程中,页边距是一个不可忽视的排版要素,本文将介绍如何使用Python设置Word文档中各个节的页边距,需要的可以参考下... 目录操作步骤代码示例页边距单位说明应用场景与高级用China编程途小结在编写或处理Word文档的过程中,页边距是一个

SpringBoot项目Web拦截器使用的多种方式

《SpringBoot项目Web拦截器使用的多种方式》在SpringBoot应用中,Web拦截器(Interceptor)是一种用于在请求处理的不同阶段执行自定义逻辑的机制,下面给大家介绍Sprin... 目录一、实现 HandlerInterceptor 接口1、创建HandlerInterceptor实

使用JavaConfig配置Spring的流程步骤

《使用JavaConfig配置Spring的流程步骤》JavaConfig是Spring框架提供的一种基于Java的配置方式,它通过使用@Configuration注解标记的类来替代传统的XML配置文... 目录一、什么是 JavaConfig?1. 核心注解2. 与 XML 配置的对比二、JavaConf

使用Python和Tkinter实现html标签去除工具

《使用Python和Tkinter实现html标签去除工具》本文介绍用Python和Tkinter开发的HTML标签去除工具,支持去除HTML标签、转义实体并输出纯文本,提供图形界面操作及复制功能,需... 目录html 标签去除工具功能介绍创作过程1. 技术选型2. 核心实现逻辑3. 用户体验增强如何运行

Go语言中使用JWT进行身份验证的几种方式

《Go语言中使用JWT进行身份验证的几种方式》本文主要介绍了Go语言中使用JWT进行身份验证的几种方式,包括dgrijalva/jwt-go、golang-jwt/jwt、lestrrat-go/jw... 目录简介1. github.com/dgrijalva/jwt-go安装:使用示例:解释:2. gi

Python使用python-docx实现自动化处理Word文档

《Python使用python-docx实现自动化处理Word文档》这篇文章主要为大家展示了Python如何通过代码实现段落样式复制,HTML表格转Word表格以及动态生成可定制化模板的功能,感兴趣的... 目录一、引言二、核心功能模块解析1. 段落样式与图片复制2. html表格转Word表格3. 模板生

go rate 原生标准限速库的使用

《gorate原生标准限速库的使用》本文主要介绍了Go标准库golang.org/x/time/rate实现限流,采用令牌桶算法控制请求速率,提供Allow/Reserve/Wait方法,具有一定... 目录介绍安装API介绍rate.NewLimiter:创建限流器limiter.Allow():请求是否

Python使用Turtle实现精确计时工具

《Python使用Turtle实现精确计时工具》这篇文章主要为大家详细介绍了Python如何使用Turtle实现精确计时工具,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录功能特点使用方法程序架构设计代码详解窗口和画笔创建时间和状态显示更新计时器控制逻辑计时器重置功能事件

Swagger2与Springdoc集成与使用详解

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1. 依赖配置2. 基础配置2.1 启用 Springdoc2.2 自定义 OpenAPI 信息3.