存储过程

【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. Oracle超出最大连接数问题及解决

    用过Oracle的应该都熟悉如何查看和设置Oracle数据库的最大连接数.这里就再啰嗦一遍. 查看当前的连接数,可以用select count(*) from v$process;设置的最大连接数(默 ...

  2. 超级终端和SecureCRT进行Console口的连接

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html 内部邀请码:C8E245J (不写邀请码,没有现金送) 国 ...

  3. android150 笔记

    1. 什么是Activity? 四大组件之一,一般的,一个用户交互界面对应一个activity,界面的容器. setContentView() ,// 要显示的布局 button.setOnclick ...

  4. Keeplived 配制图解

    http://blog.csdn.net/tantexian/article/details/50056229

  5. 进程间通信之popen和pclose函数

    常见的操作是创建一个管道连接到另一个进程,然后读其输出或向其输入端发送数据,为此,标准I/O库提供了两个函数popen和pclose.这两个函数实现的操作是:创建一个管道,调用fork产生一个子进程, ...

  6. QT Creator 代码自动补全快捷键设置

    在QT Creater界面点Tools再进Options...(找到environment->Keyboard)在里面找到FakeVim目录下的,发现默认快捷键就是CTRL+SPACE,把它删除 ...

  7. vim一个快速切换主题的插件(change-colorscheme,原创)

    概述 有时候我们想快速浏览主题并找到一款合适的主题,change-colorscheme将会满足我们的要求. 安装 git https://github.com/chxuan/change-color ...

  8. myeclipse web 包名保留字与servlet冲突

    包名不能取modify ..........等保留字 不能有数字

  9. 安卓Design包之TabLayout控件的使用

    转自: 安卓Design包之TabLayout控件的简单使用 Google在2015的IO大会上,给我们带来了更加详细的Material Design设计规范,同时,也给我们带来了全新的Android ...

  10. [课程相关]homework-03

    零.准备工作 这次的作业是结对编程,因为一些原因我们的队伍一共有三个人,成员为:梁杰.夏天晗.谢祖三.由于大家不在一个班,交流起来也不是特别方便,所以我们经过讨论决定三个人约一个时间在一起完成这次作业 ...