第章结构化查询语言SQL讲解.pptVIP

  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文档。上传文档
查看更多
* 三、嵌入式SQL的使用技术 ⑴ 在嵌入式SQL中, SQL的数据定义DDL与控制语句DCL都不需要使用游标。 它们是嵌入式SQL中最简单的一类语句,不需要返回结果数据,也不需要使用主变量。在主语言中嵌入SQL说明性语句(DECLARE)及控制语句(GRANT),只要给语句加上前缀EXEC SQL和语句结束符END_EXEC即可。在C语言中,用分号;代替END_EXEC * 例:在C语言中说明共享变量: EXEC SQL BEGIN DECLARE SECTION int grade,raise; char givencno[5],cname[13], tname[9] ; char givensno[5],sname[9],sdept[11]; char SQLSTATE[6]; EXEC SQL END DECLARE SECTION; * ⑵ 不涉及游标的嵌入式SQL DML语句 a.对于INSERT、DELETE和UPDATE语句, 只要加上前缀标识“EXEC SQL”和结束标志“END_EXEC”,就能嵌入在宿主语言程序中使用。例: ① 在关系C中插入一门新的课程,各属性值已在相应的 共享变量中: EXEC SQL INSERT INTO C(CNO,CNAME,TNAME) VALUES(:givencno,:cname,:tname); * ② 从关系SC中删除一个学生的所有选课, 该学生的姓名由共享变量sname提供。 EXEC SQL DELETE FROM SC WHERE SNO=(SELECT SNO FROM S WHERE SNAME=:sname); * ③ 把“数据库”课程的全部成绩增加某个值(该值由 共享变量raise 提供)。 EXEC SQL UPDATE SC SET GRADE=GRADE +:raise WHERE CNO IN (SELECT CNO FROM C WHERE CNAME=‘数据库’); * b.对于SELECT语句,如果已知查询结果肯定是 单元组时,可直接嵌入在主程序中使用, 此时在SELECI语句中增加一个INTO子句, 指出找到的值应送到相应的共享变量中去。 例:在关系S中根据共享变量givensno的值 检索学生的姓名和所在系。 * 例:在关系S中根据共享变量givensno的值检索 该学生的姓名和所在系: EXEC SQL SELECT SNAME,SDEPT INTO :sname,:sdept FROM S WHERE SNO=:givensno; 此处sname,sdept,givensno 都是共享变量,已在主程序中定义,并用SQL的DECLARE语句加以说明,在引用是加上“:”作为前缀标识,以示与数据库中变量区别。 * ⑶ 涉及游标的嵌入式SQL DML语句 a、当SELECT语句查询结果是多个元组时,此时要用游标机制把多个元组一次一个地传送给宿主语言程序处理。 例:在关系SC表中检索某学生(学生名由共享变量givensname给出)选课信息(SNO,CNO,GRADE), 该查询的C语言程序段: ? * EXEC SQL BEGIN DECLARE SECTION; Int grade,rise; Char sno[5],cno[5], givensname[9],SQLSTATE[6]; EXEC SQL END DECLARE SECTION; EXEC SQL DECLARE scx CURSOR FOR SELECT SNO,CNO,GRADE FROM SC WHERE SNO=(SELECT SNO FROM S WHERE SNAME=:givensname) FOR UPDATE OF GRADE; EXEC SQL OPEN scx; * While(1) { EXEC SQL FETCH FROM scx INTO :sno,:cno,:grade;

文档评论(0)

风凰传奇 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档