sql存储过程详解,sql存储过程
1,不带参数的存储过程
2,带输入参数的存储过程
3,带输入和输出参数的存储过程
4,带返回值的存储过程
不带参数的存储过程
例如,以下存储过程返回Employees表中所有职员的记录。
存储过程代码:
USE TSQLFundamentals2008; GO IF OBJECT_ID('usp_ProcDemoNoParam','P') IS NOT NULL DROP PROC usp_ProcDemoNoParam; GO -- 1,不带参数 CREATE PROC usp_ProcDemoNoParam AS BEGIN SELECT * FROM HR.Employees; END GO
调用代码:
USE TSQLFundamentals2008; GO -- 1,不带参数存储过程的调用 EXEC usp_ProcDemoNoParam;
结果:
可以看到,共返回了9条记录。
带输入参数的存储过程
例如,该存储过程接受输入参数@empid,然后返回这个职员的信息。
创建存储过程代码:
IF OBJECT_ID('usp_ProcDemoWithInputParam','P') IS NOT NULL DROP PROC usp_ProcDemoWithInputParam; GO -- 2,带输入参数 CREATE PROC usp_ProcDemoWithInputParam @empid AS INT AS BEGIN SELECT * FROM HR.Employees WHERE empid= @empid; END GO
调用:
-- 2,带输入参数存储过程调用 EXEC usp_ProcDemoWithInputParam @empid=5;
结果:
带输入和输出参数的存储过程
例如,以下存储过程接受@empid即职员ID作为输入参数,然后返回该职员的信息,同时返回代码受影响行数作为输出参数。
创建存储过程代码:
IF OBJECT_ID('usp_ProcDemoWithInputOutputParam','P') IS NOT NULL DROP PROC usp_ProcDemoWithInputOutputParam; GO -- 3,带输入和输出参数 CREATE PROC usp_ProcDemoWithInputOutputParam @empid AS INT, @NumRowsAffected AS INT OUTPUT AS BEGIN SELECT * FROM HR.Employees WHERE empid= @empid; SET @NumRowsAffected= @@ROWCOUNT; -- 赋值,也可以使用select赋值 END GO
调用:
-- 3,带输入和输出参数存储过程的调用 DECLARE @nums AS INT; EXEC usp_ProcDemoWithInputOutputParam @empid=5,@NumRowsAffected= @nums OUTPUT; SELECT @nums AS nums;
结果:
带返回值的存储过程
例如,以下存储过程接受@empid即职员ID作为输入参数,然后判断职员表中是否存在该职员的记录,如果存在则返回1,否则返回0.
创建存储过程代码:
IF OBJECT_ID('usp_ProcDemoWithReturnValue','P') IS NOT NULL DROP PROC usp_ProcDemoWithReturnValue; GO -- 4,带返回值 CREATE PROC usp_ProcDemoWithReturnValue @empid AS INT AS BEGIN IF EXISTS (SELECT * FROM HR.Employees WHERE empid=@empid) RETURN 1 ELSE RETURN 0; -- 也可以声明一个变量,然后返回这个变量 END GO
调用:
-- 4,带返回值存储过程的调用 DECLARE @status AS INT=0; --给默认值为0 EXEC @status= dbo.usp_ProcDemoWithReturnValue @empid = 5 -- int SELECT @status AS thestatus;
结果:
存储过程的好处觉得就是对数据的操作特别地快,
其实那些sql语句已经在数据库中编译过了。
在数据库中的那些语句就是你要用的sql语句。而那些你要查询是放进去的变量,被一些相当于占位副之类的东西,先占位了。你只要把参数传进去,告诉他执行那条存储过程的语句就可以了。
存储过程的好处:1.由于数据库执行动作时,是先编译后执行的。然而存储过程是一个编译过的代码块,所以执行效率要比T-SQL语句高。2.一个存储过程在程序在网络中交互时可以替代大堆的T-SQL语句,所以也能降低网络的通信量,提高通信速率。3.通过存储过程能够使没有权限的用户在控制之下间接地存取数据库,从而确保数据的安全。小结:总之存储过程是好东西,在做项目时属于必备利器,下面介绍存储过程的基本语法。存储过程的语法和参数讲解存储过程的一些基本语法:--------------创建存储过程----------------- CREATE PROC [ EDURE ] procedure_name [ ; number ] [ { @parameter data_type } [ VARYING ] [ = default ] [ OUTPUT ] ] [ ,...n ] [ WITH { RECOMPILE | ENCRYPTION | RECOMPILE , ENCRYPTION } ] [ FOR REPLICATION ] AS sql_statement [ ...n ] --------------调用存储过程----------------- EXECUTE Procedure_name '' --存储过程如果有参数,后面加参数格式为:@参数名=value,也可直接为参数值value --------------删除存储过程----------------- drop procedure procedure_name --在存储过程中能调用另外一个存储过程,而不能删除另外一个存储过程