存储过程是为了完成特定功能的SQL语句集合,存储在数据库中,用户通过指定存储过程的名称并给出参数来执行。
优点:
1、方便修改。
因为存储过程是存储在数据库中的,如果需要涉及到修改SQL语句,那么数据库专业人员只需要去修改数据库中的存储过程就可以,对程序毫无影响,如果用SQL语句的话,SQL语句是写在程序中的,如果涉及到修改SQL语句,那么就需要去修改源程序。
2、存储过程比SQL语句执行更快速:
存储过程是为了完成特定功能的SQL语句的集合,如果为了完成某一功能,使用了大量的SQL语句,那么执行存储过程只执行一次就可以,而SQL语句呢,则是需要执行多个。就类似于c语言中的自定义函数,甚至比自定义函数还要灵活很多.
1、创建简单存储过程
(1)创建一个名为stu_pr的存储过程,该存储过程能查询出o51班学生的所有资料,包括学生的基本信息、学生的选课信息(含未选课同学的信息)。要求在创建存储过程前请判断该存储过程是否已创建,若已创建则先删除,并给出“已删除! p信息,否则就给出“不存在,可创建! ”的信息。
先进行判断是否存在如:
if exists (select * from sysobjects where name='stu_pr' and type='P')begin
drop procedure stu_pr print '已删除! '
end
else
print '不存在,可创建! '
创建语句如:
create procedure stu_pr
as
select distinct * from student s
left join sc on s.sno=sc.sno
left join course c on c.Cno=sc.Cno where classno='051'
使用刚刚创建的存储过程:
exec stu_pr
。