数据库学习之——存储过程

本文深入探讨了存储过程的概念,介绍了如何创建、修改和删除存储过程,包括带参数、默认值、输出参数、表值参数及变量的存储过程。此外,还讨论了异常处理、加密和优化存储过程的方法,提供了实用的示例来帮助理解。
摘要由CSDN通过智能技术生成

存储过程的概念

存储过程是什么?

  • 存储过程是由一个或多个Transact-SQL 语句构成的一个组。

存储过程可以:

  1. 接受输入参数并以输出参数的格式向调用程序返回多个值。
  2. 包含用于在数据库中执行操作的编程语句,这包括调用其他过程(在存储过程中调用其它的存储过程)。
  3. 向调用程序返回状态值,以指明成功或失败(以及失败的原因)。

使用存储过程的好处:

  1. 减少了服务器/客户端网络流量。
  2. 更强的安全性。
  3. 减少代码的重复使用。
  4. 更容易维护 。
  5. 改进的性能。

存储过程的类型:

  1. 用户定义的存储过程:由用户自己创建的存储过程。
  2. 临时存储过程:也是由用户创建的存储过程,存储在 tempdb 中,名字以#开头,仅在创建该过程的会话中存在,会话结束,临时存储过程即被删除(类似临时表)。
  3. 系统存储过程:系统过程是 SQL Server 附带的。系统过程以前缀 sp_ 开头。帮助用户使用、管理数据库。

创建简单的存储过程

创建存储过程:

IF OBJECT_ID('P_STUDENT','P') IS NOT NULL   -- 判断该存储过程是否存在
DROP PROCEDURE P_STUDENT

CREATE PROCEDURE P_STUDENT	-- 创建存储过程
AS
BEGIN
	SELECT NAME,ADDRESS
	FROM STUDENT
END;
-------------------------------------------------------------------------------
EXEC P_STUDENT		--简写执行
EXECUTE P_STUDENT	--全称执行

修改存储过程

ALTER PROCEDURE P_STUDENT
AS
BEGIN
	SELECT NAME,ADDRESS
	FROM STUDENT
	WHERE AGE>13
END;

删除存储过程:

DROP PROCEDURE P_STUDENT

示例二:
创建存储过程并执行:

CREATE PROCEDURE [dbo].[P_COURSE1]
AS
BEGIN
	INSERT INTO COURSE1
	SELECT * FROM COURSE
END;
-------------------------------------------------------------------------------
ALTER PROCEDURE [dbo].[P_COURSE1] --执行

示例三
修改存储过程:

ALTER PROCEDURE [dbo].[P_COURSE1]
AS
BEGIN

	INSERT INTO COURSE1
	SELECT * FROM COURSE

	UPDATE COURSE1
	SET KCMC='高等数学'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值