存储过程的学习
存储过程的概念
存储过程是什么?
- 存储过程是由一个或多个Transact-SQL 语句构成的一个组。
存储过程可以:
- 接受输入参数并以输出参数的格式向调用程序返回多个值。
- 包含用于在数据库中执行操作的编程语句,这包括调用其他过程(在存储过程中调用其它的存储过程)。
- 向调用程序返回状态值,以指明成功或失败(以及失败的原因)。
使用存储过程的好处:
- 减少了服务器/客户端网络流量。
- 更强的安全性。
- 减少代码的重复使用。
- 更容易维护 。
- 改进的性能。
存储过程的类型:
- 用户定义的存储过程:由用户自己创建的存储过程。
- 临时存储过程:也是由用户创建的存储过程,存储在 tempdb 中,名字以#开头,仅在创建该过程的会话中存在,会话结束,临时存储过程即被删除(类似临时表)。
- 系统存储过程:系统过程是 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='高等数学'