博客
关于我
MySql 查询以逗号分隔的字符串的方法(正则)
阅读量:791 次
发布时间:2023-02-10

本文共 556 字,大约阅读时间需要 1 分钟。

数据库表中某个字段保存的值为“01,07,08”,需要查询下表中对应的名称。以下是一些可能的解决方法:

  • 使用find_in_set()函数

    这个函数可以检查字符串中是否存在特定的子字符串。以下是查询包含“01”、“07”或“08”的记录的SQL语句:

    SELECT * FROM test WHERE find_in_set('01', itemname) OR find_in_set('07', itemname) OR find_in_set('08', itemname);
  • 使用正则表达式

    正则表达式可以更简洁地匹配多个值。以下是使用正则表达式的SQL语句:

    SELECT * FROM test WHERE itemname REGEXP '(01|07|08)';
  • 使用LIKEIN

    如果数据库支持,可以尝试将字段值转换为数组,并使用IN子句进行匹配。例如:

    SELECT * FROM test WHERE itemname LIKE '%01,07,08%' OR itemname LIKE '%01,08%';

    不过这种方法可能需要多次重复,且不如正则表达式灵活。

  • 总结

    在支持正则表达式的数据库环境下,使用正则表达式是最优的选择,因为它简洁且灵活,只需修改表达式即可扩展更多值。

    转载地址:http://zfbfk.baihongyu.com/

    你可能感兴趣的文章
    mysql /*! 50100 ... */ 条件编译
    查看>>
    mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
    查看>>
    mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
    查看>>
    mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
    查看>>
    mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
    查看>>
    MySQL 8.0 恢复孤立文件每表ibd文件
    查看>>
    MySQL 8.0开始Group by不再排序
    查看>>
    mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
    查看>>
    multi swiper bug solution
    查看>>
    MySQL Binlog 日志监听与 Spring 集成实战
    查看>>
    MySQL binlog三种模式
    查看>>
    multi-angle cosine and sines
    查看>>
    Mysql Can't connect to MySQL server
    查看>>
    mysql case when 乱码_Mysql CASE WHEN 用法
    查看>>
    Multicast1
    查看>>
    mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
    查看>>
    MySQL Cluster 7.0.36 发布
    查看>>
    Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
    查看>>
    MySQL Cluster与MGR集群实战
    查看>>
    multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
    查看>>