[schema_name]:代表的是存储历程所属的架构的称号
比方:
CreateSchemayangyang8848
Go
CreateProcyangyang8848.AllGoods
AsSelect*FromMaster_Goods
Go
实行:ExecAllGoods产生毛病。
实行:Execyangyang8848.AllGoods准确实行。
[;Number]:用于对同名历程举行分组的可选整数。利用一个DROPPROCEDURE语句可将这些分组历程一同删除。
比方:
CreateProcS1;1
AS
Select*FromMaster_Goods
Go
CreateProcS1;2
As
Select*FromMaster_Location
Go
创立终了了两个存储历程。它们在统一个组S1里,假如实行ExecS1则存储历程默许实行ExecS1;1。假如我们想失掉一切据点信息则必要实行ExecS1;2。当我们要删除存储历程的时分,只能实行DropExecS1则该组内一切的存储历程被删除。
[@parameter]:存储过程当中的参数,除非将参数界说的时分有默许值大概将参数设置为即是另外一个参数,不然用户必需在挪用存储历程的时分为参数赋值。
存储历程最多有2100个参数。
比方:
CreateProcyangyang8848.OneGoods
@GoodsCodevarchar(10)
As
Select*FromMaster_GoodsWhereGoodsCode=@GoodsCode
Go
挪用的代码:
Declare@Codevarchar(10)
Set@Code=0004
Execyangyang8848.OneGoods@Code
在参数的后边到场Output标明该参数为输入参数。
CreateProcyangyang8848.OneGoods
@GoodsCode2varchar(10)output,@GoodsCodevarchar(10)=0011
As
Select*FromMaster_GoodsWhereGoodsCode=@GoodsCode
Set@GoodsCode2=0005
Go
挪用办法:
Declare@VV2varchar(10)
Execyangyang8848.OneGoods@Codeout
注重:假如存储历程的两个参数一个有默许值一个没有,那末我们要把有默许值得放在后边,否则会出成绩哦~~
仔细的伴侣,大概看到上边的语句有一些分歧,好比,存储历程用的是output,而挪用语句用的是out。我要告知您,二者是一样的。
这个说一个十分好用的函数OBJECT_ID:前往架构局限内工具的数据库工具标识号。
比方:我们创立存储历程时,能够以下写代码
IfObject_ID(yangyang8848.OneGoods)IsNotNull
DropProcyangyang8848.OneGoods
Go
CreateProcyangyang8848.OneGoods
@GoodsCode2varchar(10)out,@GoodsCodevarchar(10)=0011
As
Select*FromMaster_GoodsWhereGoodsCode=@GoodsCode
Set@GoodsCode2=0005
Go
针关于上边的这个存储历程,我们挪用以下SQL查询
SelectdefinitionFromsys.sql_modules
Whereobject_id=Object_ID(yangyang8848.OneGoods);
我们是能够查到了局的。
但是假如我们对该存储历程到场[ENCRYPTION]那末你将没法看就任何了局
IfObject_ID(yangyang8848.OneGoods)IsNotNull
DropProcyangyang8848.OneGoods
Go
CreateProcyangyang8848.OneGoods
@GoodsCode2varchar(10)out,@GoodsCodevarchar(10)=0011
WithEncryption
As
Select*FromMaster_GoodsWhereGoodsCode=@GoodsCode
Set@GoodsCode2=0005
Go
然后我们查询sys.sql_modules目次视图,将前往给你Null。
然后我们实行以下SQL:Execsp_helptextyangyang8848.OneGoods
你将失掉以下了局:Thetextforobjectyangyang8848.OneGoodsisencrypted.
说到这里你应当分明了,参数[ENCRYPTION]:是一种加密的功效,将CREATEPROCEDURE语句的原始文本转换为含混格局。含混代码的输入在SQLServer2005的任何目次视图中都不克不及间接显现。对体系表或数据库文件没有会见权限的用户不克不及检索含混文本。可是,可经由过程DAC端口会见体系表的特权用户或间接会见数据库文件的特权用户可以使用此文本。别的,可以向服务器历程附加调试器的用户可在运转时从内存中检索已解密的历程。
前两天写了一篇关于游标的先容文章,下边写一个例子,将游标与存储历程一同利用上:
IfObject_ID(dbo.GetMasterGoods)IsNotNull
DropProcdbo.GetMasterGoods
Go
CreateProcGetMasterGoods
@MyCursorCursorVaryingOutput
WithEncryption
As
Set@MyCursor=Cursor
For
SelectGoodsCode,GoodsNameFromMaster_Goods
Open@MyCursor
Go
--下边创建别的一个存储历程,用于遍历游标输入了局
CreateProcGetAllGoodsIDAndName
As
Declare@GoodsCodevarchar(18)
Declare@GoodsNamenvarchar(20)
Declare@MasterGoodsCursorCursor
ExecGetMasterGoods@MasterGoodsCursorout
FetchNextFrom@MasterGoodsCursor
InTo@GoodsCode,@GoodsName
While(@@Fetch_Status=0)
Begin
Begin
Print@GoodsCode+:+@GoodsName
End
FetchNextFrom@MasterGoodsCursor
InTo@GoodsCode,@GoodsName
End
Close@MasterGoodsCursor
Deallocate@MasterGoodsCursor
Go
最初实行ExecGetAllGoodsIDAndName了局为以下内容
0003:品0003
0004:品0004
0005:123123
0006:品0006
0007:品0007
0008:品0008
0009:品0009
0010:品0010
0011:品0011
0012:品0012
0013:品0013
0014:品0014