pro*c介绍

PRO*C介绍  

2007-11-09 09:20:02|  分类: Oracle |字号 订阅

PRO*C是Oracle提供的应用程序专用开发工具,它以C语言为宿主语言,能在C程序中嵌入SQL语句,进行数据库操作。这种嵌入式的SQL语句容易掌握,适合初学者。

1、设置开发环境
(1)C编译器
Solaris系统中常用的C语言编译器是GCC,是GNU组织的免费C编译器,一般Linux版本中缺省都安装有GCC,UNIX系统中有的并不自带,因此需要手动安装,本文所采用的GCC版本为3.2。
(2)PRO*C预编译器
PRO*C使用预编译技术,预编译器将源程序中的SQL语句转换为标准的Oracle库函数调用,从而生成C源程序,再经C编译器编译、链接后生成可执行文件。这个预编译器是Oracle自带的。
(3)C语言头文件和函数库。
Oracle安装程序将这些文件安装在$ORACLE_HOME/precomp目录下。

2、开发PRO*C程序
(1)说明SQL通讯区
SQL通讯区用来记录执行每一个嵌入SQL语句的状态信息,通过在函数体外使用下列语句实现:
#include <sqlca.h> 或者 EXEC SQL INCLUDE sqlca;

(2)声明宿主变量,即C变量
这些变量是应用程序与Oracle通信的桥梁,应用程序的输入数据通过C变量传递给Oracle,反之,Oracle的输出数据又通过C变量传递给应用程序。举例如下:
EXEC SQL BEGIN DECLARE SECTION;
char szUsername[16];
VARCHAR varPassword[16];
char *szStmt1="CREATE TABLE USERS (USERNAME VARCHAR2(15) NOT NULL,PASSWORD
VARCHAR2(15) NOT NULL)";
char *szStmt2= "SELECT PASSWORD FROM USERS WHERE USERNAME='chen'";
EXEC SQL END DECLARE SECTION;

值得注意的是:在SQL语句中使用C变量时,前面需加冒号,例如上面的变量应表示为:szUsername。其中,VARCHAR为C扩展数据类型,预编译时,PRO*C预编译器将它扩展为一个C结构类型
struct
{
unsigned short len;
unsigned char arr[16];
}varNo;
在SQL语句中使用VARCHAR类型变量时,只需指出结构名称varPassword就可,但在C语句中使用VARCHAR类型变量时,必须具体说明所操作变量的结构元素名称是varPassword.len还是varPassword.arr。另外,如果用VARCHAR类型变量做函数参数的话,只能用指针形式。

(3)连接数据库
EXEC SQL CONNECT :username/password@DBname;
通过sqlca.sqlcode的值来判断连接数据库成是否功。

(4)执行SQL语句(分为静态SQL语句和动态SQL语句)
静态SQL语句是在开发应用程序时就已经明确了的数据库操作,如:
EXEC SQL SELECT password INTO :szPassword FROM USERS WHERE username=:szUsername;

动态SQL语句是在运行时由外部数据提供的,不能直接在C程序中嵌入SQL 语句,但可以调用放在一个字符串变量里的SQL语句,最简单的方法是:EXEC SQL EXECUTE IMMEDIATE :szStmt1;但这样执行的SQL语句不能实现查询,实现查询可用下列方法:
EXEC SQL PREPARE select_stmt FROM :szStmt2;
EXEC SQL EXECUTE select_stmt INTO :szPassword;

如果不再需要已准备好的语句,应释放:EXEC SQL DEALLOCATE PREPARE select_stmt;

(5)提交或回滚所做的数据库处理,并退出数据库
回滚:EXEC SQL ROLLBACK WORK RELEASE;
提交:EXEC SQL COMMIT WORK RELEASE;
注意语句中的RELEASE选项,它要求关闭所有打开的游标,之后断开与数据库服务器的连接。

3、生成可执行文件
在Solaris平台下可通过命令方式对PRO*C源程序进行预编译,下列命令只列出了最常用的预编译选项:
#proc iname=example.c INCLUDE=path CODE=ANSI_C MODE=ANSI CPP_SUFFIX=cc SQLCHECK=SEMANTICS USERID=username/password@DBname
预编译后的example.cc文件就可以当作普通的C源文件来进行处理了。
#gcc -o exampled –I. -I/oracle/product/8.1.7/precomp/public example.cc
最终生成的exampled文件就是我们的可执行文件。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
IDA Pro是一款非常专业的可编程、可扩展的交互式多处理器反汇编程序。它是逆向工程师、安全分析人员和CTF竞赛选手常用的工具之一。IDA Pro支持多种CPU指令集,包括Intel x86、x64、MIPS、PowerPC、ARM、Z80、68000、c8051等等。它使用数据类型信息和派生的变量和函数名称来注释生成的反汇编代码,并提供符号化信息。IDA Pro还支持Python插件,用户可以利用插件来提供更多的功能,大大减少工作量。它还采用了先进的逆向工程技术,能够帮助用户反向编译源代码,并解决反编译相关问题。总的来说,IDA Pro是反编译领域中不可或缺的工具之一。 要安装和使用IDA Pro,您可以按照以下步骤操作: 1. 在官方网站下载IDA Pro软件包并解压缩。 2. 运行"IDAProHelper.exe"程序进行绿化。 3. 运行主程序,选择适合您的操作系统的版本。 4. 新建一个空程序,然后加载要逆向的文件。 5. 可以使用工具栏和导航栏浏览和分析加载文件的反汇编代码。 6. 您还可以打开其他窗口,如Hex_View窗口、Exports窗口和functions窗口,以获取更多的信息。 7. 最后,记得保存您的工作。 以上是关于IDA Pro反编译工具的简要介绍和安装使用步骤。希望对您有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [使用ida pro做反编译时,要注意类型转换](https://blog.csdn.net/zhangzhm/article/details/93861843)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [反编汇ida pro 7.5](https://blog.csdn.net/weixin_45078818/article/details/111359136)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值