| Solaris下PRO*C和OCI程序设计分析与比较2 |
这些变量是应用程序与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选项,它要求关闭所有打开的游标,之后断开与数据库服务器的连接。 |
|
|
|