exec 执行SQL语句问题
declare@usernamenvarchar(50)set@username='小明'exec('select*fromuserinfowhere('+@userna...
declare @username nvarchar(50)set @username='小明'exec('select * from userinfo where ('+@username'='''' or [user_name]='''+@username+''')')这个是报错的。我想实现的效果是 当@username=''时,查询所有,当@username!=‘’时,查询[user_name]=@username。一定要用exec实现
展开
展开全部
EXEC sp_executesql @sql 这是语法。你缺东西。
把SQL放在一个变量里。'select * from userinfo where ('+@username'='''' or [user_name]='''+@username+''')'
declare @sql nvarchar(500)
set @sql =''select * from userinfo where ('+@username'='''' or [user_name]='''+@username+''')'
EXEC sp_executesql @sql
把SQL放在一个变量里。'select * from userinfo where ('+@username'='''' or [user_name]='''+@username+''')'
declare @sql nvarchar(500)
set @sql =''select * from userinfo where ('+@username'='''' or [user_name]='''+@username+''')'
EXEC sp_executesql @sql
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询