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);

 

以上的两个都可以用。

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • C# 操作XML文件 XmlDocument和XElement

    C# 操作XML文件 XmlDocument和XElement首先在根目录下新建一个config.xml:<?xmlversion=”1.0″encoding=”utf-8″?><Config><Debug><Lan><ServerIp=”142.12.10.123″Port=”9601″/></Lan&g…

  • DropDownList绑定ArrayList「建议收藏」

    DropDownList绑定ArrayList「建议收藏」namespaceCDR.components{publicenumAgentLevel{K,A,B,C}publicclassAgent{publicAgentLevelLevel{get{return_level;}}publicstringName{get{return_name;}}priv…

  • (二)Sql Server的基本配置以及使用Navicat连接Sql Server

    (二)Sql Server的基本配置以及使用Navicat连接Sql Server一:sqlserver连接的验证方式分为两种:Windows身份认证:使用windows的用户名密码验证SQLServer身份认证:使用sqlserver的用户名+密码的方式登录()二:sqlserver的环境配置实际生产环境服务器肯定是需要远程连接的,所以我们需要对本机的sqlserver进行一下的基本配置:配置支持tcp连接(否则无法使用连接工具进行远程连接)配置支持SQLServer身份认证(一般情况下都会使用这种验证方式而不是windows验证)配置

  • 惠普m154a状态页_惠普m154a感叹号闪烁[通俗易懂]

    惠普m154a状态页_惠普m154a感叹号闪烁[通俗易懂]大家好,我是时间财富网智能客服时间君,上述问题将由我为大家进行解答。惠普m154a感叹号闪烁的解决方法如下:1、打开电脑管家,点击“工具箱”。2、在工具箱里找到“硬件检测”。3、在硬件检测里点击“驱动安装”。4、可以看到“安装状态”,如果是未安装可以直接点击安装。惠普公司(Hewlett-PackardDevelopmentCompany,L.P,简称HP)总部位于美国加利福尼亚州的帕罗奥多…

  • GoogLeNet系列解读「建议收藏」

    GoogLeNet系列解读「建议收藏」本文介绍的是著名的网络结构GoogLeNet及其延伸版本,目的是试图领会其中的思想而不是单纯关注结构。GoogLeNetIncepetionV1MotivationArchitecturalDetailsGoogLeNetConclusionGoogLeNetInceptionV2IntroductionGeneralDesignPrinciplesFactorizi

  • 什么是机器学习?

    什么是机器学习?1.引言为了解决计算机上的问题,我们需要一个算法。算法是应该执行以将输入变换到输出的指令序列。例如,可以设计用于排序的算法。输入是一组数字,输出是它们的有序列表。对于相同的任务,可以有各种算法,并且

发表回复

您的电子邮箱地址不会被公开。

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