一、存储过程的概念
T-SQl和C语言一样 ,是一门结构化的语言。
什么是存储过程?
存储过程是SQL查询语句与控制流程语句的预编译集合,并以特定的名称保存在数据库中。存储过程也是数据库对象
分类:
系统存储过程: 以sp_或xp_打头
用户自定义 :以proc_打头
存储过程的优点:
执行速度快 效率高
模块式编程
减少网络流量
提高安全性
二、系统存储过程
SQl server 的系统存储过程保存在master数据库中,且所有命名的系统存储过程命名以“Sp_”开头。在master数据库中,
系统存储过程数量如下:
代码如下 复制代码
select count([name])as '系统存储数量' from sysobjects
where [name] like 'sp_%'
EXECUTE 用来表示调用存储过程,也可以缩写为EXEC,
调用存储的语法如下:
EXECUTE ‘存储过程名’ ‘参数’ ---如果没有参数则省略参数
常用的系统存储过程
EXEC sp_databases 列出当前系统中的数据库
EXEC sp_renamedb 'Northwind','Northwind1' 修改数据库的名称(单用户访问)
USE stuDB GO EXEC sp_tables 返回某个表列的信息
EXEC sp_columns 查看指定列的信息
EXEC sp_help 查看某个表的所有信息
EXEC sp_helpconstraint '表名' 查看某个表的约束
EXEC sp_helpdb '数据库名' 或 EXEC sp_helpdb 查看指定数据库或所有数据库信息
EXEC sp_helptext '对象名称' 显示数据库对象(存储过程、触发器、试图)的定义文本
EXEC sp_helpindex '表名' 查看指定表的索引信息
EXEC sp_renamedb '原名称','新名称' 更改数据库名称
EXEC sp_stored_proceres 列出当前环境可用的所有存储过程
除了系统存储过程,SQL Server 还提供以Xp_开头的扩展存储过程,如可以调用DOS命名的,XP_cmdshell 存储过程
用法如下:
代码如下 复制代码
EXEC Xp_cmdshell DOS 命名 [NO_OUTPUT]
NO_OUTPUT 为可选参数,表示是否输入存储过程返回的信息
三、用户自定义存储过程
1、语法
代码如下 复制代码
create procere 存储过程名
@参数1名 数据类型 [=默认值] [参数类型(输入/输出)]
... ...
@参数n名 数据类型 [=默认值] [参数类型(输入/输出)]
as
begin
sql语句
end;
go
参数类型分为输入参数和输出参数,默认为输入参数,使用OUTPUT表示输出参数。创建存储过程最好以proc开头
2、创建不带参数的存储过程
代码如下 复制代码
--判断存储过程是否存在
if object_id('proc_student','procere') is not null
drop procere proc_student
go
create procere proc_student
as
begin
select pcid as '电脑编号',
case pcuse
when 0 then '空闲'
when 1 then '忙碌'
end as '使用状态' from pc
end;
--调用存储过程
execute proc_student select * from pc
go
3、创建带输入参数的存储过程
语法:
代码如下 复制代码
create procere 存储过程名
@参数1名 数据类型 [=默认值]
....
@参数2名 数据类型[=默认值]
as
SQl与语句
...
go
--例如
--创建带输入参数的存储过程
代码如下 复制代码
if object_id('proc_stu','procere') is not null
drop procere proc_stu
go
create procere proc_stu
@pcuse int
as
begin
select pcid as '电脑编号',
case pcuse
when 0 then '空闲'
when 1 then '忙碌'
end as '使用状态' from pc where pcuse=@pcuse end;
--调用存储过程
execute proc_stu @pcuse=1
4、创建带输出参数的存储过程
代码如下 复制代码
--创建带输出参数的存储过程
if OBJECT_ID('proc_s','procere') is not null
drop procere proc_s
go
create procere proc_s
@pcid int,
@pcus int output
as
begin
select @pcus=pcuse from pc where pcid=@pcid end;
--调用存储过程
declare @pcus int execute proc_s 5,@pcus output
四、处理错误信息
当存储过程的语句十分复杂时,可以在存储过程中加入错误语言。SQL Server中可以使用RAISERROR 返回用户自定义的错误信息。
RAISERROR 语法如下:
RAISERROR (自定义的错误信息,错误的严重级别,错误状态)
自定义错误信息:表示输出信息:表示输出的错误提示文本
错误的严重级别:表示用户自定义错误的严重性级别。(0-18极)
错误的状态:表示自定义错误的状态,值的范围在1-127
㈡ 如何用T-SQL判断SQL语法是否正确
1. SET PARSEONLY选项(类似于SSMS的Cntrl+F5)
这个选项检查每个 Transact-SQL 语句的语法并返回任何错误消息,但不编译和执行语句。
下面我们创建一个存储过程用来检查输入的语句是否正确:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
create procere IsValidSQL(@sqlvarchar(max))as
begin
begin try
set @sql = 'set parseonly on;'+@sql;
exec(@sql);
end try
begin catch
return(1);
end catch;
return(0);
end;-- IsValidSQL
--这条语句语法没有问题,返回值为0
declare @retval int;
exec @retval=IsValidSQL'select back from t ';
select @retval
--因为from语句没有了,所以语法错误,返回值为1
declare @retval int;
exec @retval=IsValidSQL'select back f t ';
select @retval
因为SET PARSEONLY只是验证语法不会生产执行计划,可以通过下面的语句验证:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
SET PARSEONLY ON
go
select *from [HumanResources].[Department]
go
SET PARSEONLY off
--可以确定执行计划没有生产
SELECT '1' AS RoundNum,usecounts,cacheobjtype,objtype,text
FROM sys.dm_exec_cached_plans
CROSS APPLYsys.dm_exec_sql_text(plan_handle)
WHERE usecounts> 0AND
text like'%HumanResources%'
AND textNOTLIKE'%Check%'
ORDER BYusecountsDESC;
GO
注意:SET PARSEONLY 的设置是在分析时设置,而不是在执行或运行时设置。
在存储过程或触发器中不要使用 PARSEONLY。另外这个检查虽然可以证明语法没有问题,但是不会检查到对象不存在或者逻辑上的问题。
2. SET NOEXEC :编译每个查询,但不执行该查询。
当 SET NOEXEC 为 ON时,SQL Server将编译每一批处理 Transact-SQL语句但并不执行它们。当 SET NOEXEC设置为 OFF时,所有批处理将在编译后执行。
以下示例在有效查询、包含无效对象名称的查询以及包含不正确语法的查询中使用 NOEXEC。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
USE AdventureWorks2012;
GO
PRINT 'Valid query';
GO
-- SETNOEXEC to ON.
SET NOEXEC ON;
GO
-- Innerjoin.
SELECT e.BusinessEntityID,e.JobTitle,v.Name
FROM HumanResources.EmployeeASe
INNER JOIN Purchasing.PurchaseOrderHeaderASpoh
ON e.BusinessEntityID=poh.EmployeeID
INNER JOIN Purchasing.VendorASv
ON poh.VendorID=v.BusinessEntityID;
GO
-- SETNOEXEC to OFF.
SET NOEXEC OFF;
GO
PRINT 'Invalid object name';
GO
-- SETNOEXEC to ON.
SET NOEXEC ON;
GO
--Function name uses is a reserved keyword.
USE AdventureWorks2012;
GO
CREATE FUNCTION dbo.Values(@BusinessEntityIDint)
RETURNS TABLE
AS
RETURN (SELECTPurchaseOrderID,TotalDue
FROM dbo.PurchaseOrderHeader
WHERE VendorID = @BusinessEntityID);
-- SETNOEXEC to OFF.
SET NOEXEC OFF;
GO
PRINT 'Invalid syntax';
GO
-- SETNOEXEC to ON.
SET NOEXEC ON;
GO
--Built-in function incorrectly invoked.
SELECT *
FROM fn_helpcollations;
-- ResetSET NOEXEC to OFF.
SET NOEXEC OFF;
GO
这个选项会编译每个查询,比上面的选项检查的要多。我们可以用Try Catch选项判断,针对错误判断写出来的语句是否有问题。
㈢ mssql存储过程
MS
SQL基础教程:创建存储过程
在MS
SQL
Server
2000
中,创建一个存储过程有两种方法:一种是使用Transaction-SQL
命令Create
Procere,
另一种是使用图形化管理工具Enterprise
Manager。
用Transaction-
SQL
创建存储过程是一种较为快速的方法,但对于初学者,使用Enterprise
Manager
更易理解,更为简单。
当创建存储过程时,需要确定存储过程的三个组成部分;
所有的输入参数以及传给调用者的输出参数。
被执行的针对数据库的操作语句,包括调用其它存储过程的语句;
返回给调用者的状态值,以指明调用是成功还是失败。
12.2.1
使用Enterprise
Manager
创建存储过程
按照下述步骤用Enterprise
Manager
创建一个存储过程:
启动Enterprise
Manager,
登录到要使用的服务器。
选择要创建存储过程的数据库,在左窗格中单击Stored
Procere
文件夹,此时在右窗格中显示该数据库的所有存储过程,如图12-1
所示。
右击Stored
Procere
文件夹,在弹出菜单中选择New
Stored
Procere,
此时打开创建存储过程对话框,
输入存储过程正文。
单击Check
Syntax,
检查语法是否正确。
单击OK,
保存。
在右窗格中,右击该存储过程,在弹出菜单中选择All
task,
选择
ManagePermissions,
设置权限,
12.2.2
用CREATE
PROCEDURE
命令创建存储过程
通过运用Create
Procere
命令能够创建存储过程,在创建存储过程之前,应该考虑到以下几个方面:
在一个批处理中,Create
Procere
语句不能与其它SQL
语句合并在一起;
数据库所有者具有默认的创建存储过程的权限,它可把该权限传递给其它的用户;
存储过程作为数据库对象其命名必须符合命名规则;
只能在当前数据库中创建属于当前数据库的存储过程。
用Create
Procere
创建存储过程的语法规则如下:
CREATE
PROC
[
EDURE
]
procere_name
[
;
number
]
[
{
@parameter
data_type
}
[
VARYING
]
[
=
default
]
[
OUTPUT
]
]
[
,...n
]
[
WITH
{
RECOMPILE
|
ENCRYPTION
|
RECOMPILE
,
ENCRYPTION
}
]
[
FOR
REPLICATION
]
AS
sql_statement
[
...n
]
㈣ 在oracle中创建带参存储过程,传进去的参数可以为空么在存储过程中要如何判断传进来的值是否为空。
可以为空的,你在存储过程中可以
判断
if
param
is
null
then
语句;
来做判断这个参数param是空的
欢迎追问,满意请采纳