请问这条SQL语句该怎么写?
我的表里有一个字段是用来表示用户的type的,3为普通用户,0,1,2为管理员,在注册时要选择注册者的type,然后我要在表里查一下这个名字是不是已经存在,在存储过程中,我是这样写的:
create procedure sp_checkNameExist
@UserName nvarchar(10),
@UserType int
as
if @UserType=3
select UserId from users where UserName=@UserName and UserLevel=3
else
exec('select UserId from users where UserName='+ @UserName +'and (UserLevel=0 or UserLevel=1 or UserLevel=2)' )
select @@rowcount
可是执行的时候,如果参数UserType给的是3,就可以查到正确的结果,如果不是3,就会出现如下的错误提示:
第 1 行: '=' 附近有语法错误。
(所影响的行数为 1 行)
请教一下错在哪里?多谢多谢!