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 ...
随机推荐
- 蓝桥杯--Quadratic Equation
蓝桥杯--Quadratic Equation 问题描述 求解方程ax2+bx+c=0的根.要求a, b, c由用户输入,并且可以为任意实数. 输入格式:输入只有一行,包括三个系数,之间用空格格开. ...
- 搜狐cache文件夹设置
比如说本来sohucache放在E盘,你想改到D盘.第一步:在运行中打开regedit,在弹出的HKEY_CURRENT_USER选中Software第二步:再选中SOHU再选中SoHuVA再选中Ca ...
- Swift学习笔记四
前面三篇笔记通过一些示例展示了Swift的一些特性,粗略地介绍了它的语法和特色,从这一篇笔记开始,将正式系统地介绍Swift的语法和特性了. Swift是一门为iOS和OSX开发准备的全新语言,但是它 ...
- hdu 5427 A problem of sorting 水题
A problem of sorting Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://bestcoder.hdu.edu.cn/contest ...
- 纯windows下制作变色龙引导安装U盘教程
原创教程:纯windows下制作变色龙引导安装U盘教程 支持Mavericks和Yosemite 支持白苹果 目标:windows下制作带 Chamelon变色龙引导的黑苹果安装U盘,支持PC机引导安 ...
- C++的64位整数
在做ACM题时,经常都会遇到一些比较大的整数.而常用的内置整数类型常常显得太小了:其中long 和 int 范围是[-2^31,2^31),即-2147483648~2147483647.而unsig ...
- Uploadify帮助文档
auto 当文件被添加到队列时,自动上传. (字符串) buttonImg 浏览按钮的背景图片路径. (字符串) buttonText 默认在按钮上显示的文本. (字符串) cancelImg 取消按 ...
- 利用正则表达式作为string.split seprator
某字符串 var str = "{1,att,7},{2,break,7},{3,crit,7},{4,combo,7},{5,break,7},{6,hit,7}"; 需要分割成 ...
- 利用 Composer 一步一步构建自己的 PHP 框架(一)——基础准备
『Composer 一统天下的时代已经到来!』——白岩松 “一个时代结束了,另一个时代开始了.” Framework Interoperability Group(框架可互用性小组),简称 FIG,成 ...
- mysql颠覆实战笔记(六)--商品系统设计(三):商品属性设计之固定属性
今天我们来讲一下商品属性 我们知道,不同类别的商品属性是不同的. 我们先建一个表prod_class_attr: