数据库中的事务、存储过程和触发器的简单使用
什么是事务(Transaction)
指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)--也就是由多个sql语句组成,必须作为一个整体执行
这些sql语句作为一个整体一起向系统提交,要么都执行、要么都不执行
语法步骤:
开始事务:BEGIN TRANSACTION
事务提交:COMMIT TRANSACTION
事务回滚:ROLLBACK TRANSACTION
判断某条语句执行是否出错:
全局变量@@ERROR;
@@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;
例:SET @errorSum=@errorSum+@@error
存储过程---就像数据库中运行方法(函数)
和C#里的方法一样,由存储过程名/存储过程参数组成/可以有返回结果。
前面学的if else/while/变量 等,都可以在存储过程中使用
优点:
执行速度更快
允许模块化程序设计
提高系统安全性
减少网络流通量
系统存储过程
由系统定义,存放在master数据库中
名称以“sp_”开头或”xp_”开头
自定义存储过程
由用户在自己的数据库中创建的存储过程
系统存储过程
说明
sp_databases
列出服务器上的所有数据库。
sp_helpdb
报告有关指定数据库或所有数据库的信息
sp_renamedb
更改数据库的名称
sp_tables
返回当前环境下可查询的对象的列表
sp_columns
回某个表列的信息
sp_help
查看某个表的所有信息
sp_helpconstraint
查看某个表的约束
sp_helpindex
查看某个表的索引
sp_stored_procedures
列出当前环境中的所有存储过程。 sp_password
添加或修改登录帐户的密码。
sp_helptext
显示默认值、未加密的存储过程、用户定义的存储过程、触发器或视图的实际文本。
定义存储过程的语法
CREATE PROC[EDURE] 存储过程名
@参数 数据类型 = 默认值 OUTPUT,
@参数n 数据类型 = 默认值 OUTPUT
AS
SQL语句
参数说明:
参数可选
参数分为输入参数、输出参数
输入参数允许有默认值
EXEC 过程名 [参数]
触发器是一种特殊类型的存储过程,它不同于前面介绍过的一般的存储过程。
一般的存储过程通过存储过程名称被直接调用,而触发器主要是通过事件进行触发而被执行。
触发器是一个功能强大的工具,在表中数据发生变化时自动强制执行。触发器可以用于SQL Server约束、默认值和规则的完整性检查,还可以完成难以用普通约束实现的复杂功能。
那究竟何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。
常见的触发器有三种:分别应用于Insert , Update , Delete 事件
常用语法
CREATE TRIGGER triggerName ON Table for UPDATE|INSERT|DELETE begin 触发器-更新 CREATE TRIGGER testForFun ON dbo.Category for UPDATE begin select * from book update Category set c_name = Android2 where c_id=3 触发器-删除 CREATE TRIGGER testForDel ON dbo.Category for delete begin select * from book delete Category set c_name = Android2 where c_id=3
最新内容请见作者的GitHub页:http://qaseven.github.io/
数据库的触发器你了解多少 触发器是与表有关的数据库对象,指的是在insert\update\delete操作之前或者之后,能够触发并执行触发器中定义的SQL语句集合。触发器的这种特性可以使得应用在数据库端确保数据的完整性以及日志记录,数据校验等操作。
mysql-视图、触发器、事务、存储过程、流程控制 视图是由查询结果构成的一张虚拟表,和真实的表一样,带有名称的列和行数据 强调:视图是永久存储的,但是视图存储的不是数据,只是一条sql语句 视图的特点: 视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系。
相关文章
- VS2010上连接SQLite数据库
- 更改SQL Server 数据库的排序规则
- 【刷题】数据库三大范式
- 大数据时代的数据存储,非关系型数据库MongoDB
- HBase、Redis、MongoDB、Couchbase、LevelDB主流 NoSQL 数据库的对比
- Spring实战6-利用Spring和JDBC访问数据库
- 如何将类序列化并直接存储入数据库
- [MySQL] 导入数据库和表的两种方式
- ETL工具之Kettle的简单使用一(不同数据库之间的数据抽取-转换-加载)
- 如何查询 SAPGUI 屏幕上某个字段对应的数据库表存储
- 如何查找BAPI SD_SALESDOCUMENT_CHANGE里字段对应的数据库存储表
- Atitit 软件项目的一整套解决方案(gui界面,中间,存储数据库,图像处理,全文搜索)attilax总结
- Atitit。数据库 安全性 重要敏感数据加密存储解决方案
- atitit. hb 原生sql跨数据库解决原理 获得hb 数据库类型运行期获得Dialect
- 【Android笔记30】Android中数据存储之SQLite数据库
- BigData之MongoDB:MongoDB(基于分布式文件存储的非关系型数据库)的简介、下载、案例应用之详细攻略
- 分盘存储:实现数据库备集群备份文件分散存储
- 十大热门问题集锦,一眼看懂华为云数据库黑科技
- 对SQLite 数据库的一点点了解
- 秒杀程序数据库设计
- MySQL的数据库引擎的类型及区别
- NoSQL四种——kv存储(memcache,Riak),列存储(Cassandra,Hbase),文档类(mongoDB,CouchDB),图数据库(neo4j)
- 时间序列数据库选型——本质是列存储,B-tree索引,抑或是搜索引擎中的倒排索引
- 什么是数据库?什么是关系数据库?什么是非关系型数据库?
- 关于各大数据库日志存储原理
- MySQL基础篇 | 存储引擎、事务、索引、视图、DBA命令、数据库设计三范式
- 数据库是什么?数据库的概念