概念#存储过程(Stored Procedure):已预编译为一个可执行过程的一个或多个SQL语句。 创建存储过程语法#CREATE proc | procedure procedure_name [{@参数数据类型} [=默认值] [output],
{@参数数据类型} [=默认值] [output],
....
]as
SQL_statements 存储过程与SQL语句对比#优势: 1、提高性能 劣势: 1、存储过程需要专门的数据库开发人员进行维护,但实际情况是,往往由程序开发员人员兼职 2、设计逻辑变更,修改存储过程没有SQL灵活 为什么在实际应用中,存储过程用到相对较少呢?#在通常的项目研发中,用存储过程却相对较少,这是为什么呢? 存储过程与SQL语句如何抉择?#基于实际应用的经验,给予如下建议: 1、在一些高效率或者规范性要求比较高的项目,建议采用存储过程 存储过程的具体应用#一、基础查询 1、创建不带参数的存储过程 例子:查询学生总数 --查询存储过程IF OBJECT_ID (N'PROC_SELECT_STUDENTS_COUNT', N'P') IS NOT NULL DROP procedure PROC_SELECT_STUDENTS_COUNT;GOCREATE procedure PROC_SELECT_STUDENTS_COUNTAS SELECT COUNT(ID) FROM StudentsGO 执行: EXEC PROC_SELECT_STUDENTS_COUNT 2、带参数的存储过程 --查询存储过程,根据城市查询总数IF OBJECT_ID (N'PROC_SELECT_STUDENTS_BY_CITY_COUNT', N'P') IS NOT NULL DROP procedure PROC_SELECT_STUDENTS_BY_CITY_COUNT;GOCREATE procedure PROC_SELECT_STUDENTS_BY_CITY_COUNT(@city nvarchar(50))AS SELECT COUNT(ID) FROM Students WHERE City=@cityGO 执行语句: EXEC PROC_SELECT_STUDENTS_BY_CITY_COUNT N'Beijing' 3、带有通配符 通配符,在参数值赋值时,加上相应的通配符 --3、查询姓氏为李的学生信息,含通配符IF OBJECT_ID (N'PROC_SELECT_STUDENTS_BY_SURNNAME', N'P') IS NOT NULL DROP procedure PROC_SELECT_STUDENTS_BY_SURNNAME;GOCREATE procedure PROC_SELECT_STUDENTS_BY_SURNNAME @surnName nvarchar(20)='李%' --默认值AS SELECT ID,Name,Age FROM Students WHERE Name like @surnNameGO 执行: EXEC PROC_SELECT_STUDENTS_BY_SURNNAMEEXEC PROC_SELECT_STUDENTS_BY_SURNNAME N'李%'EXEC PROC_SELECT_STUDENTS_BY_SURNNAME N'%李%' 4、带有输出参数 --根据姓名查询的学生信息,返回学生的城市及年龄IF OBJECT_ID (N'PROC_SELECT_STUDENTS_BY_NAME', N'P') IS NOT NULL DROP procedure PROC_SELECT_STUDENTS_BY_NAME;GOCREATE procedure PROC_SELECT_STUDENTS_BY_NAME @name nvarchar(50), --输入参数 @city nvarchar(20) out, --输出参数 @age int output --输入输出参数AS SELECT @city=City,@age=Age FROM Students WHERE Name=@name AND Age=@ageGO 执行: --执行declare @name nvarchar(50), @city nvarchar(20), @age int;set @name = N'李明';set @age = 20;exec PROC_SELECT_STUDENTS_BY_NAME @name,@city out, @age output;select @city, @age; 二、使用存储过程进行增删改 1、新增 新增学生信息 --1、存储过程:新增学生信息IF OBJECT_ID (N'PROC_INSERT_STUDENT', N'P') IS NOT NULL DROP procedure PROC_INSERT_STUDENT;GOCREATE procedure PROC_INSERT_STUDENT @id int, @name nvarchar(20), @age int, @city nvarchar(20)AS INSERT INTO Students(ID,Name,Age,City) VALUES(@id,@name,@age,@city)GO 执行: EXEC PROC_INSERT_STUDENT 1001,N'张三',19,'ShangHai' 2、修改 根据学生ID,更新学生信息 IF OBJECT_ID (N'PROC_UPDATE_STUDENT', N'P') IS NOT NULL DROP procedure PROC_UPDATE_STUDENT;GOCREATE procedure PROC_UPDATE_STUDENT @id int, @name nvarchar(20), @age int, @city nvarchar(20)AS UPDATE Students SET Name=@name,Age=@age,City=@city WHERE ID=@idGO 执行: EXEC PROC_UPDATE_STUDENT 1001,N'张思',20,'ShangHai' 3、删除 根据ID,删除某学生记录 --3、存储过程:删除学生信息IF OBJECT_ID (N'PROC_DELETE_STUDENT_BY_ID', N'P') IS NOT NULL DROP procedure PROC_DELETE_STUDENT_BY_ID;GOCREATE procedure PROC_DELETE_STUDENT_BY_ID @id intAS DELETE FROM Students WHERE ID=@idGO 执行: EXEC PROC_DELETE_STUDENT_BY_ID 1001 三、存储过程实现分页查询 1、使用row_number函数分页 --分页查询IF OBJECT_ID (N'PROC_SELECT_BY_PAGE', N'P') IS NOT NULL DROP procedure PROC_SELECT_BY_PAGE;GOCREATE procedure PROC_SELECT_BY_PAGE @startIndex int, @endIndex intAS SELECT * FROM (SELECT ID,Name,Age,City,ROW_NUMBER() OVER(ORDER BY ID DESC) AS RowNumber FROM Students) AS Temp WHERE Temp.RowNumber BETWEEN @startIndex AND @endIndexGO 执行: EXEC PROC_SELECT_BY_PAGE 1,10 2、使用传统的top分页 --使用TOP分页IF OBJECT_ID (N'PROC_SELECT_BY_PAGE_WITH_TOP', N'P') IS NOT NULL DROP procedure PROC_SELECT_BY_PAGE_WITH_TOP;GOCREATE procedure PROC_SELECT_BY_PAGE_WITH_TOP @pageIndex int, @pageSize intAS SELECT TOP(@pageSize) * FROM Students WHERE ID >=(SELECT MAX(ID) FROM (SELECT TOP(@pageSize*(@pageIndex-1) + 1) ID FROM Students ORDER BY ID) AS Temp) GO 执行: EXEC PROC_SELECT_BY_PAGE_WITH_TOP 1,2 四、其他功能: 1、存储过程,每次执行都进行重新编译 --1、存储过程,重复编译IF OBJECT_ID (N'PROC_SELECT_STUDENTS_WITH_RECOMPILE', N'P') IS NOT NULL DROP procedure PROC_SELECT_STUDENTS_WITH_RECOMPILE;GOCREATE procedure PROC_SELECT_STUDENTS_WITH_RECOMPILEwith recompile --重复编译AS SELECT * FROM StudentsGO 2、对存储过程进行加密 加密后,不能查看和修改源脚本 --2、查询存储过程,进行加密IF OBJECT_ID (N'PROC_SELECT_STUDENTS_WITH_ENCRYPTION', N'P') IS NOT NULL DROP procedure PROC_SELECT_STUDENTS_WITH_ENCRYPTION;GOCREATE procedure PROC_SELECT_STUDENTS_WITH_ENCRYPTIONwith encryption --加密AS SELECT * FROM StudentsGO 执行: EXEC PROC_SELECT_STUDENTS_WITH_ENCRYPTION 效果,无法查看脚本或者导出创建脚本 作者介绍:半路学IT,做开发3年,先就职在一家共享单车公司,做后台开发! |
|