数据库

本类阅读TOP10

·SQL语句导入导出大全
·SQL Server日期计算
·SQL语句导入导出大全
·SQL to Excel 的应用
·Oracle中password file的作用及说明
·MS SQLServer OLEDB分布式事务无法启动的一般解决方案
·sqlserver2000数据库置疑的解决方法
·一个比较实用的大数据量分页存储过程
·如何在正运行 SQL Server 7.0 的服务器之间传输登录和密码
·SQL中两台服务器间使用连接服务器

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
oracle pro*c 学习笔记

作者:未知 来源:月光软件站 加入时间:2005-5-13 月光软件站

目前在重建一个LINUX下的服务程序,需要用到ORACLE 的PRO*C。以下是学习笔录:

一、PRO*C简介

ORACLE除了提供SQL * PLUS,SQL * FORMS等数据库访问工具进行数据库访问外还可以在第三代高级语言中内嵌SQL语句或ORACLE函数的方式来访问ORACLE数据库。目前ORACLE支持的语言有C,FORTRAN,PASCAL等,采用C的部分就叫做PRO*C。其中内嵌的SQL语句包括了DML,DDL语句,可以实现动态的建立,修改,删除数据库中的表,也可以查询,插入,删除表中的表中的行,实现数据库操作的提交和回滚。使用第三代高级语言内嵌SQL语句的好处有如下三点:

1、过程化语言与非过程化语言相结合可以满足各种复杂要求的应用,还可以引用窗口和鼠标技术。

2、可以使开发的应用程序具有管理资源,SQL语句执行和指示器等能力

3、提高应用程序的执行速度。

所有PRO*C的程序在编译前都要经过ORACLE的预编译系统进行预编译,预编译系统允许采用动态SQL技术,能实现内部和外部数据类型的转换,可以嵌入PL/SQL块,能用数据类型等价来控制ORACLE解释输入数据和格式化输出数据,可以检查嵌入的SQL语句的语法和语义,可以使用数组SQL变量能利用SQLCA和ORACA进行错误诊断。

二、PRO*C程序结构

一般PRO*C主要有外部说明段与程序主体两部分组成。

外部说明段:主要说明了程序中要引用到的外部变量和函数,包括了说明段,通讯区说明和C语言的相关声明。

程序主体:同一般C程序的主体部分,可以用多个函数或仅有MAIN函数。函数中又可以包含局部说明段,局部通讯区声明和C局部变量声明。

说明段语法如下:

EXEC SQL BEGIN DECLARE SECTION;

(SQL变量声明)

EXEC SQL END DECLARE SECTION;

通讯区说明语句为:EXEC SQL INCLUDE SQLCA;

其中SQLCA为结构体,具体内容可以查看ORACLE预编译系统的头文件sqlca.h(windows 下的路径为:$orahome\precomp\public\)

struct   sqlca
{
    char    sqlcaid[8];
    int     sqlabc;
    int     sqlcode;    /*等同与SQLCODE指示SQL错误代码
    struct
     {                        /*结构体等同于SQLERRM用户贮存SQL错误信息。
         unsigned short sqlerrml;
         char           sqlerrmc[70];
     } sqlerrm;
    char    sqlerrp[8];
    int     sqlerrd[6];
    char    sqlwarn[8];
    char    sqlext[8];
};




相关文章

相关软件