sql server like 一个字段。 例如:select * from 表 where 字段1 like '%字段2%'
推荐于2017-10-08 · 知道合伙人软件行家
关注
展开全部
sql 中 like 要引用一个字段的值,需要使用连接符‘+’
所以原语句:select * from 表 where 字段1 like '%字段2%'
需要更改为:select * from 表 where 字段1 like '%'+字段2+'%'
SQL Server中 用 + 来连接字符串。如果不是字符类型,应先转换成字符类型。
也就是说,如果语句中的’字段2‘为数值型字段那么,语句需要更改为:
select * from 表 where 字段1 like '%'+cast(字段2 as varchar(20))+'%'
所以原语句:select * from 表 where 字段1 like '%字段2%'
需要更改为:select * from 表 where 字段1 like '%'+字段2+'%'
SQL Server中 用 + 来连接字符串。如果不是字符类型,应先转换成字符类型。
也就是说,如果语句中的’字段2‘为数值型字段那么,语句需要更改为:
select * from 表 where 字段1 like '%'+cast(字段2 as varchar(20))+'%'
展开全部
2个%号,表示包含“字段2”,前面%表示以“字段2”结束,后面%表示以“字段2”开始
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-05-17
展开全部
select * from 表 where 字段1 like '%' + 字段2 + '%'
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
改成这样就行了哦
select * from 表 where 字段1 like '%'+字段2+'%'
select * from 表 where 字段1 like '%'+字段2+'%'
追问
不行,会报转换数据类型失败。
下面是错误信息:
在将 varchar 值 '%' 转换成数据类型 int 时失败。
追答
改成这样
select * from 表 where 字段1 like '%'+convert(nvarchar(50),字段2)+'%'
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
楼上正解,采纳吧~
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询