存储过程:存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。功能强大,限制少

如何调用存储过程
 --无参数的存储过程
exec sp_databases; --有参数的
exec sp_helpdb TestDataBase; exec sp_renamedb TestDataBase, TDB;
-- 当参数较多的时候,建议使用显示赋值
exec sp_renamedb @newname='Testdatabase', @dbname='TDB';

创建,修改无参存储过程:

创建:

-- 一个无参的查询存储过程
/*
create proc usp_存储过程名
as
查询步骤
*/
go
create proc usp_spFenYe
as
select * from dbo.fn_fenye(1,10);--一个分页的fn,获取第一页的数据,10条/页
go

修改已有的存储过程usp_Test,以实现转账为例子(开启事务),

 alter proc usp_Test
as
begin
begin transaction
declare @myError int;
set @myError = 0;
update bank set balance=balance + 900 where cid='';
set @myError += @@ERROR;
update bank set balance=balance - 900 where cid='';
set @myError += @@ERROR;
if(@myError > 0)
begin
rollback transaction;
end
else
begin
commit transaction;
end
end;
go select * from bank; exec usp_Test;

建个有参数的存储过程,继续转账:

 create proc usp_ZZ2
@from char(4), --从那里转
@to char(4), --转到哪里
@money money --金额
as
begin
begin transaction
declare @myError int;
set @myError = 0;
update bank set balance=balance - @money where cid=@from;
set @myError += @@ERROR;
update bank set balance=balance + @money where cid=@to;
set @myError += @@ERROR;
-- 什么时候提交,什么时候回滚?
if(@myError > 0)
begin
rollback transaction;
end
else
begin
commit transaction;
end
end
go select * from bank; exec usp_ZZ2 '', '', 90; exec usp_ZZ2 @money=500, @from = '', @to = ''; exec usp_ZZ2 '', '', 410; go

依然在转账

 create proc usp_ZZ3
@from char(4),
@to char(4),
@money money
as
begin
begin transaction
declare @last money;
set @last = (select balance from bank where cId=@from);
if(@last - 10 >= @money)
-- bank表里有一个检查约束,余额要大于等于10
begin
update bank set balance=balance - @money where cid=@from;
update bank set balance=balance + @money where cid=@to;
commit;
select '转账成功';
end
else
begin
rollback;
select '转账失败';
end
end
go exec usp_ZZ3 '', '', 900; select * from bank;
 给存储过程的参数设置默认值,示例:
 create proc usp_testDefault
@str nvarchar(50) = '默认值'
as
select @str; exec usp_testDefault '我是传进来的参数啊';

output参数怎么用,还在转(转账),修改存储过程zz4;

 -- 带有output参数的存储过程

 go

 create proc usp_ZZ4
@from char(4),
@to char(4),
@money money,
@state int output
-- 这个state表示需要在存储过程中赋值,外面使用的参数
as
begin
begin transaction
declare @last money;
set @last = (select balance from bank where cId=@from);
if(@last - 10 >= @money) begin
update bank set balance=balance - @money where cid=@from;
update bank set balance=balance + @money where cid=@to;
commit;
set @state = 1;--1表示转账成功
end
else
begin
rollback;
set @state = 0;--转账失败
end
end
go
----------------
-- 使用
declare @State int;
exec usp_ZZ4 '', '', 1000, @State output;
exec usp_ZZ4 @from = '', @to = '', @money = -501, @state = @State output; select @State;
 

SqlServer存储过程,学习的更多相关文章

  1. SqlServer存储过程学习笔记(增删改查)

    * IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值. CREATE PROCEDURE [dbo].[PR_NewsAffiche_AddNewsEntity] ( ...

  2. sqlserver存储过程学习笔记(一)基础知识篇(全)

    说出来有点丢人,做sqlserver应用系统近一年,竟然没有使用过存储过程,现在就好好的梳理一下对应知识,慢慢让其加入到我的项目中去吧. 存储过程的优点:1.运行效率高,提供了在服务器端快速执行sql ...

  3. SQLServer存储过程学习记录

    简单来说,存储过程就是一条或者多条sql语句的集合,可视为批处理文件,但是其作用不仅限于批处理. 一.存储过程的概述 SQL Server中的存储过程是使用T_SQL编写的代码段.它的目的在于能够方便 ...

  4. sqlserver 存储过程学习笔记(二) 在项目中的应用<多表分页>

    (1)存储过程建立 USE [NewPlat] GO /****** Object:  StoredProcedure [dbo].[usp_PagingLarge]    Script Date: ...

  5. SqlServer存储过程应用二:分页查询数据并动态拼接where条件

    前言 开发中查询功能是贯穿全文的,我们来盘一盘使用存储过程分页查询,并且支持动态拼接where条件. 划重点:支持动态拼接where条件 对存储过程的使用有疑问的同学去[SqlServer存储过程的创 ...

  6. 解剖SQLSERVER 第十五篇 SQLSERVER存储过程的源文本存放在哪里?(译)

    解剖SQLSERVER 第十五篇  SQLSERVER存储过程的源文本存放在哪里?(译) http://improve.dk/where-does-sql-server-store-the-sourc ...

  7. Sqlserver 存储过程中结合事务的代码

    Sqlserver 存储过程中结合事务的代码  --方式一 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[ ...

  8. SQLServer 存储过程嵌套事务处理

    原文:SQLServer 存储过程嵌套事务处理 某个存储过程可能被单独调用,也可能由其他存储过程嵌套调用,则可能会发生嵌套事务的情形. 下面是一种解决存储过程嵌套调用的通用代码,在不能确定存储过程是否 ...

  9. 创建并在项目中调用SQLSERVER存储过程的简单示例

    使用SQLSERVER存储过程可以很大的提高程序运行速度,简化编程维护难度,现已得到广泛应用.创建存储过程 和数据表一样,在使用之前需要创建存储过程,它的简明语法是: 引用: Create PROC ...

随机推荐

  1. 在Unity5.6.5f1中使用C#7语法

    备忘,记忆力越来越差了,必需把这种琐碎的东西记下来,以防1年后想再用完全没头绪. 之前试过用C#6语法,但是怎么配置操作的完全没印象了. 首先去这下载扩展 https://bitbucket.org/ ...

  2. Bootstrap方法为页面添加一个弹出框

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  3. Chapter6 胞内信号网络

    一.一条从细胞表面到细胞核的通路 二.Ras蛋白处于复杂信号级联的中心位置 胞外信号→酪氨酸激酶受体→Shc→Grb→Sos→Ras 三.酪氨酸的磷酸化控制着许多胞内信号蛋白的定位与活动 Src蛋白的 ...

  4. stm32手册上的英文

    crystal-less 无晶振 USB  FS(Full-speed)此外还有High-speed接口(简称HS),Low-speed接口(简称LS) frequency频率 CRC(Cyclic ...

  5. Buffer cache hit ratio性能计数器真的可以作为SQL Server 内存瓶颈的判断指标吗?

    SQL Server中对于Buffer cache hit ratio的理解: Buffer cache hit ratio官方是这么解释的:“指示在缓冲区高速缓存中找到而不需要从磁盘中读取的页的百分 ...

  6. Android:weight,margin,padding详解实例

    weight详解 weight是用来等比例划分区域的属性. 案例代码 <LinearLayout xmlns:android="http://schemas.android.com/a ...

  7. Swift5 语言指南(十五) 继承

    类可以从另一个类继承方法,属性和其他特性.当一个类继承自另一个类时,继承类称为子类,它继承的类称为其超类.继承是一种基本行为,它将类与Swift中的其他类型区分开来. Swift中的类可以调用和访问属 ...

  8. MySQL slow_log表不能修改成innodb引擎

    背景 从mysql.slow_log 获取慢查询日志很慢,该表是csv表,没有索引. 想添加索引来加速访问,而csv引擎不能添加索引(csv引擎存储是以逗号分割的文本来存储的),只能改存储引擎来添加索 ...

  9. typeof 与instanceof

    函数原型链: 2.typeof获取到的是产生该对象的根源object, instanceof获取的是最终产生该对象的父级构造函数 <script> var arr=[1,2,3,4,&qu ...

  10. javascript实现二分法

    js 实现数组查找二分法 二分法实现原理:二分查找可以解决已经排好序数组的查找问题:只要数组中包含target(即要查找的值),那么通过不断缩小包含target数组的范围,最终就可以找到它. 其算法流 ...