FORAL用法实.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
批量绑定相关语句的使用 理解FORALL语句的关键,就是这个FORALL后面的索引变量值紧接着下面的DML语句要用到,而这个值取决于它后面IN子句规定的范围。先看看这个语句的语法: FORALL index IN [lower_bound...upper_bound| INDICES OF indexing_collection|VALUES OF indexing_collection] [SAVE EXCEPTION] Sql_statement; 从语法可以看出,检索范围的表示方式有三种方式: 缺省方式: FORALL i IN lower_bound..upper_bound。 例如FORALL i IN 集合名称.FIRST..集合名称.LAST或者1..n,其中n是常数或者函数,必须是整数值; 稀疏集合方式: FORALL i IN INDICES OF 稀疏集合名称; 这时候集合是一个稀疏集合,INDICES OF的意思就是使用稀疏集合的索引作为检索范围,遍历集合时会跳过不存在的索引元素; 还有一种用法,那就是如果原始数据(放在集合中)有我们不想要的数据,我们可以删除不想要的数据,把这些不想要的数据保存在另外一个集合中,这样另外一个集合就变为稀疏的,我们再反过来通过这个稀疏集合来用DML语句去处理原始数据,这样就要用到IN INDICES OF子句。这时候另外一个集合的内容不重要,处理时用的是稀疏集合的索引(下标),而非元素的值,哈哈,你奶奶的,这是理解的关键。 用集合值作为范围的方式: FORALL i IN VALUES OF 集合名称。 很好理解了吧,就是用集合元素的值作为范围进行检索。记住VALUE OF 集合名的意思就是“集合的值”。还要记住这个子句即可以处理紧凑集合也可以处理稀疏集合,FORALL取的是数据内容,与下标无关。 总之,FORALL中IN子句的意思与FOR循环中的IN就是一个意思,都是规定迭代范围,其中系统隐含声明的变量INDEX就是在这个范围内取值。只是真对集合,这个语句的范围表达方式做了相应的调整而已,无他。 理解这个语句的关键,是FORALL中的范围IN子句用的是索引值,在INDICES OF中就是集合元素下标,与集合内容无关,而VALUES OF子句中用的是紧跟子句后面集合元素的值,而又与集合下标无关。 请看下面的两个例子,你看懂了,也就理解了: 例1:给低于1500元工资的员工加薪5000元。 DECLARE TYPE emp_typ IS TABLE OF EMP%ROWTYPE; v_emp emp_typ; TYPE point_type IS TABLE OF PLS_INTEGER; emp_point point_type:=point_type(); BEGIN SELECT * BULK COLLECT INTO v_emp FROM emp_temp; DBMS_OUTPUT.PUT_LINE(未加薪之前的原始名单); FOR i IN v_emp.FIRST..v_emp.LAST LOOP DBMS_OUTPUT.PUT_LINE(v_emp(i).empno|| :||v_emp(i).ename|| :||v_emp(i).sal); IF v_emp(i).sal1500 THEN emp_point.EXTEND; emp_point(emp_point.LAST):=i; END IF; END LOOP; FORALL j IN VALUES OF emp_point UPDATE emp_temp SET SAL=v_emp(j).SAL+5000 WHERE EMPNO=v_emp(j).empno; END; 分析:程序首先把所有员工信息放到一个集合中,然后检索集合,找出小于1500的员工,并把位置记录在另一个集合中。然后用FORALL语句批量修改,FORALL的循环范围就是做了标记的集合。 --Example 11–5 Using FORALL with Non-Consecutive Index Values -- 生成三个空表,用来保存订单明细(有效、大的、拒绝订单) CREATE TABLE valid_orders (cust_name VARCHAR2(32), amount NUMBER(10,2)); CREATE TABLE big_orders AS SELECT * FROM valid_orders WHERE 1 = 0; CREATE TABLE rejected_o

文档评论(0)

mv2323 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档