14、SQL基础整理(存储过程)
存储过程procedure(proc)
数据库—可编程性—存储过程
新建存储过程:
create proc firstproc
as
select *from fenshu
go
执行存储过程:
存储过程—右键—执行存储过程
declare @fanhuizhi int
exec @fanhuizhi = firstproc
select 'Return Value' = @fanhuizhi
return value执行成功/失败的返回值(0为成功)
execute/exec firstproc
修改存储过程
alter proc firstproc
as
select yuwen,shuxue,yingyu,name from student,fenshu where student.code = fenshu.code
go
execute firstproc
查询多个表
create proc secondproc
as
begin
select*from student
select*from teacher
select*from fenshu
end
带子查询的查询过程
create proc threeproc
as
begin
declare @count int
select @count=count(*) from (select *from student where code = any(select code from fenshu where code in
(select code from student where MT = ( select code from teacher where name = '数一'))and shuxue>80)
)as new
if @count> 3
print'达标'
else
print'不达标'
end
exec threeproc
带参数的查询过程
create proc fourthproc
@hello varchar(20),
@ercan varchar(20)—参数部分
as
begin
print @hello+@ercan
end
go
exec fourthproc 'helloworld',',你好世界!'
复杂参数
create proc fifthproc
@name varchar(20)
as
begin
declare @countjs int,@lesson varchar(20)
select @countjs = COUNT(*)from teacher where name = @name
if @countjs = 0
begin
print '没找到这个老师'
end
else
begin
select @lesson = course from teacher where name = @name
declare @count int
if @lesson = '语文'
begin
select @count= count(*)from student where code = any(select code from fenshu where code in
(select code from student where CT = ( select code from teacher where name = @name))and yuwen>80)
end
else
if @lesson = '数学'
begin
select @count= count(*)from student where code = any(select code from fenshu where code in
(select code from student where MT = ( select code from teacher where name = @name))and shuxue>80)
end
else
if @lesson = '英语'
begin
select @count= count(*)from student where code = any(select code from fenshu where code in
(select code from student where ET = ( select code from teacher where name = @name))and yingyu>80)
end
if @count>=3
print '达标'
else
print '不达标'
end
end
go
exec fifthproc (@name=可忽略)'数一'
exec fifthproc '数'
删除存储过程
drop proc 存储过程名
练习
------------输入学生的学号,看是否结业(三门课都超过分发优秀证书,有两门课或以上不及格不结业,有一门课不及格结业)------------
alter proc jieye
@xuehao int
as
begin
declare @shuxue int
declare @yuwen int
declare @yingyu int
declare @zongfen int
select @shuxue = count(*) from fenshu where code=@xuehao and shuxue>80
select @yuwen = count(*) from fenshu where code=@xuehao and yuwen>80
select @yingyu = count(*) from fenshu where code=@xuehao and yingyu>80
set @zongfen = @shuxue+@yuwen+@yingyu
if @zongfen = 3
print '优秀'
if @zongfen = 2
print '结业'
if @zongfen < 2
print '不结业'
end
go
返回值
-----------输入一个数,使其+10返回------定义变量接收执行存储过程返回的值
create proc jisuan
@sum int(可以设默认值@sum int=10)
as
begin
set @sum = @sum +10
return @sum
end
declare @shu int
exec @shu = jisuan 2(把2改为default即可按照默认值的输出结果打印)
print @shu
---------返回总分的个数并打印出来-----------
create proc jieye2
@xuehao int
as
begin
declare @shuxue int
declare @yuwen int
declare @yingyu int
declare @zongfen int
select @shuxue = count(*) from fenshu where code=@xuehao and shuxue>80
select @yuwen = count(*) from fenshu where code=@xuehao and yuwen>80
select @yingyu = count(*) from fenshu where code=@xuehao and yingyu>80
set @zongfen = @shuxue+@yuwen+@yingyu
return @zongfen
end
declare @count int
exec @count = jieye2 1
print @count
return后面的存储过程将不再运行(放在if等句子里的例外)
练习
--输入一个数n,求n+n-1+……+1的和---
alter proc qiuhe
@n int
as
begin
declare @sum int =0
while @n>=1
begin
set @sum = @n+@sum
set @n = @n-1
end
return @sum
end
go
declare @n1 int
exec @n1 = qiuhe 5
print @n1
--------带返回值,返回参数,输入参数的存储过程--------
---输入学号,返回三门课的成绩
create proc sixproc
@yuwen decimal(18,2) output,
@shuxue decimal(18,2) output,
@yingyu decimal(18,2) output,
@code int
as
begin
declare @count int
select @yuwen = yuwen,@shuxue = shuxue,@yingyu = yingyu from fenshu where code = @code
end
go
---定义变量接受存储过程带出来的输出参数的值
declare @yuwen decimal(18,2),@yingyu decimal(18,2),@shuxue decimal(18,2)
exec sixproc @yuwen output,@shuxue output, @yingyu output,1
print @yuwen+@yingyu+@shuxue
----------------------------------------------
alter proc sixproc
@yuwen decimal(18,2) output,
@shuxue decimal(18,2) output,
@yingyu decimal(18,2) output,
@code int
as
begin
declare @count int
select @count = COUNT(*)from student where code = @code
select @yuwen = yuwen,@shuxue = shuxue,@yingyu = yingyu from fenshu where code = @code
return @count
end
go
declare @yuwen decimal(18,2),@yingyu decimal(18,2),@shuxue decimal(18,2),@count int
exec @count = sixproc @yuwen output,@shuxue output, @yingyu output,15
print @yuwen+@yingyu+@shuxue
print @count
14、SQL基础整理(存储过程)的更多相关文章
- 必杀技———SQL基础整理系列(一)
SQL(Structured Query Language)——结构化查询语言 SQL语言的组成部分 数据定义语言 (DDL:Data Definition Language) 负责数据结构定义与数据 ...
- 16、SQL基础整理(触发器.方便备份)
触发器(方便备份) 本质上还是一个存储过程,只不过不是通过exec来调用执行,而是通过增删改数据库的操作来执行(可以操作视图) 全部禁用触发器 alter table teacher disable ...
- 11、SQL基础整理(变量)
变量 定义变量:declare @hello varchar(20) 赋值:set @hello = ‘你好’ select(结果框显示)/print(消息框显示) @hello *三行必须同时 ...
- 8、SQL基础整理(约束)
约束 主键约束 防止在新增数据时出错,有约束性,起唯一标志的作用,在新增条目的时候防止不慎添加重复内容(不允许有null值) 1. 右键—设计—设置主键 2.在创建表格时设置 code int pr ...
- 5、SQL基础整理(字符串函数)
字符串函数 ASCII 返回字符串首字母的ascii编码 select ASCII('name') select ASCII(name) from xuesheng select *from xues ...
- SQL基础分页存储过程(案例一)
--分页 存储过程 案例 -- 所执行的存储过程 create proc pageForUsers @currPage int, --当前页数 @pageSize int, --每页多少条记录 @co ...
- 17、SQL基础整理(事务)
事务 事务==流程控制 确保流程只能成功或者失败,若出现错误会自动回到原点 例: begin tran insert into student values('111','王五','男','1999- ...
- 15、SQL基础整理(视图)
视图 即虚拟表 系统-右键-新建视图 编辑前200行 select *from studentscore 代码创建法: create view studentscore as select stude ...
- 13、SQL基础整理(流程控制begin……end)
流程控制 begin ……end将一个语句块包含起来,中间可以写任何语句 格式: begin--开始 select *from student end--结束 if declare @bianlian ...
随机推荐
- UI-popup
做CRM有些时间了,可是对于UI却接触的不是很多,不过感觉UI和DYNPRO差不多...很类似的,...呵呵.加油吧! LV_TITLE = TEXT-T07.”POPUP TITLE LV_PO ...
- sql里Where条件顺序
以前的理解: sql语句里where后面的条件是否分先后顺序的 ,比如 A and B and C和 C and B and A 是一样,不像C语言 A && B 与B &&a ...
- Spark(3) - External Data Source
Introduction Spark provides a unified runtime for big data. HDFS, which is Hadoop's filesystem, is t ...
- vim多行注释和取消多行注释
多行注释: 1. 进入命令行模式,按ctrl + v进入 visual block模式(可视快模式),然后按j, 或者k选中多行,把需要注释的行标记起来 2. 按大写字母i,再插入注释符,例如// 3 ...
- spring mvc表单自动装入实体对象
<form action="/springmvc1/user/add" method="post"> id: <input type=&quo ...
- Android的SwipeToDismiss第三方开源框架模拟QQ对话列表侧滑删除,置顶,将头像图片圆形化处理。
<Android SwipeToDismiss:左右滑动删除ListView条目Item> Android的SwipeToDismiss是github上一个第三方开源框架(github ...
- php pthreads 多线程扩展的使用:一个较为稳定例子。
今天研究了worker stackable的配合方法,写了两种形式,虽然能工作,但是都会出现内存不听增长的问题: 于是把第一个方法的代码邮件给了作者,到现在他没有回复我. 我最后放弃两者配合的方式,直 ...
- GCJ 2015-Qualification-A Standing Ovation 难度:0
https://code.google.com/codejam/contest/6224486/dashboard#s=p0 肯定把朋友们都设置在第0位,在第i位前面必须至少有i个人鼓掌,所以答案加上 ...
- LCA-倍增法(在线)
原文:http://www.tuicool.com/articles/N7jQV32 1. DFS预处理出所有节点的深度和父节点 inline void dfs(int u) { int i; for ...
- 大学生成绩管理系统(C语言)
功能:成绩管理系统包含了学生的全部信息,每个学生是一个记录,包括学号,姓名,性别,班级,各科成绩(语数外). 系统功能: 1.信息录入——录入学生信息: 2.信息输出——显示所有信息: 3.信息查询— ...