- 1、本文档共36页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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一样
您可能关注的文档
- “最美孝心少年”事迹材料以寸草之心报3春之晖.doc
- “时代空间”2015深圳城市生活和艺术博览会华丽绽放.doc
- “尽人事知天命”的哲学和现实意义.docx
- “投之家”注册破3万1站式P2P垂直有哪些信誉好的足球投注网站引擎步入新纪元.docx
- 东北小狠嗑-大金链子小手表一天三顿小烧烤.doc
- 东北方言(1些读音规则).doc
- 东北方言目前最全的版本2011年十二月18日版.doc
- 东华大学硕士研究生学位论文格式和答辩信息的录入要求.doc
- “潜质生”的成因和对策.doc
- 东台市3仓中学2013届高3语文自编练习8.doc
- 2025年重庆市自贡市单招(语文)测试模拟题库汇编.docx
- 2025年闽南理工学院单招语文测试题库完美版.docx
- 人教版数学小学五年级下册期末测试卷精华版.docx
- 慢性阻塞性肺疾病并发呼吸机相关肺炎原因分析及对策.pptx
- 医疗机构内部质量控制策略.pptx
- 2025年重庆市泸州市单招语文测试模拟题库及完整答案1套.docx
- 2025年重庆市资阳地区事业单位招聘考试(职业能力倾向测验)题库附答案.docx
- 2025年重庆市眉山地区选调生考试(公共基础知识)综合能力测试题汇编.docx
- 小学六年级上册数学期末测试卷附参考答案【突破训练】.docx
- 2025年长江艺术工程职业学院单招(语文)测试模拟题库a4版.docx
最近下载
- 摩托罗拉XiR_M3688_ServerManual维修手册.pdf VIP
- 奥西替尼杂质研究总结.pdf VIP
- 2024《格兰仕电器公司成本管理问题调查研究》8600字.docx VIP
- 中小学英语教师语音语调训练.ppt
- 《严格规范涉企行政检查》知识培训.pptx VIP
- MODS(多器官功能障碍综合征).ppt VIP
- 高中政治统编版必修一:(综合探究二)方向决定道路 道路决定命运.pptx
- VW75210-2 2011 (LV216-2) CN-电动汽车的高压屏蔽电缆要求和试验.pdf VIP
- 2022版小学《体育与健康课程标准》考试复习题库资料(含答案).pdf VIP
- 人工智能在邮政业的应用前景.pptx VIP
文档评论(0)