--事务分三种
--1.显示事务
--我们手动begin transaction ...... commit transaction/rollback transaction
--上面这种写法叫做“显示事务” --2.隐式事务
SET IMPLICIT_TRANSACTIONS { ON | OFF }隐式事务 --3.自动提交事务,SQL Server默认使用的是自动提交事务.
--我们每次执行一条sql语句的时候,sql server都会自动帮我们打开一个事务
--如果该sql语句执行不出错,则sql server自动提交该事务commit
--如果该sql语句执行出错了,那么sql server则自动回滚该事务。rollback --1:创建第一个简单的存储过程
CREATE PROC usp_helloworld
AS
BEGIN
PRINT 'hello world!'
END EXEC usp_helloworld --2:带参数的存储过程
CREATE PROC usp_showmsg
@msg nvarchar(300) ---多个参数使用,隔开。
AS
BEGIN
PRINT @msg
END EXEC usp_showmsg N'XXX' EXEC usp_showmsg @msg=N'' --3:简单的加法存储过程
CREATE PROC usp_add
@n int,
@m int
AS
BEGIN
PRINT @n+@m
END EXEC usp_add 100,200 DROP PROC usp_add --4:带默认值的存储过程
ALTER PROC usp_add
@num1 int = 100, --为参数加默认值
@num2 int = 200
AS
BEGIN
PRINT @num1 + @num2
END --5:部分带默认值的存储过程
ALTER PROC usp_add
@num1 int = 100, --为参数加默认值
@num2 int
AS
BEGIN
PRINT @num1 + @num2
END exec usp_add @num2=50 --6:存储过程中的输出参数
SELECT * FROM TblStudent ALTER PROC usp_selectByAge
@age int,
@count int OUTPUT -- 输出参数
AS
BEGIN
--1. 根据@age进行查询
SELECT * FROM TblStudent where tSAge>@age --2.返回一共查询出了多少条数据
SET @count=(SELECT COUNT(*) FROM TblStudent where tsage>@age)
END DECLARE @c int
EXEC usp_selectByAge @age=20,@count=@c OUTPUT
PRINT @c --7:经典写法:转账使用存储过程来编写
--存储过程
CREATE PROC usp_transfer
@from char(4),
@to char(4),
@money money,
@state bit OUTPUT --1表示转账成功,0表示转账失败!
AS
BEGIN
DECLARE @balance money,@sum int=0
SET @state=0
--1.查询@from中的余额
SET @balance=(SELECT balance FROM bank WHERE bank.cId=@from)
--2.检查余额是否充足
IF @balance-@money>10 BEGIN
----3.开始事务进行转账
--打开事务
BEGIN TRANSACTION
--1.减钱
UPDATE bank SET balance=bank.balance-@money where bank.cId=@from
SET @sum=@sum+@@error
--2.加钱
UPDATE bank SET balance=bank.balance+@money where bank.cId=@to
SET @sum=@sum+@@error IF @sum=0 BEGIN
SET @state=1 --设置转账成功
COMMIT TRAN
END
ELSE
ROLLBACK TRAN END
END
--调用存储过程
DECLARE @ok bit
EXEC usp_transfer @from='',@to='',@money=800,@state=@ok OUTPUT
SELECT @ok SELECT * FROM bank --8:经典:分页存储过程
SELECT * FROM Customers order by Customers.CustomerID asc --创建存储过程
--参数:
--每页大小pagesize
--当先用户要查看第几页
--总页数
--总条数
CREATE PROC usp_get_customers_by_page
@pagesize int=5, --每页多少条
@pageindex int=1, --用户当前要看第几页
@recordcount int OUTPUT, --总记录条数,输出参数
@pagecont int OUTPUT --总页数,输出参数
AS
BEGIN
--1. 分页查询语句
SELECT
T.CustomerID,
T.CompanyName,
T.City,
T.[Address],
T.Phone
FROM (SELECT *,rn=ROW_NUMBER()OVER(ORDER by CustomerID ASC) FROM Customers) AS T
WHERE T.rn BETWEEN @pagesize*(@pageindex-1)+1 and @pagesize*@pageindex --2.返回总条数
SET @recordcount=(SELECT COUNT(*) FROM Customers) --3.计算总页数,并返回
SET @pagecont=CEILING(@recordcount*1.0/@pagesize);
END --调用存储过程
DECLARE @pc int,@rc int
EXEC usp_get_customers_by_page 7,13,@rc OUTPUT,@pc OUTPUT
PRINT @pc
PRINT @rc --9:增删改查:存储过程
--insert
CREATE PROC usp_insert_newperson
@name nvarchar(50),
@age int
AS
BEGIN
INSERT into NewPerson VALUES(@name,@age)
END
------------------------------
--delete
CREATE PROC usp_delete_newperson
@autoId int
AS
BEGIN
DELETE from NewPerson where NewPerson.autoId=@autoId
END
------------------------------
--update
CREATE PROC usp_update_newperson
@autoId int,
@name nvarchar(50),
@age int
AS
BEGIN
UPDATE NewPerson set uName=@name,age=@age WHERE NewPerson.autoId=@autoId
END
---------------------------------------
--select
CREATE PROC usp_select_newperson
AS
BEGIN
SELECT * FROM NewPerson
END
-------------------------------------
CREATE view vw_newperson
AS
SELECT * FROM NewPerson --10:其它-----
SELECT * FROM Contacts
SELECT * FROM deleted INSERT into NewPerson (NewPerson.uName,age)
OUTPUT INSERTED.autoId VALUES('王子斌',20) ----inserted------------------- deleted----------------------- SELECT * FROM Customers DELETE from Customers where Customers.CustomerID='CHOPS' SELECT TOP 0 * INTO CustomersBak FROM Customers SELECT * FROM CustomersBak ALTER TRIGGER tri_customers_after_delete ON Customers
AFTER DELETE
AS
BEGIN
INSERT INTO CustomersBak SELECT * FROM DELETED
END SELECT * FROM Customers DELETE from Customers where Customers.CustomerID IN('CACTU','CENTC','ERNSH') CREATE TABLE A20140222 ( A VARCHAR(10)) DECLARE @SQL varchar(500)
SET @SQL='CREATE TABLE T_'+CONVERT(VARCHAR(10),GETDATE(),112)+' ( A VARCHAR(10))'
PRINT @SQL
EXEC(@SQL ) PRINT CONVERT(VARCHAR(10),GETDATE(),112)

MSSQL Transaction[事务] and Procedure[存储过程]的更多相关文章

  1. MSSQL 视图/事务(TRAN[SACTION])/存储过程(PROC[EDURE])/触发器(TRIGGER )

    --视图 视图是一张虚拟表,它表示一张表的部分数据或多张表的综合数据,其结构和数据是建立在对表的查询基础上 视图在操作上和数据表没有什么区别,但两者的差异是其本质是不同: 数据表是实际存储记录的地方, ...

  2. ADO.NET系列之事务和调用存储过程

    ADO.NET系列之Connection对象 ADO.NET系列之Command对象 ADO.NET系列之DataAdapter对象 ADO.NET系列之事务和调用存储过程 前几篇我们介绍了Conne ...

  3. MSSQL收缩事务日志&日志文件过大无法收缩

    原文:MSSQL收缩事务日志&日志文件过大无法收缩 一.MS SQL SERVER 2005 --1.清空日志 exec('DUMP TRANSACTION 数据库名 WITH NO_LOG' ...

  4. Oracle job procedure 存储过程定时任务

    Oracle job procedure 存储过程定时任务 oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相关视图 ...

  5. [原创]java WEB学习笔记77:Hibernate学习之路---Hibernate 版本 helloword 与 解析,.环境搭建,hibernate.cfg.xml文件及参数说明,持久化类,对象-关系映射文件.hbm.xml,Hibernate API (Configuration 类,SessionFactory 接口,Session 接口,Transaction(事务))

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  6. 【转】Oracle job procedure 存储过程定时任务

    原文:Oracle job procedure 存储过程定时任务 oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相 ...

  7. oracle procedure存储过程

    1.基本结构 CREATE OR REPLACE PROCEDURE 存储过程名字 ( 参数1 IN NUMBER, 参数2 IN NUMBER ) IS/AS 变量1 ; 变量2 DATE: BEG ...

  8. SqlCommand对象-Transaction事务的使用

    using (SqlConnection connection = new SqlConnection(connStr)) { SqlCommand sqlcmd = new SqlCommand() ...

  9. Oracle job procedure 存储过程定时任务(转自hoojo)

    Oracle job procedure 存储过程定时任务 oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务. 一.查询系统中的job,可以查询视图 --相关视图 ...

随机推荐

  1. Flexbox布局详解

    弹性框布局 (flexbox) 添加了级联样式表级别 2 修订版 1 (CSS2.1) 中定义的四个基本布局模式:块布局.内联布局.表格布局和定位布局.使用弹性框布局功能,你可以更加轻松地设计复杂网页 ...

  2. leetcode 26

    26. Remove Duplicates from Sorted Array Given a sorted array, remove the duplicates in place such th ...

  3. SVN更新、清理乱码解决

    我的电脑信息 win7 64bit svn版本: 先介绍一种最简单的方法,一般都会有效,疑难杂症请用第二种 方法一: 将前面6项全部选上--> [确定] 无效请仔细看下面方法二方法详解 方法二: ...

  4. Nginx 开启 path_info功能

    server { listen ; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; roo ...

  5. 软件工程 speedsnail 第二次冲刺3

    20150520 完成任务:划线第三天,能画出一条直黄线且与蜗牛共存: 遇到问题: 问题1 碰撞检测有缺陷 解决1 没有解决 明日任务: 实现蜗牛与线的碰撞

  6. Oracle中存储过程与函数的区别

    Oracle 获取信息一般用function 修改数据用存储过程(需要执行commit命令)

  7. 记一次动态调用WebService

    这次的使用参考博客园中的ID是  生命不息,折腾不止 http://www.cnblogs.com/leolion/p/4757320.html ,感谢分享 博客园让自己慢慢的成长,少不了这些无私奉献 ...

  8. Hadoop在win7下部署的问题

    问题: 为了测试方便所以在win7下部署了伪分布式hadoop运行环境,但是部署结束后在命令行运行hadoop命令创建一个用户文件目录时出现了一下情况: 系统找不到指定的批标签- make_comma ...

  9. 【译】Spark官方文档——编程指南

    本文翻自官方博客,略有添加:https://github.com/mesos/spark/wiki/Spark-Programming-Guide Spark发指南 从高的面看,其实每一个Spark的 ...

  10. ASP.NET Web API安全认证

    http://www.cnblogs.com/codeon/p/6123863.html http://open.taobao.com/docs/doc.htm?spm=a219a.7629140.0 ...