- 1、本文档共42页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第十三课_Oracle_动态SQL.ppt
使用复合数据类型 PL/SQL集合方法 动 态 SQL 动态SQL简介 当编写PL/SQL块时,静态SQL语句只能完成一些固定任务,为了使得PL/SQL块可以灵活的处理SQL语句,需要使用动态SQL。 动态SQL包括本地动态SQL和DBMS_SQL动态SQL两种实现方法。其中本地动态SQL只适用于Oracle服务器端,而DBMS_SQL动态SQL不仅适用于Oracle服务器端,而且可以在客户端应用程序中使用。 动态SQL简介 动态SQL是指在执行PL/SQL块时动态输入的SQL语句。 当在PL/SQL块中嵌入DDL语句和DCL语句时,必须使用动态SQL。另外,如果在PL/SQL块中需要执行更加灵活的select语句和DML语句,也需要使用动态SQL。 Execute immediate语句 为了在动态SQL中处理DDL、DCL、DML以及单行select into语句,需要使用execute immediate语句。 1、execute immediate语句处理DDL和DCL语句 语法如下: execute immediate dyn_string 1、execute immediate语句处理DDL和DCL语句 1、execute immediate语句处理DDL和DCL语句 1、execute immediate语句处理DDL和DCL语句 2、使用execute immediate语句处理DML语句 (1)处理无占位符和returning子句的DML语句 语法如下: execute immediate dyn_string (1)处理无占位符和returning子句的DML语句 (2)处理包含占位符的DML语句 当使用execute immediate处理包含占位符的DML语句时,需要使用using子句为占位符提供输入数据。 (2)处理包含占位符的DML语句 (3)处理包含returning子句的DML语句 当使用execute immediate处理包含returning子句的DML语句时,需使用returning into子句接受返回数据。 3、使用execute immediate语句处理单行查询语句 语法如下: execute immediate dyn_string into var1,…… 3、使用execute immediate语句处理单行语句 3、使用execute immediate语句处理单行语句 处理多行查询 使用execute immediate语句只能处理单行查询,为了动态处理select语句所返回的多行数据,需要定义游标变量、并使用open-for、fetch、close语句共同完成。 游标变量 游标变量是基于REF CURSOR类型所定义的变量。使用显示游标只能定义静态游标,而通过使用游标变量可以在打开游标时指定游标所对应的select语句,从而实现动态游标。 游标变量 游标变量包括定义游标变量、打开游标变量、提取数据和关闭游标四个阶段。 小结 执行动态SQL的Execute immediate语句 1、execute immediate语句处理DDL和DCL语句 2、使用execute immediate语句处理DML语句 (1)处理无占位符和returning子句的DML语句 (2)处理包含占位符的DML语句 (3)处理包含returning子句的DML语句 3、使用execute immediate语句处理单行语句 游标变量处理多行数据 当使用execute immediate处理单行查询语句时,需要使用 into子句接受返回数据。 例:动态输入职工编号,显示职工姓名和工资。 DECLARE query_stat VARCHAR2(100):=SELECT ename,sal FROM scott.emp WHERE empno=:eno; v_name emp.ename%TYPE; v_sal emp.sal%TYPE; BEGIN EXECUTE IMMEDIATE query_stat INTO v_name,v_sal USING empno; dbms_output.put_line(姓名:||v_name|| ,工资:||
文档评论(0)