sql存储过程怎么使用变量来替代列名,比如select * from Table where @c

sql存储过程怎么使用变量来替代列名,比如select*fromTablewhere@col=@KeyWord... sql存储过程怎么使用变量来替代列名,比如select * from Table where @col =@KeyWord 展开
 我来答
blademaster717
推荐于2016-04-18 · TA获得超过1456个赞
知道小有建树答主
回答量:882
采纳率:97%
帮助的人:366万
展开全部
那就SQL语句需要变为动态的

declare @str varchar(100)
set @str = 'select * from Table where ' + @col + '=' + @KeyWord
exec(@str)
追问
执行过程的时候会报错 比如说我的@col输入为“学生”,@KeyWord输入为“张三”,它会弹出说列名“张三”无效,这是为什么
追答
如果你那字段是字符串,那么就要改为:

declare @str varchar(100)
set @str = 'select * from Table where ' + @col + '=''' + @KeyWord + ''''
exec(@str)
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
智能LOL
2014-12-30 · 超过20用户采纳过TA的回答
知道答主
回答量:29
采纳率:0%
帮助的人:28.1万
展开全部
CREATE PROCEDURE HumanResources.uspGetEmployeesTest2
@LastName nvarchar(50),
@FirstName nvarchar(50)
AS
SET NOCOUNT ON;
SELECT FirstName, LastName, Department
FROM HumanResources.vEmployeeDepartmentHistory
WHERE FirstName = @FirstName AND LastName = @LastName
AND EndDate IS NULL;
GO
追问
是回答我提的问题的吗?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式