sql server like 一个字段。 例如:select * from 表 where 字段1 like '%字段2%'

如题所述

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))+'%'
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-05-17
2个%号,表示包含“字段2”,前面%表示以“字段2”结束,后面%表示以“字段2”开始
第2个回答  2013-05-17
select * from 表 where 字段1 like '%'  +   字段2  +  '%'

第3个回答  2013-05-17
改成这样就行了哦
select * from 表 where 字段1 like '%'+字段2+'%'追问

不行,会报转换数据类型失败。
下面是错误信息:
在将 varchar 值 '%' 转换成数据类型 int 时失败。

追答

改成这样
select * from 表 where 字段1 like '%'+convert(nvarchar(50),字段2)+'%'

本回答被提问者采纳
第4个回答  2013-05-17
楼上正解,采纳吧~