急急急,Sql查询一个字段是否存在某一个值,怎么写查询语句?

如图片所示的表结构,当参数是2的时候,查询出fubclass里面包含2的所有记录,即第一条和第二条记录,当参数是3的时候,3条记录都应该查询出来。
MSSQL数据库,最好不用like语句

第1个回答  2012-06-05
不知道是什么数据库..
oracle数据库sql语句如下:
select * from 表名 where instr(fuclass,'你要传入的参数')>0;

其实这样也有问题,你这题的思路应该是先根据逗号分隔符截取字符串,然后根据你传入的参数和根据逗号截取出来的字符串进行比较,如果存在那就是你要的记录,否则就不是,但是oracle并不存在这样一种函数.比如gp中使用的split_part函数,所以比较麻烦,只能自己构建一个函数,然后调用这个函数先对字符串进行处理

出问题的原因是如果你传入一个'2',那么'22'也会算作是合格字符,而将结果返回
第2个回答  2017-07-13
where fubclass REGEXP '2'查询2的记录
where fubclass REGEXP '3' 查询3的记录
正则表达式其实也是like,不知道满足你的要求不
第3个回答  2012-06-05
'SQL SERVER使用:
select * from 表名 as a where instr(a.fubclass,"2")>0
Oracle 使用:
select * from 表名 as a where instr(a.fubclass,'2')>0
以上作用是查询表名的fubclass字段包含2的记录集追问

instr 没有这个函数吧

追答

必须有

第4个回答  2012-06-05
select * from XX,where fubclass like '%2%'
select * from XX,where fubclass like '%3%'
第5个回答  2018-03-16
SELECT * FROM `表名` WHERE LOCATE('2',`fubclass`);

相似回答