MYSQL查询某字段中以逗号分隔的字符串的方法

MYSQL查询某字段中以逗号分隔的字符串的方法

https://www.cnblogs.com/gmq-sh/p/6848929.html
 
首先我们建立一张带有逗号分隔的字符串。

CREATE TABLE test(id int(6) NOT NULL AUTO_INCREMENT,PRIMARY KEY (id),pname VARCHAR(20) NOT NULL,pnum VARCHAR(50) NOT NULL);

然后插入带有逗号分隔的测试数据
INSERT INTO test(pname,pnum) VALUES(‘产品1′,’1,2,4’);
INSERT INTO test(pname,pnum) VALUES(‘产品2′,’2,4,7’);
INSERT INTO test(pname,pnum) VALUES(‘产品3′,’3,4’);
INSERT INTO test(pname,pnum) VALUES(‘产品4′,’1,7,8,9’);

INSERT INTO test(pname,pnum) VALUES(‘产品5′,’33,4’);

 

查找pnum字段中包含3或者9的记录
MySQL> SELECT * FROM test WHERE find_in_set(‘3’,pnum) OR find_in_set(‘9’,pnum);
+—-+——-+———+
| id | pname | pnum    |
+—-+——-+———+
|  3 | 产品3 | 3,4     |
|  4 | 产品4 | 1,7,8,9 |
+—-+——-+———+
2 rows in set (0.03 sec)

 

使用正则
mysql> SELECT * FROM test WHERE pnum REGEXP ‘(3|9)’;
+—-+——-+———+
| id | pname | pnum    |
+—-+——-+———+
|  3 | 产品3 | 3,4     |
|  4 | 产品4 | 1,7,8,9 |
|  5 | 产品5 | 33,4    |
+—-+——-+———+
3 rows in set (0.02 sec)
这样会产生多条记录,比如33也被查找出来了。

 

换一种方式

 

 

  1. mysql> SELECT * FROM test WHERE CONCAT(‘,’,pnum,‘,’) REGEXP ‘[^0-9]+[3|9][^0-9]+’;  

+—-+——-+———+
| id | pname | pnum    |
+—-+——-+———+
|  3 | 产品3 | 3,4     |
|  4 | 产品4 | 1,7,8,9 |
+—-+——-+———+
2 rows in set (0.01 sec)

 

 

3、select * from oa_student_archives where CONCAT(‘,’,pe_projects,’,’) like ‘%,11,%’;

这种方式也可以。

 

注意:

标红的mysql> SELECT * FROM test WHERE CONCAT(‘,’,pnum,‘,’) REGEXP ‘[^0-9]+[3|9][^0-9]+’; 

这种,当时小于10的数据搜索是可以的,但是如果是大于10的,则不能用,原因我还不太清楚,有大神可以解释下吗?

 

总结如下:

1、select * from oa_student_archives where CONCAT(‘,’,pe_projects,’,’) like ‘%,11,%’;

2、select * from oa_student_archives where find_in_set(’12’, pe_projects);

 

以上的两个都可以用。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113473.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月17日 下午4:00
下一篇 2021年10月17日 下午4:00


相关推荐

  • 外挂基础_开挂的正确姿势

    外挂基础_开挂的正确姿势一、前言  所谓游戏外挂,其实是一种游戏外辅程序,它可以协助玩家自动产生游戏动作、修改游戏网络数据包以及修改游戏内存数据等,以实现玩家用最少的时间和金钱去完成功力升级和过关斩将。虽然,现在对游戏外挂程序的“合法”身份众说纷纭,在这里我不想对此发表任何个人意见,让时间去

    2022年10月8日
    4
  • 3D视觉传感技术:时间飞行法 (ToF) 技术分析

    3D视觉传感技术:时间飞行法 (ToF) 技术分析现行的深度传感镜头作为智能手机的一大创新 已在目前主流智能手机上广泛应用 因苹果在最新版 iPadPro 上搭载了 D ToF 直接飞行时间法 深度传感镜头引起了极大的关注 推动了 3D 视觉在消

    2026年3月18日
    2
  • dify源码本地部署,dify k8s部署

    dify源码本地部署,dify k8s部署

    2026年3月13日
    2
  • Druid介绍及入门[通俗易懂]

    Druid介绍及入门[通俗易懂]1.什么是Druid?Druid是一个高效的数据查询系统,主要解决的是对于大量的基于时序的数据进行聚合查询。数据可以实时摄入,进入到Druid后立即可查,同时数据是几乎是不可变。通常是基于时序的事实事件,事实发生后进入Druid,外部系统就可以对该事实进行查询。Druid采用的架构: shared-nothing架构与lambda架构 Druid设计三个原则:1.快速查询(FastQu…

    2022年7月23日
    10
  • BurpSuite系列(五)—-Intruder模块(暴力激活成功教程)「建议收藏」

    BurpSuite系列(五)—-Intruder模块(暴力激活成功教程)「建议收藏」一、简介BurpIntruder是一个强大的工具,用于自动对Web应用程序自定义的攻击,BurpIntruder是高度可配置的,并被用来在广范围内进行自动化攻击。你可以使用BurpIntruder方便地执行许多任务,包括枚举标识符,获取有用数据,漏洞模糊测试。合适的攻击类型取决于应用程序的情况,可能包括:缺陷测试:SQL注入,跨站点脚本,缓冲区溢出,路径遍历;暴力攻击认证

    2022年7月12日
    72
  • pycahrm激活码 3月最新注册码

    pycahrm激活码 3月最新注册码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    81

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号