• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > sql server的存储过程

sql server的存储过程

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了sql,server,存储等相关知识,希望本文的分享对您有所帮助
存储过程

【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

结果为:

2323.jpg

--------综合练习题

(存储过程综合训练)

创建一个货物表:编号,货物名称,单位,价格,库存数量,备注。(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 '苹果'

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05教会你完全搞定MySQL数据库 轻松八句话
  • 2018-12-05oracle存储过程中return和exit区别概述及测试
  • 2018-12-05Mysql的limit用法与几种分页形式
  • 2018-12-05Oracle返回星期几的函数
  • 2018-12-05Mysqlslap MySQL压力测试工具 简单教程
  • 2017-05-11基于SQL中SET与SELECT赋值的区别详解
  • 2018-12-05MYSQL速度慢的问题 记录数据库语句
  • 2018-12-05如何使JDK导入证书
  • 2018-12-05关于MySQL5.7.19安装目录下如何创建my.ini文件的示例详解
  • 2018-12-05MySQL 5.7新特性| Json Column和Generated Column(上)

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 在MySQL中使用mysqlbinlog flashback的简单教程
    • MySQL动态创建表,数据分表的存储过程
    • SQL 新增/修改 表字段列的类型等
    • 分享MySQL的自动化安装部署的方法
    • 关于学生信息管理系统的知识点
    • 日期和时间处理函数及数值处理函数实例(数据处理函数的使用二)
    • mysql query browser中文乱码的解决方法
    • 如何解决MySQL的root密码忘记的问题_MySQL
    • mysql innodb的监控(系统层,数据库层)详解
    • MySQL下海量数据的迁移步骤分享

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有