今天写代码时前台传过来类似‘1,2,3,4,5,6’的字符串,这种情况直接用IN是无效的,需要把字符串分割成数组或者组装成列表,然后再利用mabatis的foreach函数
SELECT * FROM fast_input f where id in
separator="," close=")">
#{item}
或者可以用INSTR,FIND_IN_SET等函数,正好借此测试了下这个三个函数的效率。
建表:
CREATE TABLE `fast_input` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
`content` varchar(100) DEFAULT NULL COMMENT '内容',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
循环插入数据
INSERT INTO fast_input(content) SELECT content FROM fast_input
我用了65000条数据,分别执行以下语句
SELECT * FROM fast_input f where FIND_IN_SET(id,'4,14,144');
受影响的行: 0
时间: 0.022s
SELECT * FROM fast_input f where INSTR(CONCAT(',','4,14,144',','),CONCAT('