存储过程

------------存储过程--------------
--usp_存储过程


--无参数的一个查询存储过程语法
/*
create proc usp_存储过程名
as
查询步骤
*/
go
create proc usp_spFenYe1
as
select * from dbo.Fn_FenYe1(1,2);

go

-----------
exec usp_spFenYe1;

------------------
go
alter proc usp_ZZ1--修改存储过程,create 为创建
as 
begin
 
begin transaction
declare @myError int ;
set @myError=0;
update bank set balance=balance+900 where cId='001';
set @myError+=@@ERROR;
update bank set balance=balance-900 where cId='002';
if(@myError>0)
begin
rollback transaction
end
else
begin 
commit transaction
end
end


--执行存储过程
go
exec usp_ZZ1;
go
select * from bank;


-------------------视图,存储过程,内联表值函数
--视图里面只能有一个结果集的查询


go
create view vw_Test1
as
   select 1 as n,2 as m,3 as k
   union
   select 4,5,6;


go
select * from vw_Test1;
---------------------------
go
create proc usp_Test
as 
begin
if(OBJECT_ID('TestTbl')) is not null
drop table TestTbl;
create table TestTbl
(
id int
)
end;
go
exec usp_Test;
select * from TestTbl


----------------带有参数的存储过程
--转账的例子
--转账时,输入谁转给谁,同时转多少


/*
    create proc usp_ZZ2
    @参数名 类型名,
     @参数名 类型名,
     @参数名 类型名
     as  
     begin --事务
*/
go
create proc usp_ZZ2
@from char(4),
@to char(4),
@money money
as
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;
if(@myError>0)
begin
rollback transaction;
end
else
begin
commit transaction;
end
go


exec usp_ZZ2'001','002',100;exec usp_ZZ2 @from='001',@to='002',@money=100;
select * from bank;


------------有的存储过程不需要参数,有时又需要参数
--一般不需要参数的时候,是有一个默认值的参数
/*
语法


create proc usp_TestDefault
@testVal int =默认值
as
select
*/
--调用一个存储过程,如输入参数,就将参数打印出来,否则打印默认值
go
create proc usp_TestDefault
@str nvarchar(50)='默认值'
as 
select @str;


exec usp_TestDefault;
exec usp_TestDefault '我是传进来的参数'
---一般情况,使用存储过程返回数据,都是使用output参数


select datediff (second ,'2012-01-01 0: 0:0',getdate())


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)
-- 我为了保证一致性,要求当转账后,即减去钱以后,余额还要大于10
-- @last - @money > 10
begin
update bank set balance=balance - @money where cid=@from;
update bank set balance=balance + @money where cid=@to;
commit;
set @state = 1;--成功
end
else
begin
rollback;
set @state = 0;--失败
end
end
go


--使用
declare @mystate int;
exec usp_ZZ4 '001','002',100,@mystate output;
select @mystate;























































































  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
USB-IF高速;,经认证符合通用串行总线规范修订版 2.0 接口在 8 位模式下与 ULPI 规范修订版 1.1 兼容 工业标准 UTMI+ 低引脚接口 (ULPI) 可将 54 UTMI+ 信号转换为标准的 12 引脚链路控制器接口 54.7mA 未配置电流(典型情况)— 适用于总线供电的应用 83uA 挂起电流(典型情况)— 适用于电池供电的应用 闭锁性能超过 150 mA(每 EIA/JESD 78),Class II ESD 防护水平达 ±8kV HBM(在不使用外部保护设备的情况下) 集成了各种保护措施,在每个第三方的测试设备中均可耐受 IEC61000-4-2 ESD 测试(±8kV 接触电压和 ±15kV 空气电压) 支持用于附带 LS 设备的 FS 集线器的 FS 前导码 (UTMI+ Level 3) 支持 HS SOF 和 LS keep-alive 脉冲 包括对可选的 On-The-Go (OTG) 协议的全面支持,在 On-The-Go 附录修订版 1.0a 规范中有详细说明 支持 OTG 主机协商协议 (HNP) 和会话请求协议 (SRP) 允许主机关闭 VBUS,以便在 OTG 应用中节省电池电量 通过内部比较器支持 VBUS 电平的 OTG 监视。包括对外部 VBUS 或故障监视器的支持。 低潜伏高速接收器(最高为 43 高速时钟)允许使用带 ULPI 包装器的潜伏 UTMI 链路 用于接口保护的 STP 上的集成下拉电阻,允许在使用低速链路(针对低功率情况对软件进行了配置)的情况下,可靠地启动 Link/PHY 内置的 1.8V 调节器允许在使用单个 3.3V 电源的情况下工作 对 ID、DP 和 DM 线路到 VBUS 或接地进行内部短路保护 集成的 24MHz 晶振支持水晶操作或 24MHz 外部时钟输入 用于 480MHz 高速 USB 操作的内部 PLL 工业运行温度:-40°C 到 +85°C 符合 RoHS 的 32 引脚无铅 QFN 封装(5 x 5 毫米, 高度为 0.90 毫米)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值