当前位置: 首页 > 编程笔记 >

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

拓拔君博
2023-03-14
本文向大家介绍SQL Server数据库中的存储过程介绍,包括了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数据库死锁的一个存储过程分享,包括了查询Sqlserver数据库死锁的一个存储过程分享的使用技巧和注意事项,需要的朋友参考一下 使用sqlserver作为数据库的应用系统,都避免不了有时候会产生死锁, 死锁出现以后,维护人员或者开发人员大多只会通过sp_who来查找死锁的进程,然后用sp_kill杀掉。利用sp_who_lock这个存储过程,可以很方便的知道哪个

  • 问题内容: 我有一张桌子,我需要在99%的时间内自动分配ID(其他1%似乎使用身份列来排除)。因此,我有一个存储过程来获取以下行中的下一个ID: `` 检查必须检查用户是否手动使用了ID并找到下一个未使用的ID。 当我依次调用它并返回1、2、3时,它可以正常工作。我需要做的是在多个进程同时调用此方法的情况下提供一些锁定。理想情况下,我只需要它专用于围绕此代码锁定last_auto_id表,以便第二

  • 本文向大家介绍oracle中存储函数与存储过程的区别介绍,包括了oracle中存储函数与存储过程的区别介绍的使用技巧和注意事项,需要的朋友参考一下 在oracle中,函数和存储过程是经常使用到的,他们的语法中有很多相似的地方,可是也有它们的不同之处,这段时间刚学完函数与存储过程,来给自己做一个总结: 一:存储过程:简单来说就是有名字的pl/sql块。 语法结构:      案例:         

  • 本文向大家介绍sqlserver中存储过程的递归调用示例,包括了sqlserver中存储过程的递归调用示例的使用技巧和注意事项,需要的朋友参考一下 递归式指代码片段调用自身的情况;危险之处在于:如果调用了自身一次,那么如何防止他反复地调用自身。也就是说提供递归检验来保证适当的时候可以跳出。 以阶层为例子说存储过程中递归的调用。 递归 当创建此存储过程时候,会遇见一条报告信息

  • 本文向大家介绍SQLServer用存储过程实现插入更新数据示例,包括了SQLServer用存储过程实现插入更新数据示例的使用技巧和注意事项,需要的朋友参考一下 实现 1)有相同的数据,直接返回(返回值:0); 2)有主键相同,但是数据不同的数据,进行更新处理(返回值:2); 3)没有数据,进行插入数据处理(返回值:1)。 【创建存储过程】 【执行方式】 返回值0,已经存在相同的 返回值1,插入成功