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

相关文章

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有