SQL数据管理实验指导书.doc
实验一 SQL Server 基础一实验目的1了解安装、启动和终止SQL Server的方法。2了解“服务管理器” 、“企业管理器”及“查询分析器”基本使用方法。3掌握SQL Server 中数据库、及数据表的建立与管理方法。 二、SQL Server简介SQL Server是一种基于客户/服务器的关系型数据库管理系统,它使用Transact-SQL语言在服务器和客户机之间传送请求和答复。SQL Server使用客户/服务器体系结构把所有的工作负荷分解成在服务顺上的任务和在客户机上的任务。客户机应用程序负责商业逻辑和向用户提供数据,一般运行在一个或者多个客户机上,但是也可以运行在服务器上。服务器管理数据库和分配可用的服务器资源,例如内存、网络带宽和磁盘操作。客户机应用程序界面允许应用程序在单独的客户机上运行,并且通过网络与服务器通讯。SQL Server可以在多种操作系统上运行。SQL Server的服务器环境可以是Windows NT或者Windows 9x,其客户机环境可以是WindowsNT、Windows9x、第三方平台和Internet浏览器三三、SqlServer2000的安装购买SQL Server2000的软件安装盘,参照下列示意图:第1步:选择“安装SQLSERVER2000组件”第2步:选择“安装数据库服务器”第3步:在欢迎界面里,点击下一步第4步:计算机名界面中,选择“本地计算机”,点击下一步第5步:在“安装选择”中,选择“创建新的SQLSERVER实例,或安装客户端工具”,点击下一步第6步:输入你的姓名如“WWL“,点击下一步第7步:在安装定义里边,选择“服务器和客户端工具“,点击下一步第8步:在“实例名”界面里,选择默认,点击下一步第9步:在“安装类型”中,选择你安装的路径(点击浏览按钮),点击下一步第10步:照图选择各项,点击下一步第11步:照图选择各项,然后在输入密码里,输入你的密码(自己一定要记住),点击下一步第12步:点击下一步第13步:在许可模式里,选择“每客户”,100设备,点击继续完成安装!SQL Server包括3个服务,即MSSQLServer、SQL Server Agent和Microsoft.Distributed Transaction Coordinator(MS DTC)服务。MSSQLServer服务就是SQL Server的RDBMS(关系数据库管理系统);SQL Server Agent服务用于管理任务、警报和操作员;MS DTC服务是分布式事务协处理器,用于保证在多个服务器之间事务同时完成或者取消,协调多服务器之间的事务一致性。本课程实验主要介绍其中的MSSQLServer服务。在SQL Server系统中,有两种类型的数据库:系统数据库和用户数据库。系统数据库是系统提供的数据库,包含了记录系统中所有系统信息的系统表。用户数据库就是用户自己创建的数据库,包含了用户的所有数据。系统安装之后,生成了四个系统数据库和两个样板数据库。这四个系统数据库分别是master、model、msdb和tempdb。Master数据库是最重要的系统数据库,它记录了系统中所有系统级的信息。Model数据库是一个模板数据库,它包含了用户数据库中应该包含的所有系统表的结构。当创建用户数据库时,系统自动把Model数据库中的内容拷贝到新建的用户数据库中。Msdb数据库记录了有关SQL Server Agent服务的信息,例如作业、警报、操作员等信息。Tempdb数据库是一个临时数据库,当某些操作有中间数据时,这些中间数据就保存在该数据库中。两个样板数据库是pubs和Northwind。Pubs数据库记录了一个虚构的出版公司的数据信息,Northwind数据库保存了一个虚构的贸易公司的数据信息。一个数据库中,有许多数据对象。各对象的种类和相应描述如下表所示:数据库对象描述表由行和列组成,是存储数据的地方数据类型限制输入到表中的数据类型约束有主键、外键、唯一键、缺省和检查五种类型的约束缺省自动插入的常量值规则限制表中列的取值范围索引加快检索数据的方式视图查看一个式者多个表的一种方式存储过程一组预编译的SQL语句,可以完成指定的操作触发器一种特殊类型的存储过程,当某个操作影响到它保护的数据时,它就会自动触发执行SQL Server安装之后,其目录和文件的默认位置是:安装路径下Microsoft SQL ServerMSSQL,其中几个主要目录是:BACKUP(备份文件的默认位置)、Data(数据库文件)、LOG(错误日志文件)。SQL Server的详细介绍请查阅SQL Server使用手册或帮助。四、操作步骤1SQL Server服务管理器 SQL Server服务管理器(Service Manager)是在服务器端实际工作时最有用的实用程序。SQL Server服务管理器的主要作用是用来启动数据库服务器的实时服务、暂停和停止正在运行的服务,或在暂停服务后继续服务。 从SQL Server 2000程序组中启动“服务管理器”,弹出如下对话框,在“服务器”列表框中,选择输入相应的服务器名称。在“服务”列表框中,选择输入相应的服务,此处可选择“SQL Server服务”。单击启动/继续可以启动相应服务,单击停止可停止相应服务。如图1-1:图1-12企业管理器(Enterprise Manager)企业管理器是SQL Server中最重要的一个管理工具。用户和系统管理员可以使用它来管理网络、计算机、服务和其它系统组件。企业管理器不仅能够配置系统环境和管理SQL Server,而且由于它能够以层叠列表的形式来显示所有的SQL Server对象,因而所有SQL Server对象的建立与管理都可以通过它来完成。 为了管理SQL Server必须使用“企业管理器”注册服务器。方法如下: 从SQL Server 2000程序组中启动“企业管理器”。如图1-2 在窗口左栏中右击某一个服务器组,单击新建SQL Server注册。 按提示执行以下三项操作:选择服务器选择身份验证模式(SQL Server身份验证,指定登录名和密码)指定SQL Server组。注册了服务器后,通过右击目录树中的服务器,然后从弹出的快捷菜单中选择“属性”,可以设置大多数服务器常用的选项。详细设置参数参阅SQL Server系统管理手册或帮助。如图1-3图1-2图1-34查询分析器介绍SQL Server 2000的查询分析器(Query Analyzer)可以使用户交互式地输入和执行各种Transact-SQL语句,并且迅速地查看这些语句的执行结果,来完成对数据库中的数据的分析和处理。“查询分析器” ,可以通过图形界面执行SQL语句。“查询分析器”是一种可以完成多种工作的多用途工具,在其中可以交互式地输入和执行各种SQL语句,并且可以在一个窗口中同时查看SQL语句和其结果集;可以在同时执行多个SQL语句,也可以执行脚本文件中的部分语句;此外还提供了一种图形化分析查询语句执行规则的方法,可以报告由“查询分析器”选择的数据检索方法,并且可以根据查询规划调整查询语句的执行等。打开方法:单击工具/SQL查询分析器。如下图1-5所示,可在工具栏中选择要操作的数据库(如master),并在查询窗口中输入相应的SQL语句(select * from sysfiles),点击工具条的绿色小三角运行你输入的SQL语句。此时在查询窗口的下部会显示执行结果。图1-5查询结果的显示方式,可通过查询菜单设置:文本显示结果、以表格显示结果或结果保存为文件。5查看数据库及浏览表中记录查看已建立的数据库运行企业管理器,在窗口左栏中选择一个已注册的数据库服务器。单击左侧的+号,选择“数据库”选项,可以看到在数据库服务器中已建立的数据库。注意:如右击“数据库”并选择“新建数据库” ,可建立新的数据库。 浏览表中记录 选择某数据库并选择数据库中的“表”选项 。选择要浏览的表,按右键并选择:打开表/返回所有行 ,即可浏览表中记录。注意:可右击“表”选项,在弹出的菜单中选择“新建表” ,可建立新表。6、数据库建立与管理(1)启动、并打开SQL Server。 从SQL Server 2000程序组中启动SQL Server,在弹出的对话框中选择输入:服务器名称和相应服务,单击启动/继续。选择打开已注册的数据库服务器。(2)使用图形界面创建数据库和表 使用图形界面(企业管理器)并依据内容1中的关系模型创建数据库和表。创建数据库 运行企业管理器,单击窗口左栏树下面的,直到出现“数据库”选项。 右击“数据库”选项,点击“新建数据库”,在弹出对话框中输入你要创建的数据库名(例如mybatabase)后直接按确定键。这时系统就会创建一个名为mydatabse的数据库。 创建表 在企业管理器中,选择数据库。右击“表”选项。 选择“新建表” ,输入:列名、数据类型、长度等,并存盘。注意:通过选择“保存更改脚本”,可将建表过程保存为脚本文件,供以后用查询分析器建表。(3)使用查询分析器创建表. 从SQL Server程序组中启动“查询分析器”,出现如下图2-1登录界面,图2-1输入SQL Server名,登录名sa,密码:无然后按确定。. 在出现的“查询窗口”中选择你要操作的数据库,然后就可以在下面的编辑框中输入SQL语句建立相关表。试用此方法建立:学生-课程数据库,基本表见教材59页。. 点击工具条的绿色小三角(或按F5)就可以运行你输入的SQL语句。 此处,也可打开并执行上题中保存的脚本文件来实现建表。7. 数据库的备份与还原数据库的备份: 运行企业管理器,右击你所要备份的数据库,选择“所有任务”中的“备份数据库”。 输入备份数据库的名称,点击“添加”后输入备份数据库存放的目录和文件名。按确定按钮,备份完成。数据库的还原:一旦数据库遭到破坏,可用备份的数据库进行恢复。 运行企业管理器,右击“数据库”,在“所有任务”中选“还原数据库”。 在“选项”页中选中“在现有数据库上强制还原”。 在“常规”页中输入恢复的数据库名,选择“从设备” 还原,点击“选择设备”后,再点击“添加”按钮选择你所要恢复的数据库备份文件名。点击确定按钮完成恢复。 如果原有数据库被删除,恢复异常。则可先建立一个同名数据库,再在数据库上进行强制还原即可。8、数据的导入与导出9、数据库的分离与附加实验二 SQL编程一实验目的1. 熟练掌握SQL编程方法2. 掌握Transact-SQL基本语法3. 掌握SQL-查询分析器的基本用法4. 掌握SQL中常用统计函数的用法5. 掌握游标的基本用法二实验要求1. 回顾SQL语法2. 熟悉SQL Server2000的基本操作3. 预习Transact-SQL基本语法4. 预习游标用法三实验内容1. 用统计函数sum、avg、min、max、count等进行查询2. 统计函数结合group by进行查询3. 实现Transact-SQL中的判断和循环结构编程4. 用游标实现一个统计功能四实验指导1. 启动SQL-查询分析器,可以从开始菜单中启动,也可以从企业管理器中启动。1). 从开始菜单中启动,如下图2-1所示,之后出现图2-2所示的界面,根据实际情况选择各选项,点击确定即可。图2-1图2-22). 从企业管理器中启动,先启动企业管理器,然后选择则“工具”®“SQL-查询分析器”即可,如下图2-3。图2-32. SQL-查询分析器的使用。1). SQL-查询分析器有三个窗口:对象浏览器(可选)、查询窗口和结果显示窗口,如下图2-4所示。其中对象浏览器窗口中显示的是各数据库中的对象与一些公共对象;查询窗口是一个输入窗口,用来接受用户输入各查询语句,可以输入多条查询语句,选择执行其中的一条或是多条;结果显示窗口用于显示执行后的结果信息,也可用于显示查询的执行计划信息,另外可以选择将查询后的结果显示为表格形式或是文本形式,也可以将查询的结果以文件的方式保存下来。图2-42). 使用之前可先设定好各参数,如所使用的数据库(在图2-4所显示的下拉窗口中选择即可)、查询结果的显示方式等。在查询窗口中输入查询语句,可以按下Ctrl+F5键或是点击图2-4中所示的蓝色对勾按钮进行语句的语法分析,也可以直接按下F5键或是点击图2-4中所示的绿色三角按钮执行其中选中的一条或是多条语句,若无语法错误,结果将显示在查询窗口下面的结果显示窗口中。 3. 查询及函数举例 select stuid,name from studentdrop table student1-排序:select * from student order by stuidselect distinct adressfrom student-计数:select adress,count(adress) 人数 from student group by adress-求最大值:select max(age)from student-select name from student where age=(select max(age) from student where sex='m') -平均值:select * from studentwhere age>(select avg(age) from student) order by age desc4. 游标的使用3). 声明游标在这一步中,需要指定游标的属性和根据要求产生的结果集。有两种方法可以指定一个游标。形式1 (ANSI 92)DECLARE cursor_name INSENSITIVE SCROLL CURSORFOR select_statementFOR READ ONLY | UPDATE OF column_list形式2DECLARE cursor_name CURSORLOCAL | GLOBALFORWARD_ONLY | SCROLLSTATIC | KEYSET | DYNAMICREAD_ONLY | SCROLL_LOCKS | OPTIMISTICFOR select_statementFOR READ ONLY | UPDATE OF column_listINSENSITIVE关键字指明要为检索到的结果集建立一个临时拷贝,以后的数据从这个临时拷贝中获取。如果在后来游标处理的过程中,原有基表中数据发生了改变,那么它们对于该游标而言是不可见的。这种不敏感的游标不允许数据更改。SCROLL关键字指明游标可以在任意方向上滚动。所有的fetch选项(first、last、next、relative、absolute)都可以在游标中使用。如果忽略该选项,则游标只能向前滚动(next)。Select_statement指明SQL语句建立的结果集。Transact SQL语句COMPUTE、COMPUTE BY、FOR BROWSE和INTO在游标声明的选择语句中不允许使用。READ ONLY指明在游标结果集中不允许进行数据修改。UPDATE关键字指明游标的结果集可以修改。OF column_list指明结果集中可以进行修改的列。缺省情况下(使用UPDATE关键字),所有的列都可进行修改。LOCAL关键字指明游标是局部的,它只能在它所声明的过程中使用。GLOBAL关键字使得游标对于整个连接全局可见。全局的游标在连接激活的任何时候都是可用的。只有当连接结束时,游标才不再可用。FORWARD_ONLY指明游标只能向前滚动。STATIC的游标与INSENSITIVE的游标是相同的。KEYSET指明选取的行的顺序。SQL Server将从结果集中创建一个临时关键字集。如果对数据库的非关键字列进行了修改,则它们对游标是可见的。因为是固定的关键字集合,所以对关键字列进行修改或新插入列是不可见的。DYNAMIC指明游标将反映所有对结果集的修改。SCROLL_LOCK是为了保证游标操作的成功,而对修改或删除加锁。OPTIMISTIC指明哪些通过游标进行的修改或者删除将不会成功。注意:· 如果在SELECT语句中使用了DISTINCT、UNION、GROUP BY语句,且在选择中包含了聚合表达式,则游标自动为INSENSITIVE的游标。· 如果基表没有唯一的索引,则游标创建成INSENSITIVE的游标。· 如果SELECT语句包含了ORDER BY,而被ORDER BY的列并非唯一的行标识,则DYNAMIC游标将转换成KEYSET游标。如果KEYSET游标不能打开,则将转换成INSENSITIVE游标。使用SQL ANSI-92语法定义的游标同样如此,只是没有INSENSITIVE关键字而已。ii. 打开游标打开游标就是创建结果集。游标通过DECLARE语句定义,但其实际的执行是通过OPEN语句。语法如下:OPEN GLOBAL cursor_name | cursor_variable_nameGLOBAL指明一个全局游标。Cursor_name是被打开的游标的名称。Cursor_variable_name是所引用游标的变量名。该变量应该为游标类型。在游标被打开之后,系统变量cursor_rows可以用来检测结果集的行数。cursor_rows为负数时,表示游标正在被异步迁移,其绝对值(如果cursor_rows为,则绝对值为)为当前结果集的行数。异步游标使用户在游标被完全迁移时仍然能够访问游标的结果。iii. 从游标中取值在从游标中取值的过程中,可以在结果集中的每一行上来回移动和处理。如果游标定义成了可滚动的(在声明时使用SCROLL关键字),则任何时候都可取出结果集中的任意行。对于非滚动的游标,只能对当前行的下一行实施取操作。结果集可以取到局部变量中。Fetch命令的语法如下:FETCH NEXT | PRIOR| FIRST | LAST | ABSOLUTE n | nvar | RELATIVE n | nvarFROM GLOBAL cursor_name | cursor_variable_nameINTO variable_name ,nNEXT指明从当前行的下一行取值。PRIOR指明从当前行的前一行取值。FIRST是结果集的第一行。LAST是结果集的最后一行。ABSOLUTE n表示结果集中的第n行,该行数同样可以通过一个局部变量传播。行号从0开始,所以n为0时不能得到任何行。RELATIVE n表示要取出的行在当前行的前n行或后n行的位置上。如果该值为正数,则要取出的行在当前行前n行的位置上,如果该值为负数,则返回当前行的后n行。INTO cursor_variable_name表示游标列值存储的地方的变量列表。该列表中的变量数应该与DECLARE语句中选择语句所使用的变量数相同。变量的数据类型也应该与被选择列的数据类型相同。直到下一次使用FETCH语句之前,变量中的值都会一直保持。每一次FETCH的执行都存储在系统变量fetch_status中。如果FETCH成功,则fetch_status被设置成0。fetch_status为-1表示已经到达了结果集的一部分(例如,在游标被打开之后,基表中的行被删除)。fetch_status可以用来构造游标处理的循环。例如:DECLARE iname char(20), fname char(20)OPEN author_curFETCH FIRST FROM author_cur INTO iname, fnameWHILE fetch_status = 0BEGINIF fname = AlbertPRINT “Found Albert Ringer”ELSEPrint “Other Ringer”FETCH NEXT FROM author_cur INTO iname, fnameENDiv. 关闭游标CLOSE语句用来关闭游标并释放结果集。游标关闭之后,不能再执行FETCH操作。如果还需要使用FETCH语句,则要重新打开游标。语法如下:CLOSE GLOBAL cursor_name | cursor_variable_namev. 释放游标游标使用不再需要之后,要释放游标。DEALLOCATE语句释放数据结构和游标所加的锁。语法如下:DEALLOCATE GLOBAL cursor_name | cursor_variable_name下面给出游标的一个完整的例子:USE masterGOCREATE PROCEDURE sp_BuildIndexesASDECLARE TableName sysname, msg varchar(100), cmd varchar(100)DECLARE table_cur CURSOR FORSELECT name FROM sysobjects WHERE type=uOPEN table_curFETCH NEXT FROM table_cur INTO TableNameWHILE fetch_status = 0BEGINIF fetch_status = -2CONTINUESELECT msg = “Building indexes for table”+TableName+”PRINT msgSELECT cmd = “DBCC DBREINDEX (”+TableName+”')”EXEC (cmd)PRINT “ “FETCH NEXT FROM table_cur INTO TableNameENDDEALLOCATE table_curGO下面的脚本将为PUBS数据库执行sp_BuildIndexesUSE pubsGOEXEC ap_BuildIndexes注意:上面也是创建用户定义的系统存储过程的示例。 5. 按如下所给要求实现各查询,查询中所使用的数据库为Northwind。1). 查询表Products中供货商代号为2 的产品的平均价格2). 查询表Suppliers中各国家的供应商数目3). 查询表Orders中到目前为止所用的所有运费4). 查询表Suppliers中供应商数目最多和最少的国家名称5). 将表Products中库存大于100的产品价格下调30%、50到100之间的下调20%、余下的下调10%。6). 利用游标将表Suppliers中各国家的供应商名称分别以字符串的形式输出。实验三 存储过程与触发器一实验目的6. 了解存储过程和触发器的基本作用7. 掌握存储过程和触发器的创建方法8. 掌握存储过程和触发器的运行机制9. 了解常见的系统存储过程二实验要求5. 熟悉SQL语法6. 熟练掌握企业管理器管理对象的方法7. 掌握SQL查询分析器的用法8. 了解存储过程和触发器的相关知识三实验内容5. 创建一个存储过程6. 创建一个触发器四实验指导3. 存储过程是保存起来的可以接受和返回用户提供的参数的 Transact-SQL 语句的集合。可以创建一个过程供永久使用,或在一个会话中临时使用(局部临时过程),或在所有会话中临时使用(全局临时过程)。创建存储过程的语法及参数如下:1). 语法 CREATE PROCEDURE procedure_name ;number parameter data_type VARYING=defaultOUTPUT ,.n WITH RECOMPILE|ENCRYPTION|RECOMPILE,ENCRYPTION FOR REPLICATION AS sql_statement .n2). 参数procedure_name:新存储过程的名称。过程名必须符合标识符规则,且对于数据库及其所有者必须唯一。number:是可选的整数,用来对同名的过程分组,以便用一条 DROP PROCEDURE 语句即可将同组的过程一起除去。例如,名为 orders 的应用程序使用的过程可以命名为 orderproc;1、orderproc;2 等。DROP PROCEDURE orderproc 语句将除去整个组。如果名称中包含定界标识符,则数字不应包含在标识符中,只应在 procedure_name 前后使用适当的定界符。parameter:过程中的参数。在 CREATE PROCEDURE 语句中可以声明一个或多个参数。用户必须在执行过程时提供每个所声明参数的值(除非定义了该参数的默认值)。存储过程最多可以有 2.100 个参数。使用 符号作为第一个字符来指定参数名称。参数名称必须符合标识符的规则。每个过程的参数仅用于该过程本身;相同的参数名称可以用在其它过程中。默认情况下,参数只能代替常量,而不能用于代替表名、列名或其它数据库对象的名称。data_type:参数的数据类型。所有数据类型(包括 text、ntext 和 image)均可以用作存储过程的参数。不过,cursor 数据类型只能用于 OUTPUT 参数。如果指定的数据类型为 cursor,也必须同时指定 VARYING 和 OUTPUT 关键字。VARYING:指定作为输出参数支持的结果集(由存储过程动态构造,内容可以变化)。仅适用于游标参数。default:参数的默认值。如果定义了默认值,不必指定该参数的值即可执行过程。默认值必须是常量或 NULL。如果过程将对该参数使用 LIKE 关键字,那么默认值中可以包含通配符(%、_、 和 )。OUTPUT:表明参数是返回参数。该选项的值可以返回给 EXECUTE。使用 OUTPUT 参数可将信息返回给调用过程。Text、ntext 和 image 参数可用作 OUTPUT 参数。使用 OUTPUT 关键字的输出参数可以是游标占位符。4. 触发器是一种特殊的存储过程,在用户试图对指定的表执行指定的数据修改语句时自动执行。创建触发器的语法及参数如下:1). 语法CREATE TRIGGER trigger_name ON table|view WITH ENCRYPTION FOR|AFTER|INSTEAD OFINSERT,UPDATEWITH APPENDNOT FOR REPLICATIONASIF UPDATE(column)AND|ORUPDATE(column) .n |IF(COLUMNS_UPDATED()bitwise_operatorupdated_bitmask)comparison_operatorcolumn_bitmask.n sql_statement .n 2). 参数trigger_name:是触发器的名称。触发器名称必须符合标识符规则,并且在数据库中必须唯一。可以选择是否指定触发器所有者名称。Table | view:是在其上执行触发器的表或视图,有时称为触发器表或触发器视图。可以选择是否指定表或视图的所有者名称。WITH ENCRYPTION:加密syscomments表中包含CREATE TRIGGER 语句文本的条目。使用WITH ENCRYPTION可防止将触发器作为 SQL Server复制的一部分发布。AFTER:指定触发器只有在触发SQL语句中指定的所有操作都已成功执行后才激发。所有的引用级联操作和约束检查也必须成功完成后,才能执行此触发器。如果仅指定FOR关键字,则AFTER是默认设置。不能在视图上定义AFTER 触发器。INSTEAD OF:指定执行触发器而不是执行触发 SQL 语句,从而替代触发语句的操作。在表或视图上,每个INSERT、UPDATE或DELETE语句最多可以定义一个INSTEAD OF触发器。然而,可以在每个具有INSTEAD OF触发器的视图上定义视图。INSTEAD OF触发器不能在WITH CHECK OPTION的可更新视图上定义。如果向指定了WITH CHECK OPTION 选项的可更新视图添加INSTEAD OF触发器,SQL Server将产生一个错误。用户必须用ALTER VIEW删除该选项后才能定义INSTEAD OF 触发器。 DELETE , INSERT , UPDATE :是指定在表或视图上执行哪些数据修改语句时将激活触发器的关键字。必须至少指定一个选项。在触发器定义中允许使用以任意顺序组合的这些关键字。如果指定的选项多于一个,需用逗号分隔这些选项。对于INSTEAD OF触发器,不允许在具有ON DELETE级联操作引用关系的表上使用DELETE选项。同样,也不允许在具有ON UPDATE级联操作引用关系的表上使用UPDATE选项。WITH APPEND:指定应该添加现有类型的其它触发器。WITH APPEND 不能与INSTEAD OF触发器一起使用,或者,如果显式声明AFTER触发器,也不能使用该子句。只有当出于向后兼容而指定FOR时(没有INSTEAD OF或AFTER),才能使用WITH APPEND。NOT FOR REPLICATION:表示当复制进程更改触发器所涉及的表时,不应执行该触发器。AS:是触发器要执行的操作。sql_statement:是触发器的条件和操作。触发器条件指定其它准则,以确定DELETE、INSERT或UPDATE语句是否导致执行触发器操作。当尝试DELETE、INSERT或UPDATE操作时,Transact-SQL语句中指定的触发器操作将生效。触发器可以包含任意数量和种类的 Transact-SQL语句。触发器旨在根据数据修改语句检查或更改数据;它不应将数据返回给用户。触发器中的Transact-SQL语句常常包含控制流语言。CREATE TRIGGER语句中使用几个特殊的表:deleted和 inserted是逻辑(概念)表。这些表在结构上类似于定义触发器的表(也就是在其中尝试用户操作的表);n:是表示触发器中可以包含多条Transact-SQL语句的占位符。对于IF UPDATE (column)语句,可以通过重复UPDATE (column)子句包含多列。IF UPDATE(column):测试在指定的列上进行的INSERT或UPDATE操作,不能用于DELETE操作。可以指定多列。因为在ON子句中指定了表名,所以在IF UPDATE子句中的列名前不要包含表名。若要测试在多个列上进行的INSERT或UPDATE操作,请在第一个操作后指定单独的UPDATE(column)子句。在INSERT操作中IF UPDATE将返回 TRUE值,因为这些列插入了显式值或隐性(NULL)值。column:是要测试INSERT或UPDATE操作的列名。该列可以是SQL Server支持的任何数据类型。 IF (COLUMNS_UPDATED():测试是否插入或更新了提及的列,仅用于 INSERT或UPDATE触发器中。COLUMNS_UPDATED返回varbinary 位模式,表示插入或更新了表中的哪些列。COLUMNS_UPDATED函数以从左到右的顺序返回位,最左边的为最不重要的位。最左边的位表示表中的第一列;向右的下一位表示第二列,依此类推。如果在表上创建的触发器包含8列以上,则COLUMNS_UPDATED返回多个字节,最左边的为最不重要的字节。在INSERT操作中 COLUMNS_UPDATED将对所有列返回TRUE 值,因为这些列插入了显式值或隐性(NULL)值。bitwise_operator:是用于比较运算的位运算符。updated_bitmask:是整型位掩码,表示实际更新或插入的列。例如,表 t1 包含列C1、C2、C3、C4和C5。假定表t1上有UPDATE 触发器,若要检查列C2、C3和C4是否都有更新,指定值14;若要检查是否只有列C2有更新,指定值2。comparison_operator:是比较运算符。使用等号(=)检查updated_bitmask 中指定的所有列是否都实际进行了更新。使用大于号(>)检查updated_bitmask中指定的任一列或某些列是否已更新。column_bitmask:是要检查的列的整型位掩码,用来检查是否已更新或插入了这些列。5. 使用企业管理器创建和管理存储过程。1). 选择要创建存储过程的数据库结点并展开,右键点击点击存储过程从弹出的菜单中选择“新建存储过程(S)”即可如下图3-1所示,之后出现图3-2所示的界面。图3-1图3-2 在图3-2所示的“文本(T)”框中填写创建存储过程的语句,之后必须进行语法检查。也