OCI 简介

简介: 文章整理自网络: oci - 简介        OCI(Oracle Call Interface)是ORACLE公司开发的一个应用程序开发工具,是一个通过访问Oracle数据库的服务器,控制各类SQL语句的执行,进而创建应用程序的的应用程序接口(API)。

文章整理自网络:

oci - 简介

       OCI(Oracle Call Interface)是ORACLE公司开发的一个应用程序开发工具,是一个通过访问Oracle数据库的服务器,控制各类SQL语句的执行,进而创建应用程序的的应用程序接口(API)。它支持SQL所有的数据定义,数据操作,查询,事务管理等操作,支持C和C++的数据类型,调用,语法和语义。它提供了一组可对Oracle数据库进行存取的接口子例程(函数)。
       OCI程序实质上就是用高级语言写的程序,其特点是内部含有对OCI子函数库的调用,通过在第三代程序设计语言(如C语言)中进行调用可达到存取ORACLE数据库的目的。

oci - 函数名称

ORACLE调用接口(Oracle Call Interface简称OCI)

oci - 函数功能

提供了一组可对ORACLE数据库进行存取的接口子例程(函数),通过在第三代程序设计语言(如C语言)中进行调用可达到存取ORACLE数据库的目的

oci - 基本编程流程

OCI基本编程流程如图所示:



       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:句柄类型

相关文章
|
6月前
|
Oracle 关系型数据库 数据库
Oracle 简介与 Docker Compose部署
Oracle 数据库是一款由 Oracle 公司开发的关系型数据库管理系统(RDBMS)。它被广泛应用于企业级应用程序,提供了可靠的数据存储和强大的数据管理功能。
249 1
Oracle 简介与 Docker Compose部署
|
Kubernetes 程序员 应用服务中间件
Kubernetes深入学习之二:编译和部署镜像(api-server)
在k8s的源码包中,除了kubectl这样的可执行程序,还有api-server、controller-manager这些docker容器,今天的实战是修改这些容器镜像的源码,再部署新的镜像,验证我们修改的代码是否生效
539 0
Kubernetes深入学习之二:编译和部署镜像(api-server)
|
开发框架 数据可视化 JavaScript
DM 平台 /netcore 开源框架
DLVM 是一个集数据库、逻辑、视图及模型为一体的并涵盖了常用基础套件,以 NetCore 为主的底层框架。具备安全性、可扩展性、可配置性及可视化操作等优点,并且具有一键创建模块的功能。
245 0
DM 平台 /netcore 开源框架
|
存储 Kubernetes 安全
真正运行容器的工具:深入了解 runc 和 OCI 规范
真正运行容器的工具:深入了解 runc 和 OCI 规范
真正运行容器的工具:深入了解 runc 和 OCI 规范
|
开发者 Docker 容器
SAP ABAP Platform 1909最新版的 docker 镜像
SAP ABAP Platform 1909最新版的 docker 镜像
556 0
SAP ABAP Platform 1909最新版的 docker 镜像
|
SQL 存储 Kubernetes
把运行在 Docker 容器内的 Microsoft SQL 服务器部署到 SAP Kyma 中
把运行在 Docker 容器内的 Microsoft SQL 服务器部署到 SAP Kyma 中
116 0
把运行在 Docker 容器内的 Microsoft SQL 服务器部署到 SAP Kyma 中
|
Linux 开发工具 Docker
使用 Docker CLI 将 CE 引擎升级到 EE 引擎
Docker 船长 Sujay Pillai 使用 Docker CLI 将 CE 引擎升级到 EE 引擎。
2461 0
|
存储 NoSQL 应用服务中间件
最佳实践系列丨Docker EE 服务发现参考架构(三)
现在您已经了解了 HRM 的工作原理和与它相关的要求,本部分将介绍用于 HTTP 路由、日志记录、监控和从节点的 HRM 语法。
2236 0
|
网络协议 前端开发 数据安全/隐私保护
最佳实践系列丨Docker EE 服务发现参考架构(二)
swarm mode 网格路由非常适合传输层路由。它使用服务的已发布端口路由到服务。但是,如果希望基于主机名将流量路由到服务应该怎么办?
2141 0
|
运维 负载均衡 网络协议
最佳实践系列丨Docker EE 服务发现参考架构(一)
服务发现对服务进行注册并发布其连接信息,以使其他服务了解如何连接到服务。随着应用向微服务和面向服务的架构转变,服务发现已经成为所有分布式系统的必要组成部分,增加了这些环境的运维复杂性。
8067 0