存储过程

【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的存储过程的更多相关文章

  1. Sqlserver中存储过程,触发器,自定义函数(二)

    Sqlserver中存储过程,触发器,自定义函数: 自定义函数:1.函数类型:2.函数的参数和返回值: 1.函数类型:标量值函数,返回的是一个标量值表值函数:内联表值函数:多语句表值函数. 标量值函数 ...

  2. Sqlserver中存储过程,触发器,自定义函数(一)

    Sqlserver中存储过程,触发器,自定义函数 1.存储过程有关内容存储过程的定义:存储过程的分类:存储过程的创建,修改,执行:存储过程中参数的传递,返回与接收:存储过程的返回值:存储过程使用游标. ...

  3. Sqlserver中存储过程,触发器,自定义函数

    Sqlserver中存储过程,触发器,自定义函数: 1. 触发器:是针对数据库表或数据库的特殊存储过程,在某些行为发生的时候就会被激活 触发器的分类: DML触发器:发生在数据操作语言执行时触发执行的 ...

  4. JSON序列化及利用SqlServer系统存储过程sp_send_dbmail发送邮件(一)

    JSON序列化 http://www.cnblogs.com/yubaolee/p/json_serialize.html 利用SqlServer系统存储过程sp_send_dbmail发送邮件(一) ...

  5. SqlServer中存储过程中将Exec的执行结果赋值给变量输出

    原文 SqlServer中存储过程中将Exec的执行结果赋值给变量输出 背景: 遇到这样一种情况:动态向存储过程中传入表名和表的某些属性(这里用到的是主键ID),然后利用这两个变量查出一条数据的某些字 ...

  6. SqlServer复杂存储过程

    SqlServer复杂存储过程 CREATE PROCEDURE FETCH_GOOUT_INFO AS BEGIN WITH l as(SELECT A.ZJHM, O.KSQR, O.JSRQ, ...

  7. SQLServer 的存储过程与java交互

    一.   存储过程简介 Sql Server的存储过程是一个被命名的存储在服务器上的Transacation-Sql语句集合,是封装重复性工作的一种方法,它支持用户声明的变量.条件执行和其他强大的编程 ...

  8. SqlServer中存储过程 returnC#代码处理以及对应的MySQL如何改写

    一.SqlServer 中 1. 创建表 create table testuser( id int, --primary key, names ), address ), paw ) ) 2.创建存 ...

  9. SQLServer 中存储过程

    SQLServer 中存储过程返回的三种方式( 包括存储过程的创建, 在存储过程中调用, 在VS中调用的方法)存储过程有三种返回:   1.   用return返回数字型数据   2.   用返回参数 ...

  10. asp.net+Sqlserver 通过存储过程读取数据

    Sqlserver代码  创建存储过程如下: /*根据父id获取类别总数*/ IF EXISTS (SELECT name FROM sysobjects WHERE name = N'getsite ...

随机推荐

  1. AOV网络拓扑排序

    这个算法,主要是为输出一个无环图的拓扑序列 算法思想: 主要依赖一个栈,用来存放没有入度的节点,每次读取栈顶元素,并将栈顶元素的后继节点入度减一,如果再次出现入度为零的节点,就加入到栈中.参考< ...

  2. java读取properties的工具类PropertiesUtil

    package org.properties.util; import java.io.FileInputStream; import java.io.FileOutputStream; import ...

  3. 错误内存【读书笔记】C程序中常见的内存操作有关的典型编程错误

    题记:写这篇博客要主是加深自己对错误内存的认识和总结实现算法时的一些验经和训教,如果有错误请指出,万分感谢. 对C/C++程序员来讲,内存管理是个不小的挑战,绝对值得慎之又慎,否则让由上万行代码构成的 ...

  4. myeclipse 10创建maven项目

    创建maven项目,这里使用的不是myeclipse自带的maven插件.而是自己 又一次安装的插件,就不啰嗦了,直接上图吧 1.先是安装maven插件.将maven插件解压把它放进E:\xuan\M ...

  5. linux自己带的apache重新启动

    如果是linux自己带的apache的话就使用命令 service httpd start 启动 service httpd stop 关闭 service httpd restart 重新启动 如果 ...

  6. Android Camera

    Android调用系统api使用照相机功能,实现拍照获取图片以及从照相机库中获取指定图片的功能. 下面是演示样例代码: <?xml version="1.0" encodin ...

  7. Asp.Net MVC 3【Filters(过滤器)】

    这里分享MVC里的Filters(过滤器),什么是MVC里的过滤器,他的作用是什么? 过滤器的请求处理管道中注入额外的逻辑.他们提供了一个简单而优雅的方式来实现横切关注点.这个术语是指所有对应用程序的 ...

  8. debian下软件包管理方式总结

    linux最流行的包管理方式除了rpm之外就是debian的deb格式了.目前采用deb管理方式的主流操作系统主要有debian和ubuntu系列.和rpm包管理方式不同的是,虽然debian也有包含 ...

  9. php生成excel或php生成csv

    一.php生成excel 使用phpexcel类文件生成 二.php生成csv <?php$action ="make";if ($action=='make'){ $fp ...

  10. scala Option 里的 orNull orElse getOrElse 区别和使用

    Scala Option Scala Option类型用来表示一个值是可选的(有值或无值) Option[T] 是一个类型为 T 的可选值的容器: 如果值存在, Option[T] 就是一个 Some ...