首页  >  文章  >  后端开发  >  mysql如何根据字符串中的字母查询出一个字段中与字母相匹配的数据

mysql如何根据字符串中的字母查询出一个字段中与字母相匹配的数据

WBOY
WBOY原创
2016-06-20 12:28:13961浏览

如:
一个字符串可能为A,B,C
也可能为B,C
也可能为C

数据表中fID字段存在多个A或B或C

如果字符中包含A,B,C,要查询出fID中fID为A或B或C的数据
如果字符中包含,B,C,要查询出fID中fID为B或C的数据

CREATE TABLE `tab` (
`fID` VARCHAR(2) NULL DEFAULT NULL,
`fName` VARCHAR(10) NULL
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB;
INSERT INTO `tab` (`fID`, `fName`) VALUES
('A', 'A01'),
('A', 'A02'),
('A', 'A03'),
('A', 'A04'),
('B', 'B02'),
('B', 'B03'),
('B', 'B04'),
('B', 'B01'),
('B', 'B05'),
('C', 'C02'),
('C', 'C03'),
('C', 'C01');


回复讨论(解决方案)

假定你输入的串是(或经处理后)A,C,B 这样的格式,那么可以
严格匹配
select * from tab where find_in_set(fID, '$inp')
模糊匹配
select * from tab where '$inp' like concat('%‘, fID, '%')

感谢用xuzuning 的解答,用 find_in_set(fID, '$inp')解决了

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn