查询 dept_role 表 role_id 列的数据中包含"2"的数据

问题:

查询 dept_role 表 role_id 列的数据中包含"2"的数据(无论有无被"|"分隔)。如下图↓

dept_role

思路: 如果按照一般的思路新截取 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');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值