首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >有没有办法让TSQL变量成为常量?

有没有办法让TSQL变量成为常量?
EN

Stack Overflow用户
提问于 2008-08-25 19:03:30
回答 11查看 92K关注 0票数 96

有没有办法让TSQL变量成为常量?

EN

回答 11

Stack Overflow用户

回答已采纳

发布于 2008-08-25 19:05:30

不能,但您可以创建一个函数并将其硬编码在其中并使用它。

下面是一个示例:

代码语言:javascript
复制
CREATE FUNCTION fnConstant()
RETURNS INT
AS
BEGIN
    RETURN 2
END
GO

SELECT dbo.fnConstant()
票数 63
EN

Stack Overflow用户

发布于 2012-10-04 16:31:48

对于缺少constans,我的解决办法是向优化器提供有关值的提示。

代码语言:javascript
复制
DECLARE @Constant INT = 123;

SELECT * 
FROM [some_relation] 
WHERE [some_attribute] = @Constant
OPTION( OPTIMIZE FOR (@Constant = 123))

这将告诉查询编译器在创建执行计划时将变量视为常量。缺点是您必须定义该值两次。

票数 27
EN

Stack Overflow用户

发布于 2008-08-25 19:15:26

不,但是应该使用好的旧的命名约定。

代码语言:javascript
复制
declare @MY_VALUE as int
票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26652

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档