sql 添加变量

在sql语句中添加变量。

 

declare @local_variable data_type

声明时需要指定变量的类型,

可以使用set和select对变量进行赋值,

在sql语句中就可以使用@local_variable来调用变量

 

声明中可以提供值,否则声明之后所有变量将初始化为NULL。

 

例如:declare @id int

         declare @id int = 3

         set @id=2

         select id

         select @id = column_id from table where column_user = 'ABC'

 

 

T-SQL中的参数与变量

 

在TSQL中,查询语句编译时并不为变量赋值(SET OR SELECT Operation),即变量赋值在编译完成,语句执行时才执行赋值操作,因此查询优化器不一定能为查询语句生成一个合适的执行计划

ex:

DECLARE @Id INT =100; SELECT * FROM dbo.Users WHERE UserId>@Id

可以使用以下几种方式修改:

复制代码
--=====================================================
DECLARE @Id INT =100; SELECT * FROM dbo.Users WHERE UserId>@Id OPTION(RECOMPILE) --===================================================== DECLARE @Id INT =100; SELECT * FROM dbo.Users WHERE UserId>@Id OPTION(RECOMPILE(@ID=2)); --===================================================== SP_EXECUTESQL ' SELECT * FROM dbo.Users WHERE UserId>@Id',N'@Id INT',@ID=100 --===================================================== CREATE PROCEDURE dbo.usp_GetUser ( @ID INT ) AS BEGIN SELECT * FROM dbo.Users WHERE UserId>@Id END GO EXEC dbo.usp_GetUser @ID=100 --=====================================================

转载于:https://www.cnblogs.com/nxxshxf/p/5589934.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值