SQLserver的存储过程
存储过程
【Create是创建存储过程,alter是更改、改变存储过程】
【在第一次写存储过程时用create,若修改存储过程程序之后,则alter替换create再执行】
【在数据库中begin end为大括号的意思】
·创建存储过程的格式:
--(procedure可简写为proc)proc为程序、步骤的意思。后跟存储过程名
create proc 存储过程名
as
代码块
Go
--exec为执行的意思。执行存储过程
Exec 存储过程名
---------修改存储过程
alter proc hehe ---alter更改、改变的意思
as
select 学生学号,语文分数 from fenshu
go
exec hehe
-------------查询多个表
create proc chaxun
as
begin
select * from fenshu
select * from jiaoshi
select * from xuesheng
end
go
exec chaxun
--------------带参数的存储过程
create proc chucunguocheng
@yican varchar(20), @yican 含义为形参
@ercan varchar(20)
as
begin
print @yican+@ercan
end
go
exec chucunguocheng '你好','中国'
例题:
-------输入学号,判断学生优秀、结业、不结业(三门课及格为优秀,两门课及格为结业)
alter proc biye
@xuehao int --创建输入变量
as
begin
declare @y int
declare @s int
declare @w int
declare @zongshu int
select @y=COUNT(*) from fenshu where 学生学号=@xuehao and 语文分数>=60
select @s=COUNT(*) from fenshu where 学生学号=@xuehao and 数学分数>=60
select @w=COUNT(*) from fenshu where 学生学号=@xuehao and 英语分数>=60
set @zongshu=@y+@s+@w
if @zongshu=3
print '优秀'
if @zongshu =2
print '结业'
if @zongshu=1
print'不结业'
if @zongshu=0
print'输入错误'
end
go
exec biye 1
结果为:
--------综合练习题
(存储过程综合训练)
创建一个货物表:编号,货物名称,单位,价格,库存数量,备注。(10条数据)
之后,进货,如果已有此货,增加数量,否则,新增入数据库表中。
出货,如果有人要货,判断数量是否充足,充足减库存,否则告知不足。
根据名字随时删除数据库中的数据,有则删除,无则告知。
------------创建数据库及数据表,并插入数据----------
create database 笔记本
go
create table bijiben
(
编号 int,
名称 nvarchar(20),
备注 varchar(20),
价格 int,
库存 int,
单位 nvarchar(10)
)
go --------(随机排名)------
insert into bijiben values(1,'苹果','macbook',12000,10,'美国')
insert into bijiben values(2,'宏基','acer',3500,20,'中国台湾')
insert into bijiben values(3,'华硕','asus',3500,25,'中国')
insert into bijiben values(4,'戴尔','dell',4300,30,'美国')
insert into bijiben values(5,'神舟','hass',4000,20,'中国')
insert into bijiben values(6,'联想','lenovo',4200,30,'中国')
insert into bijiben values(7,'惠普','ph',3600,20,'美国')
insert into bijiben values(8,'三星','samsung',3700,10,'日本')
insert into bijiben values(9,'索尼','sony',7000,10,'日本')
insert into bijiben values(10,'东芝','toshiba',3200,10,'日本')
select *from bijiben
----------------------进货------------------------
create proc jinhuo --创建进货存储过程
@bianhao int, --进货编号
@bjbn nvarchar(20),--笔记本名
@beizhu nvarchar(20),--备注
@jiage int,--价格
@jinhuo int,--进多少台
@danwei nvarchar(20)--单位
as
begin
declare @ybjbn nvarchar(20),@ykc int --@ykc为数据中的原有的库存数
select @ybjbn=count(名称) from bijiben where 名称=@bjbn
if @ybjbn=0 --当数据库中没有输入的数据时
begin
insert into bijiben values(@bianhao,@bjbn,@beizhu,@jiage,@jinhuo,@danwei)
print'新电脑添加成功!'
end
else if @ybjbn=1 --当数据库中有输入的数据时
begin
select @ykc=库存 from bijiben where 名称=@bjbn
set @ykc=@ykc+@jinhuo
update bijiben set 库存=@ykc where 名称=@bjbn
print'该电脑库存添加成功!'
end
end
go
exec jinhuo 11,'戴尔','dell',4200,10,'美国'
----------------------出货------------------------
create proc chuhuo --创建出货存储过程
@name nvarchar(20), --要出货的笔记本名称
@shuliang int --出货的数量
as
begin
declare @ygeshu int,@hgeshu int --@ygeshu为数据库原来的库存,@hgeshu交易后剩余的库存
select @ygeshu=库存 from bijiben where 名称=@name
if @shuliang>@ygeshu --当出货的数量大于库存的数量时
print'对不起,库存不足~~'
else
begin
set @hgeshu=@ygeshu-@shuliang
update bijiben set 库存=@hgeshu where 名称=@name --修改交易后库存数
print'交易成功!'
end
end
go
exec chuhuo '苹果',11
---------------------------删除一款笔记本数据-------
create proc qingchu
@scbjbn nvarchar(20) --要删除的笔记本的名称
as
begin
declare @sgeshu int --要查找笔记本的个数
select @sgeshu=COUNT(*) from bijiben where 名称=@scbjbn
if @sgeshu=1
begin
delete from bijiben where 名称=@scbjbn
print'该笔记本的数据删除成功!'
end
if @sgeshu=0
print'未找到该名称的笔记本~~'
end
exec qingchu '苹果'
SQLserver的存储过程的更多相关文章
- Sqlserver中存储过程,触发器,自定义函数(二)
Sqlserver中存储过程,触发器,自定义函数: 自定义函数:1.函数类型:2.函数的参数和返回值: 1.函数类型:标量值函数,返回的是一个标量值表值函数:内联表值函数:多语句表值函数. 标量值函数 ...
- Sqlserver中存储过程,触发器,自定义函数(一)
Sqlserver中存储过程,触发器,自定义函数 1.存储过程有关内容存储过程的定义:存储过程的分类:存储过程的创建,修改,执行:存储过程中参数的传递,返回与接收:存储过程的返回值:存储过程使用游标. ...
- Sqlserver中存储过程,触发器,自定义函数
Sqlserver中存储过程,触发器,自定义函数: 1. 触发器:是针对数据库表或数据库的特殊存储过程,在某些行为发生的时候就会被激活 触发器的分类: DML触发器:发生在数据操作语言执行时触发执行的 ...
- JSON序列化及利用SqlServer系统存储过程sp_send_dbmail发送邮件(一)
JSON序列化 http://www.cnblogs.com/yubaolee/p/json_serialize.html 利用SqlServer系统存储过程sp_send_dbmail发送邮件(一) ...
- SqlServer中存储过程中将Exec的执行结果赋值给变量输出
原文 SqlServer中存储过程中将Exec的执行结果赋值给变量输出 背景: 遇到这样一种情况:动态向存储过程中传入表名和表的某些属性(这里用到的是主键ID),然后利用这两个变量查出一条数据的某些字 ...
- SqlServer复杂存储过程
SqlServer复杂存储过程 CREATE PROCEDURE FETCH_GOOUT_INFO AS BEGIN WITH l as(SELECT A.ZJHM, O.KSQR, O.JSRQ, ...
- SQLServer 的存储过程与java交互
一. 存储过程简介 Sql Server的存储过程是一个被命名的存储在服务器上的Transacation-Sql语句集合,是封装重复性工作的一种方法,它支持用户声明的变量.条件执行和其他强大的编程 ...
- SqlServer中存储过程 returnC#代码处理以及对应的MySQL如何改写
一.SqlServer 中 1. 创建表 create table testuser( id int, --primary key, names ), address ), paw ) ) 2.创建存 ...
- SQLServer 中存储过程
SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)存储过程有三种返回: 1. 用return返回数字型数据 2. 用返回参数 ...
- asp.net+Sqlserver 通过存储过程读取数据
Sqlserver代码 创建存储过程如下: /*根据父id获取类别总数*/ IF EXISTS (SELECT name FROM sysobjects WHERE name = N'getsite ...
随机推荐
- oracle中extents存在的理由
extents的特性:1:一个extent由相连的多个blocks组成,多个extents组成一个segment,2:oracle在为segment分配空间时,是以extent为单位因此extents ...
- linux杂谈(十八):DNS服务器的配置(一)
原文地址: http://blog.chinaunix.net/uid-29622064-id-4242123.html 1.DNS服务器简介 域名系统(英文:Domain Name System,縮 ...
- 【转】larbin中的url去重算法
1.bloom filter算法 传说中,larbin使用bloom filter算法来进行url去重.那我们就先来了解下bloom filter算法好了. [以下转自:http://hi.baidu ...
- Java基础-新建项目、包和类
1,新建项目
- 算法优化:rgb向yuv的转化最优算法,快得让你吃惊!
朋友曾经给我推荐了一个有关代码优化的pdf文档<让你的软件飞起来>,看完之后,感受颇深.为了推广其,同时也为了自己加深印象,故将其总结为word文档.下面就是其的详细内容总结,希望能于己于 ...
- VVDocumenter - Xcod代码注释工具
刚接触IOS开发时,发现XCODE非常的强大的,后续的代码实践中发现XOCDE的代码文档注释非常的差, 每次都要用手敲,蛋疼至极: 随着不断学习发现XCODE有代码片段内嵌一说(如:for .bloc ...
- HttpClient post json
public static JSONObject post(String url,JSONObject json){ HttpClient client = new DefaultHttpClient ...
- SQL Server XML Path[转]
FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作.那么以一个实例为主 ...
- SkyEye的使用
转载:http://blog.csdn.net/htttw/article/details/7226754 对于希望学习ARM汇编的同学而言, 购买ARM开发板进行板上实测无疑是一个有效的方法,不过购 ...
- c语言字符串_续
第一篇文章 http://www.cnblogs.com/bluewelkin/p/4063265.html 续篇如下 例一:统计字母的个数(忽略大小写,有空格也可继续统计字母,直到\n结束,但空格未 ...