1、存储过程

存储过程可以包含数据操纵语句、变量、逻辑 控制语句等,比如:单个select语句, select语句块,select语句与逻辑控制块。

存储过程优点: 

   执行速度更快

   允许模块化程序设计

   提高系统安全性

   减少网络流通量

由系统定义,存放在master数据库中

   类似C语言中的系统函数

   系统存储过程的名称都以“sp_”开头或”xp_”开头

用户自定义存储过程

语法:
  CREATE PROC[EDURE] 存储过程名
    @参数1 数据类型 = 默认值 OUTPUT,
    …… ,
    @参数n 数据类型 = 默认值 OUTPUT
    AS
    SQL语句
  GO

例子:请创建存储过程,查看本次考试平均分以及未通过考试的学员名单

create database test

use test

create table stuInfo
(
stuNo int identity(1,1) primary key ,
stuName varchar(1000) not null ,
stuAge int check(stuAge>=0 and stuAge<=130) not null,
stuSex char(2) default('男') not null,
stuAddress text not null
)

insert into stuInfo(stuName,stuAge,stuAddress) values('张三',20,'湖南省')

select * from stuInfo

create table stuMarks
(
stuMID int identity(1,1) primary key,
stuNo int not null references stuInfo(stuNo),
stuMMakes float not null,
stuMLungunger float not null
)

insert into stuMarks values(1,99,90),
(2,88,88),
(3,77,77),
(4,60,60),
(5,55,55),
(6,69,60)

  create proc stu_procstu--创建存储过程
  AS
  DECLARE @writtenAvg float,@labAvg float
  SELECT @writtenAvg=AVG(stuMMakes),@labAvg=AVG(stuMLungunger)
  FROM stuMarks
  print '笔试平均分:'+convert(varchar(10),@writtenAvg)
  print '机试平均分:'+convert(varchar(10),@labAvg)
  IF (@writtenAvg>70 AND @labAvg>70)
  print '本班考试成绩:优秀'
  ELSE
  print '本班考试成绩:较差'
  print '--------------------------------------------------'
  print ' 参加本次考试没有通过的学员:'
  SELECT stuName,stuInfo.stuNo,stuMMakes,stuMLungunger
  FROM stuInfo INNER JOIN stuMarks ON stuInfo.stuNo=stuMarks.stuNo
  WHERE stuMMakes<60 OR stuMLungunger<60

  exec stu_procstu--调用执行存储过程
  drop proc stu_procstu--删除存储过程

存储过程的参数分为两种:输入参数和输出参数

输入参数:

  

--根据输入的参数查找本次考试没有通过的学员

  CREATE PROCEDURE proc_stu_para
  @writtenPass int,
  @labPass int
  AS
  print '--------------------------------------------------'
  print ' 参加本次考试没有通过的学员:'
  SELECT stuName,stuInfo.stuNo,stuMMakes,stuMLungunger
  FROM stuInfo
  INNER JOIN stuMarks ON stuInfo.stuNo=stuMarks.stuNo
  WHERE stuMMakes<@writtenPass OR stuMLungunger<@labPass
  GO

  exec proc_stu_para 60,80

输出参数

--查看本次及格分数线的一下的学员人数,检验分数线是否需要调整

  CREATE PROCEDURE proc_stu_out
  @notpassSum int OUTPUT,
  @writtenPass int=60,
  @labPass int=60
  AS

  SELECT stuName,stuInfo.stuNo,stuMMakes, stuMLungunger
  FROM stuInfo
  INNER JOIN stuMarks ON stuInfo.stuNo=stuMarks.stuNo
  WHERE stuMMakes<@writtenPass OR stuMLungunger<@labPass
  SELECT @notpassSum=COUNT(stuNo)      --改参数接受未满足条件的数量用于调用输出@notpassSum
  FROM stuMarks WHERE stuMMakes<@writtenPass OR stuMLungunger<@labPass
  GO

  DECLARE @sum int     --调用存储过程,输入参数,检验输出值
  EXEC proc_stu_out @sum OUTPUT ,64
  print '--------------------------------------------------'
  IF @sum>=3
  print '未通过人数:'+convert(varchar(5),@sum)+ '人, 超过60%,及格分数线还应下调'
  ELSE
  print '未通过人数:'+convert(varchar(5),@sum)+ '人,已控制在60%以下,及格分数线适中'
  GO

注意接收存储过程返回值时必须加output关键字

sql 存储过程学习的更多相关文章

  1. SQL数据库问题 解释一下下面的代码 sql 存储过程学习

    SQL数据库问题 解释一下下面的代码 2008-08-13 11:30wssqyl2000 | 分类:数据库DB | 浏览1154次 use mastergocreate proc killspid( ...

  2. [BILL WEI]SQL 存储过程学习

    --查看数据库exec sp_databases ;--查看表exec sp_tables ;--查看列exec sp_columns WMS_ASN;--查看索引exec sp_helpindex ...

  3. SQL存储过程概念剖析

    一.SQL存储过程的概念,优点及语法 定义:将常用的或很复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来, 那么以后要叫数据库提供与已定义好的存储过程的功能相同的服务时,只需调用execut ...

  4. SQL server存储过程学习

    由于之前使用 Linq to Sql来操作数据库,对于数据库的存储过程.函数等比较薄弱.乘着自己闲着的时候,就百度自学了一点存储过程,以防以后要用. 基础通俗易懂的存储过程通过 存储过程学习 ,然后自 ...

  5. SQL server学习(三)T-SQL编程、逻辑控制语句和安全模式

    T-SQL编程 T-SQL编程与C语言类似,只是语法稍有不同而已,总体思想还是没有变化的.多的就不说了,还是从变量开始. 变量也分为全局变量和局部变量,表示方式稍有不同. 局部变量: 局部变量必须以标 ...

  6. SQL Server 学习系列之五

    SQL Server 学习系列之五 SQL Server 学习系列之一(薪酬方案+基础) SQL Server 学习系列之二(日期格式问题) SQL Server 学习系列之三(SQL 关键字) SQ ...

  7. SQL Sever 学习系列之一

    SQL Sever 学习系列之一 本学习系列,从实际工作需要中积累,对于一个新手而言,写出几条漂亮的查询语句,应该是可以受启发的. 一.问题的需求是:员工薪酬发放,现有资金能发放多少人,哪些人应得? ...

  8. SQL 语句学习

     Sql语句学习 一. select playerId, count(playerId) as num from OperateLog_$i where playerId > 0 and roo ...

  9. SQL server学习

    慕课网sql server学习 数据库第一印象:desktop--web server--database server** 几大数据库:sql server.oracle database.DB2. ...

随机推荐

  1. office365的开发者训练营,免费,在微软广州举办

    本活动在微软官网的地址: https://www.microsoft.com/china/events/detail_1707   先上活动内容:   Office 365每月有超过1亿的商业活跃用户 ...

  2. git相关的操作

    给大家分享下git的使用心得,有不足的请大家补充: 克隆:git clone https://XXXXX 克隆指定分支:git clone -b https://XXXX 添加所有:git add . ...

  3. 2019-01-29 VS Code创建自定义Python代码片段

    续前文[日常]Beyond的歌里最多是"唏嘘"吗? - Python分词+词频最后的想法, 发现VS Code支持用户自定义代码片段: Creating your own snip ...

  4. CYQ.Data 支持分布式数据库(主从备)高可用及负载调试

    前言: 继上一篇,介绍 CYQ.Data 在分布式缓存上支持高可用,详见:CYQ.Data 对于分布式缓存Redis.MemCache高可用的改进及性能测试 本篇介绍 CYQ.Data 在对数据库层面 ...

  5. 在asp.net core2.1中添加中间件以扩展Swashbuckle.AspNetCore3.0支持简单的文档访问权限控制

    Swashbuckle.AspNetCore3.0 介绍 一个使用 ASP.NET Core 构建的 API 的 Swagger 工具.直接从您的路由,控制器和模型生成漂亮的 API 文档,包括用于探 ...

  6. linux 上安装多个不同版本的mysql 踩的坑

    最近由于业务需要,考虑使用json类型,据了解 mysql 在版本5.7中可以支持 json 类型的数据支持,但同时目前开发环境中使用的是 mysql 5.6版本,上面还有很多项目的数据库在上面,同时 ...

  7. ansible基础-Jinja2模版 | 过滤器

    Jinja2模版介绍 注:本文demo使用ansible2.7稳定版 在ansible基础-变量的「8.2 模版使用变量」章节中关于模版与变量也有所提及,有兴趣的同学可以去回顾一下. ansible通 ...

  8. [Swift-2019力扣杯春季决赛]4. 有效子数组的数目

    给定一个整数数组 A,返回满足下面条件的 非空.连续 子数组的数目: 子数组中,最左侧的元素不大于其他元素. 示例 1: 输入:[1,4,2,5,3] 输出:11 解释:有 11 个有效子数组,分别是 ...

  9. Linux知识要点大全(第二章)

    第二章   linux操作系统安装与配置主要内容 1:vmware虚拟机安装与使用 2:Linux系统安装前准备 3:Linux Centos 系统的安装 4:Centos 6.8的登录和关闭 5:C ...

  10. Android-PickerView【仿iOS的PickerView控件,并封装了时间选择和选项选择这两种选择器】使用

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 本文主要演示Android-PickerView的选项选择器.时间选择器的简单运用.由于每一个版本略有不用,所以实际使用方式以git ...