sql 存储过程中 如何使用declare 有的存储过程声明了,有的没有声明。请回答的详细点。。谢谢
答案:4 悬赏:0 手机版
解决时间 2021-02-19 22:41
- 提问者网友:暗中人
- 2021-02-19 00:06
sql 存储过程中 如何使用declare 有的存储过程声明了,有的没有声明。请回答的详细点。。谢谢
最佳答案
- 五星知识达人网友:时间的尘埃
- 2021-02-19 01:08
如果你把存储过程看作是批处理语句就好理解多了!
存储过程只不过是一个带着名称的SQL批处理语句,如果在整个过程中需要变量时就是可以声明,但该变量声明后只能存活在批处理(存储过程)的运行中,运行完毕后就会消失,这种声明的格式就是
declare 变量名 类型
其中变量名为了与数据库中的列名相互区别,所以变量名有一个前置@符号,比如说
declare @count int
就是将变量@count声明为int类型的,以后可以使用变量@count作为整型变量使用。在这里可能有一些误解,有人认为@count是变量名,也有人认为count是变量名,而@只是一个符号,其实不管那一种理解对于声明变量上来说是不影响的,事实上应该来说@count被称为变量名较为合适些。
刚才说过,该变量声明后只存活于批处理或是存储过程的运行中而已,也就是说是一个局部变量,其实在SQL中还有一种变量是全局变量的,他们以@@开头,但目前的SQL中还不允许客户自己的声明全局变量,只是系统中存的。比如查询系统版本,就可以使用select @@version的方式进行查看的。因为不能够声明,所以不与declare一块使用的情况。
其实在SQL中将变量一词演译的非常深,还有一类变量就是表名,列名,存储过程等名称,这些名称其实也算是数据库的全局变量的,只要表存在,那么表名一定会存在于master数据库中的一个表中,列名也是一样,这一类的变量有一个特殊,都是已经存在的boject的,所以不须要进行声明,等于是建库或表时进行了声明,然后就可以了使用了,这种情况下的变量前边是没有@符号提示的。
所以一般情况下,我们只称@前置的为变量,没有前置的为数据库相关变量,而@@是系统变量不须声明。但只要是在使用@自定义的变量时,就必须选进行声明,而其他的则不须要。追问CREATE PROCEDURE jiafa
@a VARCHAr(2000)
AS
BEGIN
EXECute('select ' + @a)
END
GO
EXEC jiafa '22+33'
这个为什么不声明呢, 我就是想知道什么情况下用 什么情况下不用声明追答看到你这样问我哭了,本来我还想打给你什么是传入的形参呢!
正常的程序中有这样的:(javascript为例)
function sfuction(obj)
{
objXXXXXXX;
}
试问一下其中的obj进行了赋值或是声明了吗?
其中@a VARCHAr(2000)表示为存储过程传入的形参,也就是说,这个参数是用来接收的,是形参显然不用定义了!如果这样写你可能看的更新楚些:
create proc procname
( @intvalue int,
@stringtemp nvarchar(100)
)
as
begin
XXXXXX
end
其中括号中的内容就是形参,也就是说传入值让这个参数进行接收,而此时还没有任何的执行,就必须先让这个参数接收,这样的就是形参,不是自定义的变量!只是表示要传入的值而已,显然这样的值是不可能进行定义的!而在begin段中可以直接进行处理的!
所以形参不能算是自定义的参数!他只表示传入的第一个值按在处理中按参数@a进行引用,该类型必须为Nvarchar(2000)而已。
所以注意一下形参是不须也是不能定义的!
存储过程只不过是一个带着名称的SQL批处理语句,如果在整个过程中需要变量时就是可以声明,但该变量声明后只能存活在批处理(存储过程)的运行中,运行完毕后就会消失,这种声明的格式就是
declare 变量名 类型
其中变量名为了与数据库中的列名相互区别,所以变量名有一个前置@符号,比如说
declare @count int
就是将变量@count声明为int类型的,以后可以使用变量@count作为整型变量使用。在这里可能有一些误解,有人认为@count是变量名,也有人认为count是变量名,而@只是一个符号,其实不管那一种理解对于声明变量上来说是不影响的,事实上应该来说@count被称为变量名较为合适些。
刚才说过,该变量声明后只存活于批处理或是存储过程的运行中而已,也就是说是一个局部变量,其实在SQL中还有一种变量是全局变量的,他们以@@开头,但目前的SQL中还不允许客户自己的声明全局变量,只是系统中存的。比如查询系统版本,就可以使用select @@version的方式进行查看的。因为不能够声明,所以不与declare一块使用的情况。
其实在SQL中将变量一词演译的非常深,还有一类变量就是表名,列名,存储过程等名称,这些名称其实也算是数据库的全局变量的,只要表存在,那么表名一定会存在于master数据库中的一个表中,列名也是一样,这一类的变量有一个特殊,都是已经存在的boject的,所以不须要进行声明,等于是建库或表时进行了声明,然后就可以了使用了,这种情况下的变量前边是没有@符号提示的。
所以一般情况下,我们只称@前置的为变量,没有前置的为数据库相关变量,而@@是系统变量不须声明。但只要是在使用@自定义的变量时,就必须选进行声明,而其他的则不须要。追问CREATE PROCEDURE jiafa
@a VARCHAr(2000)
AS
BEGIN
EXECute('select ' + @a)
END
GO
EXEC jiafa '22+33'
这个为什么不声明呢, 我就是想知道什么情况下用 什么情况下不用声明追答看到你这样问我哭了,本来我还想打给你什么是传入的形参呢!
正常的程序中有这样的:(javascript为例)
function sfuction(obj)
{
objXXXXXXX;
}
试问一下其中的obj进行了赋值或是声明了吗?
其中@a VARCHAr(2000)表示为存储过程传入的形参,也就是说,这个参数是用来接收的,是形参显然不用定义了!如果这样写你可能看的更新楚些:
create proc procname
( @intvalue int,
@stringtemp nvarchar(100)
)
as
begin
XXXXXX
end
其中括号中的内容就是形参,也就是说传入值让这个参数进行接收,而此时还没有任何的执行,就必须先让这个参数接收,这样的就是形参,不是自定义的变量!只是表示要传入的值而已,显然这样的值是不可能进行定义的!而在begin段中可以直接进行处理的!
所以形参不能算是自定义的参数!他只表示传入的第一个值按在处理中按参数@a进行引用,该类型必须为Nvarchar(2000)而已。
所以注意一下形参是不须也是不能定义的!
全部回答
- 1楼网友:洎扰庸人
- 2021-02-19 03:36
qq:1055090527
- 2楼网友:几近狂妄
- 2021-02-19 03:03
存储过程的参数有两种 一种是传承参数 就比如这样:alter procedure pro_cc
@a varchar(100)
as 一种是内置参数 eg:declare @i int
declare @count int
declare @tstr varchar(50)
declare @tb table(i varchar(50))
不可能没有声明 没声明会报错
公司部让上qq 只能这样说下
@a varchar(100)
as 一种是内置参数 eg:declare @i int
declare @count int
declare @tstr varchar(50)
declare @tb table(i varchar(50))
不可能没有声明 没声明会报错
公司部让上qq 只能这样说下
- 3楼网友:往事隔山水
- 2021-02-19 01:57
declare就是声明变量的,如果数据库表中有的字段就不用声明了,没有的但是存储过程中要用到的变量就需要声明,格式declare @变量名 变量类型 如:declare @Uname varchar(10)追问能给个实例讲解一下否?追答set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
ALTER PROC [dbo].[S] ( @TBL VARCHAr(100),
@WHERe VARCHAr(100) = NULL ) --这两个是调用的时候传进来的参数,不用声明
AS
DECLARE @SQLSTRING NVARCHAr(500) --这个是存储过程里需要这样一个变量,不是传入的所以需要声明
IF @WHERe IS NULL
SELECt @WHERe = ''
ELSE
SELECT @WHERe = ' WHERe '+@WHERe
SELECT @SQLSTRING = N'SELECT * FROM '+@TBL+' '+@WHERe
EXEC sp_executesql @SQLSTRING
set QUOTED_IDENTIFIER ON
go
ALTER PROC [dbo].[S] ( @TBL VARCHAr(100),
@WHERe VARCHAr(100) = NULL ) --这两个是调用的时候传进来的参数,不用声明
AS
DECLARE @SQLSTRING NVARCHAr(500) --这个是存储过程里需要这样一个变量,不是传入的所以需要声明
IF @WHERe IS NULL
SELECt @WHERe = ''
ELSE
SELECT @WHERe = ' WHERe '+@WHERe
SELECT @SQLSTRING = N'SELECT * FROM '+@TBL+' '+@WHERe
EXEC sp_executesql @SQLSTRING
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯