知方号

知方号

oracle存储过程中如何执行动态SQL语句,详细

oracle存储过程中如何执行动态SQL语句,详细?

有时需要在oracle存储过程中执行动态SQL语句,例如表名是动态的,或字段是动态的, 或查询命令是动态的,可用下面的方法: setserveroutputondeclarennumber;sql_stmtvarchar2(50); tvarchar2(20);beginexecuteimmediatealtersessionsetnls_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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至lizi9903@foxmail.com举报,一经查实,本站将立刻删除。