问题:
查询 dept_role 表 role_id 列的数据中包含"2"的数据(无论有无被"|"分隔)。如下图↓
思路: 如果按照一般的思路新截取 role_id 的值,然后再进行条件的筛选,会是一个很麻烦的工作,而且很有可能导致数据遗漏。
因此这里提供的方法是:在 role_id 的两边添加 “|”,再进行模糊匹配。
即:
SELECT
*
FROM
dept_role
WHERE
# 在 role_id 的两边添加 "|",再进行模糊匹配。
CONCAT( '|', role_id, '|' ) LIKE '%|2|%'
查询结果
对应的 MySQL 数据库表脚本
CREATE TABLE `dept_role` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
`department_id` int(11) NULL DEFAULT NULL COMMENT '部门id(非必填)',
`user_id` int(11) NULL DEFAULT NULL COMMENT '用户id(非必填)',
`role_id` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '角色id(string格式,多个角色以符号 | 隔开)',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 28 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '部门角色关系表' ROW_FORMAT = Dynamic;
INSERT INTO `demo`.`dept_role`(`id`, `user_id`, `role_id`) VALUES (1, 10, '1');
INSERT INTO `demo`.`dept_role`(`id`, `user_id`, `role_id`) VALUES (2, 13, '2');
INSERT INTO `demo`.`dept_role`(`id`, `user_id`, `role_id`) VALUES (3, 21, '1|2');
INSERT INTO `demo`.`dept_role`(`id`, `user_id`, `role_id`) VALUES (4, 33, '2|3|4');
INSERT INTO `demo`.`dept_role`(`id`, `user_id`, `role_id`) VALUES (8, 17, '22');
INSERT INTO `demo`.`dept_role`(`id`, `user_id`, `role_id`) VALUES (13, 122, '22|1|14');
INSERT INTO `demo`.`dept_role`(`id`, `user_id`, `role_id`) VALUES (21, 122, '22|1|2|14');