leon1509 发表于 2013-1-26 12:34:04

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

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,很少用,在此不做介绍。
页: [1]
查看完整版本: [转]PROC中的4种动态SQL简介