六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 41|回复: 0

[转]PROC中的4种动态SQL简介

[复制链接]

升级  90.33%

143

主题

143

主题

143

主题

举人

Rank: 3Rank: 3

积分
471
 楼主| 发表于 2013-1-26 12:34:04 | 显示全部楼层 |阅读模式
http://oracle.chinaitlab.com/exploiture/38243.html
  

  (1)动态SQL1: 不能是查询(SELECT)语句,并且没有宿主变量.
  
  用法:拼一串动态SQL语句,并用EXECUTE IMMEDIATE执行,如:
  EXEC SQL EXECUTE IMMEDIATE "CREATE TABLE dyn1 (col1 VARCHAR2(4))";  
  (2)动态SQL2: 不能是查询(SELECT)语句,并且输入的宿主变量数目是知道的,
  
  用法:拼一串动态SQL语句,用PREPARE,EXECUTE语句执行.
  strcpy(c_sql, "DELETE FROM EMP WHERE EMPNO = ");  EXEC SQL PREPARE sql_stmt FROM :c_sql;  EXEC SQL EXECUTE sql_stmt USING :emp_number;  
  (3)动态SQL3: 用于创建动态查询, 并且要查询的字段及输入的宿主变量数目是知道的
  
  用法: 拼一串动态SQL语句,用PREPARE分析该语句,并要定义一个CURSOR进行取值
  
  如:如要查询的数据按一年12月放到12张表中。表名为user_fee_1mon, user_fee_2mon,....可采用动态SQL3来进行查询
  strcpy(c_sql,"select c_user_id,c_user_name,to_char(t_date,'yyyy/mm/dd hh:mi:ss'),n_fee\n");  strcat(c_sql,"from USER_FEE_");  strcat(c_sql,ac_mon);  strcat(c_sql," \n where c_user_id = :v1");    EXEC SQL PREPARE s FROM :c_sql;    EXEC SQL DECLARE cur_user_fee CURSOR FOR s;    EXEC SQL OPEN cur_user_fee USING :ac_user_id;    while(1)  {    EXEC SQL FETCH cur_user_fee into :c_user_id,:c_user_name,:c_date,:n_fee);    if (sqlca.sqlcode < 0)  {  /*FETCH CURSOR失败*/  printf("fetch cursor cur_user_fee fail,sqlcode=%ld,sqlserr=%s",sqlca.sqlcode,sqlca.sqlerrm.sqlerrmc);  }  if( sqlca.sqlcode == SQLNOTFOUND)  {  break;  }  }  EXEC SQL CLOSE cur_user_fee;  
  (4)动态SQL4:要处理的字段及输入的宿主变量数目和主变量的类型事先是不知道的,如:
  INSERT INTO EMP (<unknown> VALUES (<unknown>
  
  是最复杂的动态SQL,很少用,在此不做介绍。
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表