SQL Server之存储过程

存储过程的概念

存储过程Procedure是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中,用户通过指定存储过程的名称并给出参数来执行。

存储过程中可以包含逻辑控制语句和数据操纵语句,它可以接受参数、输出参数、返回单个或多个结果集以及返回值。

由于存储过程在创建时即在数据库服务器上进行了编译并存储在数据库中,所以存储过程运行要比单个的SQL语句块要快。同时由于在调用时只需用提供存储过程名和必要的参数信息,所以在一定程度上也可以减少网络流量、简单网络负担。

--===========系统存储过程==============

--显示系统数据库
exec sp_databases

--显示数据库详细信息
exec sp_helpdb

--给指定的数据库更换名称
exec sp_renamedb ‘aa‘,‘bb‘

--查看指定表名的详细信息
exec sp_help student

--查看指定索引、视图、存储过程等的创建文本信息
exec sp_helptext sp_help

--调用存储过程必须在批处理文件第一位
if exists(select * from sysobjects where name = ‘Table1‘)
    drop table Table1
go
sp_help sp_help

--==========系统扩展存储过程================
use master
go

--创建文件夹bank
exec xp_cmdshell ‘mkdir D:\bank‘,no_output
    if exists(select * from sysdatabases where name = ‘bankDB‘)
        drop database bankDB
    go

    create database bankDB
    on primary
    (
        name = ‘bankDB‘,
        filename = ‘D:\bank\bankDB.mdf‘,
        size = 5MB,
        maxsize = 10MB,
        filegrowth = 15%
    )log on(
        name = ‘bankDB_log‘,
        filename = ‘D:\bank\bankDB_log.ldf‘,
        size = 5MB,
        filegrowth = 15%
    )

--调用储存过程查看文件夹信息
exec xp_cmdshell ‘dir D:\bank\‘

--========创建存储过程,查询Java Logic最近一次考试平均分以及未通过考试的学员名单=========
use MySchool
go

if exists(select * from sysobjects where name = ‘sp_getavgresult‘)
drop proc sp_getavgresult
go
--创建存储过程实现
create proc sp_getavgresult
    @returnnum int output, --返回未及格的人数
    @returnsum int output, --参加考试总人数
    @subjectName varchar(30), --添加科目
    @score int = 60 --添加输入参数(及格分数)
as
declare @subjectId int
declare @maxdate date
declare @avg int

--查询java logic课程的编号
select @subjectId = SubjectId from Subject where SubjectName = @subjectName

--查询java logic课程最近一次考试时间
select @maxdate = MAX(ExamDate) from Result where SubjectId = @subjectId

--查询java logic课程最近一次考试的平均分
select @avg = AVG(StudentResult) from Result where
    SubjectId = @subjectId and ExamDate = @maxdate
print ‘未通过考试的人员名单:=======================‘
--查询java logic课程最近一次考试未通过的学生名单
select studentName,studentResult from student s
inner join Result r on r.StudentNo = s.StudentNo
        where SubjectId = @subjectId
        and ExamDate = @maxdate
        and StudentResult < @score

--查询参加考试的总人数
select @returnsum = COUNT(*) from Result where ExamDate = @maxdate and SubjectId = @subjectId

--查询未及格的人数
select @returnnum = COUNT(*) from Result where ExamDate = @maxdate and SubjectId = @subjectId
                                  and StudentResult < @score

if(@avg > 70)
begin
    print ‘考试结果:优秀‘
end
else
begin
    print ‘考试结果:较差‘
end

go

--=======调用储存过程实现业务逻辑===========----

declare @sum int --参加考试总人数
declare @num int --未及格人数
declare @percent float(2) --及格百分比

--调用存储过程
exec sp_getavgresult @num output,@sum output,@subjectName = ‘java logic‘,@score = 60

print ‘=========================================‘
print ‘参加考试人数为:‘ + convert(varchar(30),@sum)
print ‘未及格人数为:‘ + convert(varchar(30),@num)

--计算及格率
set @percent = convert(float(2),(@sum - @num))/@sum * 100
print ‘及格百分比:‘ + convert(varchar(30),@percent) +‘%‘

--判断是否要调及格分数线
if(@percent > 50)
begin
    print ‘不需要调分数线。。。‘
end
else
begin
    print ‘需要降低分数线。。。‘
end
时间: 2024-07-28 18:35:05

SQL Server之存储过程的相关文章

SQL Server中存储过程 比 直接运行SQL语句慢的原因

问题是存储过程的Parameter sniffing 在很多的资料中都描述说SQLSERVER的存储过程较普通的SQL语句有以下优点: 1. 存储过程只在创造时进行编译即可,以后每次执行存储过程都不需再重新编译,而我们通常使用的SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度. 2. 经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用SP来封装数据库操作.当对数据库进行复杂操作时(如对多个表进行 Update,Insert,Query,Delete时),可将此复杂操作用

SQL Server创建存储过程(转载)

什么是存储过程? q       存储过程(procedure)类似于C语言中的函数 q       用来执行管理任务或应用复杂的业务规则 q       存储过程可以带参数,也可以返回结果 q       存储过程可以包含数据操纵语句.变量.逻辑 控制语句等 存储过程的优点 (1)执行速度快. 存储过程创建是就已经通过语法检查和性能优化,在执行时无需每次编译. 存储在数据库服务器,性能高. (2)允许模块化设计. 只需创建存储过程一次并将其存储在数据库中,以后即可在程序中调用该过程任意次.存储

SQL Server中存储过程比直接运行SQL语句慢的原因

原文:SQL Server中存储过程比直接运行SQL语句慢的原因 在很多的资料中都描述说SQLSERVER的存储过程较普通的SQL语句有以下优点: 1.       存储过程只在创造时进行编译即可,以后每次执行存储过程都不需再重新编译,而我们通常使用的SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度. 2.       经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用SP来封装数据库操作.当对数据库进行复杂操作时(如对多个表进行 Update,Insert,Query

SQL Server中的CLR编程——用.NET为SQL Server编写存储过程和函数

原文:SQL Server中的CLR编程--用.NET为SQL Server编写存储过程和函数 很早就知道可以用.NET为SQL Server2005及以上版本编写存储过程.触发器和存储过程的,不过之前开发的系统要么因为历史原因用的是SQL2000要么根本用不着在SQL Server中启用CLR,所以一直没有尝试.最近因为项目的原因,在这方面做了一个调研,现在在这里分享一下心得. 首先要说明的是要在SQL Server中启用CLR必须是在SQL Server2005及以上版本,其次在默认情况下是

在sql server中建存储过程,如果需要参数是一个可变集合怎么处理?

在sql server中建存储过程,如果需要参数是一个可变集合的处理 原存储过程,@objectIds 为可变参数,比如 110,98,99 ALTER PROC [dbo].[Proc_totalScore] @categoryKey int, @objectIds VARCHAR(MAX) AS BEGIN      SELECT c.Name,AVG(e.Score) Score FROM dbo.Sys_com_comment_main m      INNER JOIN dbo.sys

SQL SERVER 系统存储过程

Transact-SQL中的存储过程,非常类似于Java语言中的方法,它可以重复调用.当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句.这样就可以提高存储过程的性能. Ø 存储过程的概念 存储过程Procedure是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中,用户通过指定存储过程的名称并给出参数来执行. 存储过程中可以包含逻辑控制语句和数据操纵语句,它可以接受参数.输出参数.返回单个或多个结果集以及返回值. 由于存储过程在创建时即在数据库服务器上进

SQL Server 2014存储过程的备份和还原

Sql Server 2014存储过程备份和恢复... 1 1.      备份存储过程:... 1 2.      还原... 8 Sql Server 2014存储过程备份和恢复 1. 备份存储过程: 在数据库管理软件中先备份好存储过程 操作步骤:数据库->可编程性->存储过程 看到有几个存储过程,然后 选择生产脚本 选择下一步 还可以展开选择要备份的存储过程: 选择下一步,设置脚本编写选项:确定就好: 选择确定之后选择下一步 就开始备份存储过程了: 备份完成: 在磁盘上找到该存储过程的备

SQL Server 的存储过程

Transact-SQL中的存储过程,非常类似于Java语言中的方法,它可以重复调用.当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句.这样就可以提高存储过程的性能. Ø 存储过程的概念 存储过程Procedure是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中,用户通过指定存储过程的名称并给出参数来执行. 存储过程中可以包含逻辑控制语句和数据操纵语句,它可以接受参数.输出参数.返回单个或多个结果集以及返回值. 由于存储过程在创建时即在数据库服务器上进

查看SQL SERVER 加密存储过程,函数,触发器,视图

原文:查看SQL SERVER 加密存储过程,函数,触发器,视图 create  PROCEDURE sp_decrypt(@objectname varchar(50))ASbeginset nocount on--CSDN:j9988 copyright:2004.07.15 --V3.2 --破解字节不受限制,适用于SQLSERVER2000存储过程,函数,视图,触发器--修正上一版"视图触发器"不能正确解密错误--发现有错,请E_MAIL:[email protected]be

sql server系统存储过程大全

关键词:sql server系统存储过程,mssql系统存储过程 xp_cmdshell --*执行DOS各种命令,结果以文本行返回. xp_fixeddrives --*查询各磁盘/分区可用空间 xp_loginconfig --*报告SQL Server 实例在Windows 上运行时的登录安全配置 xp_logininfo --*返回有关Windows 认证登录的信息. xp_msver --*返回有关Microsoft SQL Server 的版本信息 xp_enumgroups