SQL Server数据库中的存储过程介绍

 更新时间:2015年01月27日 09:03:05   投稿:junjie  
这篇文章主要介绍了SQL Server数据库中的存储过程介绍,本文讲解了什么是存储过程、存储过程语法、存储过程的一些使用实例等内容,需要的朋友可以参考下

什么是存储过程

如果你接触过其他的编程语言,那么就好理解了,存储过程就像是方法一样。

竟然他是方法那么他就有类似的方法名,方法要传递的变量和返回结果,所以存储过程有存储过程名有存储过程参数也有返回值。

存储过程的优点:   

存储过程的能力大大增强了SQL语言的功能和灵活性。

1.可保证数据的安全性和完整性。
2.通过存储过程可以使没有权限的用户在控制之下间接地存取数据库,从而保证数据的安全。
3.通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性。
4.在运行存储过程前,数据库已对其进行了语法和句法分析,并给出了优化执行方案。这种已经编译好的过程5.可极大地改善SQL语句的性能。
6.可以降低网络的通信量。
7.使体现企业规则的运算程序放入数据库服务器中,以便 集中控制。

存储过程可以分为系统存储过程、扩展存储过程和用户自定义的存储过程

系统存储过程

我们先来看一下系统存储过程,系统存储过程由系统定义,主要存放在MASTER数据库中,名称以"SP"开头或以"XP"开头。尽管这些系统存储过程在MASTER数据库中,

但我们在其他数据库还是可以调用系统存储过程。有一些系统存储过程会在创建新的数据库的时候被自动创建在当前数据库中。

常用系统存储过程有:

复制代码 代码如下:

exec sp_databases; --查看数据库
exec sp_tables;        --查看表
exec sp_columns student;--查看列
exec sp_helpIndex student;--查看索引
exec sp_helpConstraint student;--约束
exec sp_helptext 'sp_stored_procedures';--查看存储过程创建定义的语句
exec sp_stored_procedures;
exec sp_rename student, stuInfo;--更改表名
exec sp_renamedb myTempDB, myDB;--更改数据库名称
exec sp_defaultdb 'master', 'myDB';--更改登录名的默认数据库
exec sp_helpdb;--数据库帮助,查询数据库信息
exec sp_helpdb master;
exec sp_attach_db --附加数据库
exec sp_detach_db --分离数据库

存储过程语法:

在创建一个存储过程前,先来说一下存储过程的命名,看到好几篇讲存储过程的文章都喜欢在创建存储过程的时候加一个前缀,养成在存储过程名前加前缀的习惯很重要,虽然这只是一件很小的事情,但是往往小细节决定大成败。看到有的人喜欢这样加前缀,例如proc_名字。也看到这加样前缀usp_名字。前一种proc是procedure的简写,后一种sup意思是user procedure。我比较喜欢第一种,那么下面所有的存储过程名都以第一种来写。至于名字的写法采用骆驼命名法。

创建存储过程的语法如下:

复制代码 代码如下:

CREATE PROC[EDURE] 存储过程名

@参数1 [数据类型]=[默认值] [OUTPUT]

@参数2 [数据类型]=[默认值] [OUTPUT]

AS

SQL语句

EXEC 过程名[参数]

使用存储过程实例:

1.不带参数

复制代码 代码如下:

create procedure proc_select_officeinfo--(存储过程名)
as select Id,Name from Office_Info--(sql语句)

exec proc_select_officeinfo--(调用存储过程)


2.带输入参数
复制代码 代码如下:

create procedure procedure_proc_GetoffinfoById --(存储过程名)
@Id int--(参数名 参数类型)
as select Name from dbo.Office_Info where Id=@Id--(sql语句)

exec procedure_proc_GetoffinfoById 2--(存储过程名称之后,空格加上参数,多个参数中间以逗号分隔)

注:参数赋值是,第一个参数可以不写参数名称,后面传入参数,需要明确传入的是哪个参数名称

3.带输入输出参数

复制代码 代码如下:

create procedure proc_office_info--(存储过程名)
@Id int,@Name varchar(20) output--(参数名 参数类型)传出参数要加上output
as
begin
select @Name=Name from dbo.Office_Info where Id=@Id --(sql语句)
end
declare @houseName varchar(20) --声明一个变量,获取存储过程传出来的值
exec proc_office_info--(存储过程名)
4,@houseName output--(传说参数要加output 这边如果用@变量 = OUTPUT会报错,所以换一种写法)
select @houseName--(显示值)

4.带返回值的

复制代码 代码如下:

create procedure proc_office_info--(存储过程名)
@Id int--(参数名 参数类型)
as
begin
if(select Name from dbo.Office_Info where Id=@Id)=null --(sql语句)
begin
return -1
end
else
begin
return 1
end
end

declare @house varchar(20) --声明一个变量,获取存储过程传出来的值
exec @house=proc_office_info 2 --(调用存储过程,用变量接收返回值)
--注:带返回值的存储过程只能为int类型的返回值
print @house

相关文章

  • SQLServer 优化SQL语句 in 和not in的替代方案

    SQLServer 优化SQL语句 in 和not in的替代方案

    用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格。
    2010-04-04
  • SQL Server UPDATE语句的用法详解

    SQL Server UPDATE语句的用法详解

    SQL Server中的数据改动是免不了的,使用UPDATE语句就可以实现我们对数据库数据的更新修改操作,下面就让我们来了解一下UPDATE语句的用法
    2014-08-08
  • SQL Server事务日志文件过大(已满)的解决方案

    SQL Server事务日志文件过大(已满)的解决方案

    随着数据库使用时间增长,日志文件也在不停的增大,这篇文章主要给大家介绍了关于SQL Server事务日志文件过大(已满)的解决方案,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • SQL函数substr使用简介

    SQL函数substr使用简介

    文章是介绍了sql中的substr()字符串截取函数的用法,十分的简单实用,有需要的同学可以参考一下。
    2015-05-05
  • SQL Server数据库的修复SQL语句

    SQL Server数据库的修复SQL语句

    使用数据库的过程中,由于断电或其他原因,有可能导致数据库出现一些小错误,比如检索某些表特别慢,查询不到符合条件的数据等。
    2008-11-11
  • 详解Sql基础语法

    详解Sql基础语法

    这篇文章主要介绍了详解Sql基础语法的相关资料,需要的朋友可以参考下
    2016-01-01
  • SQL Server的触发器你了解多少

    SQL Server的触发器你了解多少

    这篇文章主要为大家详细介绍了SQL Server触发器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • SQL Server 高性能写入的一些经验总结

    SQL Server 高性能写入的一些经验总结

    本篇博文将针对一些常用的数据库性能调休方法进行介绍,而且,为了编写高效的SQL代码,我们需要掌握一些基本代码优化的技巧,所以,我们将从一些基本优化技巧进行介绍
    2012-08-08
  • SQL判断语句用法和多表查询

    SQL判断语句用法和多表查询

    这篇文章主要介绍了SQL判断语句用法和多表查询的相关资料,需要的朋友可以参考下
    2016-12-12
  • vs10安装之后一些列问题

    vs10安装之后一些列问题

    sql05不能用了,数据库又没个08怎么办呢 这时候不用卸载vs10 和sql08、05,只需要安装一个sql08就行了
    2011-12-12

最新评论