数据库原理和应用10”.pptVIP

  1. 1、本文档共36页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库原理和应用10”

5.3一些通用的嵌入式SQL 1、select 语句 不使用游标在程序中执行select语句,那么该查询最多检索出一行记录。如果该查询检索到多于一行的记录,系统将返回一个运行期错误。 exec sql select [all | distinct] expr {,expr …} into host-variable{,host-variable…} from table[name] {,table[name] ….} [where search_condition] 2、declare cursor语句 exec sql declare cursor_name cursor for subquery [order by column[asc | desc]{,column[asc | desc]}] [for {read only | update[of colname{,colname...}]}] 子查询格式允许使用子句 group by 和 having 在最后一行的可选格式用于指明游标是read only或update ,若缺省,当使用了order by,游标是read only ,否则为update 。 注:在oracle中允许同时使用这两个格式,但改为with readonly 在order by子句前面。 故,若程序逻辑想通过游标更新或删除一条记录,在游标声明中必须包括for update,在 for update 没有指定列,则被选到的列都被认为是可更新的,若游标使用了for read only,则不能通过该游标来更新或删除记录。 注:这里定义的游标只能在一个行集合中向前移动,在SQL-99中新增了一个可滚动游标。但oracle 和DB2 UDB不支持。这意味着要第二次抽取某行记录,只能关闭后再打开游标。通常情况下,游标在被再打开前必需先关闭。 3、delete语句 有两种格式的delete语句,一种是定位删除:它删除游标所在的当前记录;另一种是查找删除:格式与交互式SQL中相同。 exec sql delete from tablename [name] [where condition | where current of cursor_name] 定位删除使用特殊语法:current of cursor_name 两种where条件是可选的。 长整型变量sqlca.sqlerrd[2]包含了删除操作所影响到的行数。 在定位删除中,当删除执行后,游标指针加1下移一行,若执行删除时,游标没有指向任意一行,则whenever语句的not found 就成立。 特别注意的是:在删除中约定的游标必须已经打开并且指向一个实际的行,删除中的from必须同选择游标时的from子句指向同一个数据源。此外,使用的游标必须是一个可更新的游标,不能被声明为read only。 例5.3.1 从customers表中删除所有住在Duluth并且没有订单的顾客记录。 使用定位删除: exec sql declare delcust cursor for select cid from customers c where c.city=‘Duluth’ and not exists(select * from orders o where o.cid=c.cid ) for update of cid whenever not found goto skip; exec sql open delcust; while(true) { exec sql fetch delcust into : cust_id; exec sql delete from customers where current of delcust } 注:我们当然也可以创建一个游标检索所有没有下过订单的顾客的city和cid,然后在程序逻辑中测试if (strcmp(city,”Duluth”)==0),来判断该行是否删除,但是,由于性能的原因,SQL在执行一个检测时能够不带额外开销是最好的,(在宿主程序与SQL中的切换是比较大的一个开销),我们通常将尽量多的任务交给SQL去做。 故:大家思考,在例5.3.1中的定位删除与查找删除,哪种效率更高? 4、update语句 与delete一样

文档评论(0)

185****7617 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档