日期:2014-05-16  浏览次数:20432 次

数据库中的事务、存储过程和触发器的简单使用
l什么是事务(Transaction)
l指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)--也就是由多个sql语句组成,必须作为一个整体执行
l这些sql语句作为一个整体一起向系统提交,要么都执行、要么都不执行
l语法步骤:
?开始事务:BEGIN TRANSACTION
?事务提交:COMMIT TRANSACTION
?事务回滚:ROLLBACK TRANSACTION
l判断某条语句执行是否出错:
?全局变量@@ERROR;
?@@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;
         例:SET @errorSum=@errorSum+@@error
 
l存储过程---就像数据库中运行方法(函数)
l和C#里的方法一样,由存储过程名/存储过程参数组成/可以有返回结果。
l前面学的if else/while/变量 等,都可以在存储过程中使用
l优点:
执行速度更快
允许模块化程序设计
提高系统安全性
减少网络流通量
l系统存储过程
?由系统定义,存放在master数据库中
?名称以“sp_”开头或”xp_”开头
l自定义存储过程
?由用户在自己的数据库中创建的存储过程
 
 
系统存储过程
说明
sp_databases
列出服务器上的所有数据库。
sp_helpdb
报告有关指定数据库或所有数据库的信息
sp_renamedb
更改数据库的名称
sp_tables
返回当前环境下可查询的对象的列表
sp_columns
回某个表列的信息
sp_help
查看某个表的所有信息
sp_helpconstraint
查看某个表的约束
sp_helpindex
<