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
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 SQL Server数据库中的存储过程介绍
相关文章
- 使用 WGCLOUD 监测SQL Server数据库状态
- 通过Windows批处理命令执行SQL Server数据库备份
- SQL SERVER数据库的作业的脚本及存储过程
- SQL SERVER备份数据库存储过程的方法
- MySQL Error number: MY-013281; Symbol: ER_SERVER_RPL_ENCRYPTION_HEADER_ERROR; SQLSTATE: HY000 报错 故障修复 远程处理
- Mysql报错java.sql.SQLException:null,message from server:”Host ‘27,45,38,132’ is not allowed to connect详解数据库
- JSP连接Sql Server数据库示例详解编程语言
- SQL Server的死锁:如何解决?(死锁sqlserver)
- 从Oracle到SQL Server:数据库转换全攻略(oracle转mssql)
- 使用SQL Server 实现数据库管理(简述sqlserver)
- 淘宝数据库:如何使用SQL Server助力更精彩的用户体验(淘宝的sqlserver)
- SQL Server:让你拥抱数据库优势(可以用sqlserver)
- SQL Server软删除:避免数据误删除带来的后果(sqlserver软删除)
- 语言SQL Server中运行R语言:省时省力又高效(sqlserver跑R)
- 掌握好SQL Server赋权,打开数据库之门(sqlserver 赋权)
- SQL Server计数器:使用心得分享(sqlserver计数器)
- SQL Server自我阻碍、实现更大程度安全(sqlserver自阻塞)
- SQL Server约束——确保数据安全的护航者(sqlserver约束名)
- 函数SQL Server窗口函数:实现数据的高效分析(sqlserver窗口)
- SQL Server 社区版:免费的入门数据库管理解决方案(sqlserver社区版)
- 操作SQL Server学习:掌握换行操作(sqlserver的换行)
- SQL Server数据库中添加值的简单方法(sqlserver添加值)
- 件注册SQL Server组件,轻松实现数据库功能扩展(sqlserver注册组)
- SQL Server 构建数据库的概念性标注(sqlserver标注)
- 据库SQL Server数据库——实现信息存储与管理的利器(sqlserver数)
- 据库SQL Server:轻松搭建个性化小数据库(sqlserver 小数)
- SQL Server:领略小图标的精彩世界(sqlserver小图标)
- 本安装SQL Server官方版本,快速加速你的执行力(sqlserver官方版)
- 快速高效地将SQL Server安装转换为最新版(sqlserver安转)
- SQL Server:促进企业数据库发展的核心技术(sqlserver 含义)
- SQL Server压缩包实现大数据快速传输(sqlserver压缩包)
- SQL Server卡慢:如何解决优化问题?(sqlserver 卡慢)
- SQL Server 增添账号的技术实现(sqlserver加帐户)
- SQL Server 前一天的记忆(sqlserver前一天)
- SQL Server数据库:实现信息持久存储的数据库技术(sqlserver db)