- 1、本文档共174页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于本表条件的更新 例2. 将‘s01’学生的年龄改为22岁 UPDATE S SET Sage = 22 WHERE Sno = ‘s01 基于其他表条件的更新 例3:将计算机系全体学生的成绩加5分。 (1)用子查询实现 UPDATE SC SET Grade = Grade + 5 WHERE Sno IN (SELECT Sno FROM S WHERE Sdept = 计算机系 ) UPDATE SC SET GRADE=1.1*GRADE WHERE CNO IN (SELECT CNO FROM C WHERE CNAME=数据库原理); ?把课程名为”数据库原理”的成绩提高10%。 4.6 存储过程和触发器 4.6.1 存储过程的定义、修改和删除 4.6.2 触发器的定义、修改和删除 * 4.6.1 存储过程的定义、修改和删除 存储过程(Stored Procedure)是预编译的Tansant-SQL语句的集合,这些语句作为一个单元进行处理,实现对重复性工作的封装。 存储过程在创建时就被编译和优化,调用一次以后,相关信息就保存在内存中,下次调用时可以直接执行。 * 1.使用Transact-SQL语句创建存储过程 创建存储过程语法格式: CREATE PROC [ EDURE ] procedure_name ? [@parameter data_type?[ OUTPUT ]??] [ ,...n ]] AS sql_statement [ ...n ] 2.执行存储过程 语法格式: EXECUTE 存储过程名[[@形参=]实参值|@变量[OUTPUT]|[DEFAULT]] 创建无参存储过程 在sc中查出成绩大于90分的学生在s表中的基本信息。 CREATE PROCEDURE p1 AS SELECT s.sno,sname,age,sex,sdept FROM s,sc where grade90 and sc.sno=s.sno GO 调用: exec p1 创建带参数的存储过程P2 创建带参数的存储过程,该存储过程返回student数据库中‘某个学号’学生选修课程名及分数情况 CREATE PROCEDURE student_que2 @snoid char(6) AS SELECT sno,cname,grade FROM sc,c WHERE sc.cno=c.cno and sc.sno= @snoid ; GO 调用: exec student_que2 100004 3.修改存储过程 语法格式: ALTER PROC [ EDURE ] procedure_name ???? [@parameter data_type [ OUTPUT ]??] [ ,...n ]] AS sql_statement [ ...n ] 修改存储过程p1,返回成绩在80-90分的人在s表中的详细信息。 alter PROCEDURE p1 AS SELECT sno,sname,age,sex,sdept FROM s WHERE sno in (select sno from sc where grade=80 and grade=90) GO 4.删除存储过程 语法格式: DROP PROCEDURE 存储过程名 删除存储过程P1。 DROP PROCEDURE P1 4.6.2 触发器的定义、修改和删除 触发器是一种特殊的存储过程,在用户试图对指定的表执行指定的数据修改语句时自动执行。触发器常常用于强制业务规则和数据完整性。 * 1.使用Transact-SQL语句创建触发器 语法格式: CREATE TRIGGER trigger_name ON { table | view } { FOR | AFTER | INSTEAD OF } {[DELETE] [,] [INSERT] [,] [UPDATE] }? AS SQL语句段 ... 注意:两种特殊的逻辑(概念)表 Deleted表存储DELETE和UPDATE语句所影响的行的复本。在执行DELETE或UPDATE语句时,行从触发器表中删除,并传输到deleted表中。 Inserted表存储INSERT和UPDATE语句所影响的新的行。在一个插入或更新事务处理中,新数据行被同时添加到inserted表和定义触发器的表中。Inserted表中的行是定义触发器表中新行的副本。 在sc表上创建一个触发器,分数大于60则不能删除 Create
您可能关注的文档
- 赠送礼物的礼仪剖析.ppt
- 赞美训练营剖析.ppt
- 旅游路拓宽改造工程导行方案重点.docx
- 第6讲_Flash元件、逐帧动画与形状重点.ppt
- 第4章-SPSS基本统计分析重点.ppt
- 第6讲分支界限法重点.ppt
- 旅游政策与法规第7章旅游交通运输法律制度重点.ppt
- 第4章SQL_Server2008概述重点.ppt
- 第4章Transact-SQL语言重点.ppt
- 设备全员管理讲义剖析.doc
- [中央]2023年中国电子学会招聘应届生笔试历年参考题库附带答案详解.docx
- [吉安]2023年江西吉安市青原区总工会招聘协理员笔试历年参考题库附带答案详解.docx
- [中央]中华预防医学会科普信息部工作人员招聘笔试历年参考题库附带答案详解.docx
- [保定]河北保定市第二医院招聘工作人员49人笔试历年参考题库附带答案详解.docx
- [南通]江苏南通市崇川区人民法院招聘专职人民调解员10人笔试历年参考题库附带答案详解.docx
- [厦门]2023年福建厦门市机关事务管理局非在编工作人员招聘笔试历年参考题库附带答案详解.docx
- [三明]2023年福建三明市尤溪县招聘小学幼儿园新任教师79人笔试历年参考题库附带答案详解.docx
- [哈尔滨]2023年黑龙江哈尔滨市木兰县调配事业单位工作人员笔试历年参考题库附带答案详解.docx
- [上海]2023年上海市气象局所属事业单位招聘笔试历年参考题库附带答案详解.docx
- [台州]2023年浙江台州椒江区招聘中小学教师40人笔试历年参考题库附带答案详解.docx
文档评论(0)