oracle存储过程中如何执行动态SQL语句,详细?
有时需要在oracle存储过程中执行动态SQL语句,例如表名是动态的,或字段是动态的, 或查询命令是动态的,可用下面的方法: setserveroutputondeclarennumber;sql_stmtvarchar2(50); tvarchar2(20);beginexecuteimmediate'altersessionsetnls_date_format=''YYYYMMDD'''; t:='t_'||sysdate; sql_stmt:='selectcount(*)from'||t; executeimmediatesql_stmtinton; dbms_output.put_line('Thenumberofrowsof'||t||'is'||n);end; 如果动态SQL语句很长很复杂,则可用包装. CREATEORREPLACEPACKAGEtest_pkgISTYPEcur_typISREFCURSOR; PROCEDUREtest_proc(v_tableVARCHAR2,t_curOUTcur_typ);END;/ CREATEORREPLACEPACKAGEBODYtest_pkgISPROCEDUREtest_proc(v_tableVARCHAR2,t_curOUTcur_typ)ISsqlstrVARCHAR2(2000);BEGINsqlstr:='SELECT*FROM'||v_table; OPENt_curFORsqlstr;END;END;/ 在oracle中批量导入,导出和删除表名以某些字符开头的表 spoolc:\a.sql
如何查看db2动态语句的执行计划?
db2有图形执行计划显示工具,如果没有图形环境,如unix主机,可以生成文本的文件来显示执行计划1.如果第一次执行,请先 connect to dbname,执行db2 -tvf $HOME/sqllib/misc/EXPLAIN.DDL建立执行计划表2.db2 set current explain mode explain设置成解释模式,并不真正执行下面将发出的sql命令3.db2 "select count(*) from staff"执行你想要分析的sql语句4.db2 set current explain mode no取消解释模式5.db2exfmt -d sample -g TIC -w -l -s % -n % -o db2exmt.out执行计划输出到文件db2exmt.out
图片来源:网络
如何在程序中用动态sql语句创建视图?
可根据实际需要用create view语句创建视图。 举例: 有如下表: 要将id不等于1的数据创建到视图v_test中,可用如下语句: create view v_test as select * from test where id1;这样以后,如果在test表中添加数据,
mybatis怎么拼接动态sql?
MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑。
MyBatis中用于实现动态SQL的元素主要有: if choose(when,otherwise) trim where set foreach