对Oracle数据库编程的总结

数据库 Oracle
以下的文章是对Oracle数据库编程的总结,其中包括如何访问数据库的技术与方法,VC数据库的编程几种常用的方法的介绍。

本文是对Oracle数据库编程的总结 ,现在有很多的常用的数据库,其中包括Oracle, MS SQL Server, Sybase, Informix, MySQL, DB2, Interbase / Firebird, PostgreSQL, SQLite, SAP/DB, TimesTen, MS ACCESS等等。

数据库编程是对数据库的创建、读写等一列的操作。

数据库编程分为数据库客户端编程与数据库服务器端编程。数据库客户端编程主要使用ODBC API、ADO、ADO.NET、OCI、OTL等方法;数据库服务端编程主要使用OLE DB等方法。Oracle数据库编程需要掌握一些访问数据库技术方法,还需要注意怎么设计高效的数据库、数据库管理与运行的优化、数据库语句的优化。

一、访问数据库技术方法

数据库编程分为数据库客户端编程与数据库服务器端编程。数据库客户端编程主要使用ODBC API、ADO、ADO.NET、OCI、OTL等方法;数据库服务端编程主要使用OLE DB等方法。

1、几种是数据库访问方法比较

ODBC API是一种适合数据库底层开发的编程方法,ODBC API提供大量对数据源的操作,ODBC API能够灵活地操作游标,支持各种帮定选项,在所有ODBC相关编程中,API编程具有最高的执行速度。

DAO提供了很好的Oracle数据库编程的对象模型.但是,对数据库的所有调用以及输出的数据都必须通过Access/Jet数据库引擎,这对于使用数据库应用程序,是严重的瓶颈。

OLE DB提供了COM接口,与传统的数据库接口相比,有更好的健壮性和灵活性,具有很强的错误处理能力,能够同非关系数据源进行通信。

ADO最主要的优点在于易于使用、速度快、内存支出少和磁盘遗迹小。

ADO.NET 是利用数据集的概念将数据库数据读入内存中,然后在内存中对数据进行操作,最后将数据集数据回写到源数据库中。

OTL 是 Oracle, Odbc and DB2-CLI Template Library 的缩写,是一个C++编译中操控关系数据库的模板库, OTL中直接操作Oracle主要是通过Oracle提供的OCI接口进行,进行操作DB2数据库则是通过CLI接口来进行,至于MS的数据库和其它一些数据库,则OTL只提供了ODBC来操作的方式。

当然Oracle和DB2也可以由OTL间接使用ODBC的方式来进行操纵。具有以下优点:跨平台;运行效率高,与C语言直接调用API相当;开发效率高,起码比ADO.net使用起来更简单,更简洁;部署容易,不需要ADO组件,不需要.net framework 等。

2、VC数据库编程几种方法

VC数据库编程几种方法,包括ODBC连接、MFC ODBC连接、DAO连接、OLE DB、OLE DB Templates连接、ADO、Oracle专用方法(OCI(Oracle Call Interface)访问、Oracle Object OLE C++ Class Library )。

<1.>通用方法

1. ODBC连接

 

ODBC(Open DataBase Connectivity)是MSOA的一部分,是一个标准数据库接口。它提供对关系数据库访问的统一接口,实现对异构数据源的一致访问。

 

ODBC数据访问由以下部分组成:

<1>句柄(Handles):ODBC使用句柄来标识ODBC环境、连接、语句和描述器.

 

<2>缓存区(Buffers):

 

<3>数据类型(Data types)

 

<4>一致性级别(Conformance levels)

 

用ODBC设计客户端的一般步骤:

 

<1>分配ODBC环境

 

<2>分配连接句柄

 

<3>连接数据源

 

<4>构造和执行SQL语句

 

<5>获得查询结果

 

<6>断开数据源的连接

 

<7>释放ODBC环境

 

ODBC API是一种适合数据库底层开发的编程方法,ODBC API提供大量对数据源的操作,ODBC API能够灵活地操作游标,支持各种帮定选项,在所有ODBC相关编程中,API编程具有最高的执行速度.因此,ODBC API编程属于底层编程。

 

2. MFC ODBC连接

MFC ODBC是MFC对ODBC进行的封装,以简化对ODBC API的 调用,从而实现面向对象的Oracle数据库编程接口.

 

MFC ODBC的封装主要开发了CDatabase类和CRecordSet类

 

(1) CDatabase类

 

CDatabase类用于应用程序建立同数据源的连接。CDatabase类中包含一个m_hdbc变量,它代表了数据源的连接句柄。如果要建立CDatabase类的实例,应先调用该类的构造函数,再调用Open函数,通过调用,初始化环境变量,并执行与数据源的连接。在通过Close函数关闭数据源。

 

CDatabase类提供了对数据库进行操作的函数及事务操作。

 

(2) CRecordSet类

 

CRecordSet类定义了从数据库接收或者发送数据到数据库的成员变量,以实现对数据集的数据操作。

 

CRecordSet类的成员变量m_hstmt代表了定义该记录集的SQL语句句柄,m_nFields为记录集中字段的个数,m_nParams为记录集所使用的参数个数。

 

CRecordSet的记录集通过CDatabase实例的指针实现同数据源的连接,即CRecordSet的成员变量m_pDatabase.

 

MFC ODBC编程更适合于界面型数据库应用程序的开发,但由于CDatabase类和CRecordSet类提供的数据库操作函数有限,支持的游标类型也有限,限制了高效的数据库开发。在编程层次上属于高级编程。

 

【编辑推荐】

  1. Oracle查询分页的存储过程实际代码示例
  2. Oracle数据库的安全,PL/SQL的SQL注入
  3. Oracle应用顾问发展计划 着力培养实用型软件人才
  4. Oracle 字符串split的相关实际应用代码介绍
  5. Oracle创建Split 与Map 函数的代码示例
责任编辑:佚名 来源: 互联网
相关推荐

2010-04-19 13:59:17

Oracle 数据库

2010-04-20 10:41:49

Oracle数据库

2011-04-12 10:09:33

Oracle数据库关闭

2010-04-14 13:14:46

Oracle数据库

2011-06-14 15:11:59

ORACLE

2011-09-02 10:06:51

OracleSqlLoad常用技巧

2010-04-13 10:55:35

Oracle数据库

2010-04-21 09:49:10

Oracle数据库字符

2009-06-30 15:02:41

磁盘排序Oracle数据库性能

2010-05-04 17:08:24

Oracle数据库

2011-03-17 14:09:25

Oracle数据库字符

2011-11-03 16:57:42

NoSQL

2010-04-01 17:06:57

Oracle数据库

2010-11-15 10:30:04

Oracle数据库启动

2019-08-28 07:11:00

Oracle数据库LOB

2011-08-09 18:15:24

Oracle 10g查找数据

2011-08-10 15:38:12

ConstraintOracle

2011-07-29 15:31:52

Oracle数据库ORDER BY

2010-05-04 11:02:44

Oracle数据库

2010-06-01 09:22:35

MySQL数据库
点赞
收藏

51CTO技术栈公众号