mysql tidb like查询有换行符内容问题解决

问题解决记录

文章目录


前言

记录一次使用mysql、tidb存储带有换行符内容的模糊查询。

一、问题现象

最近需要做一个需求,mysql的版本号为8.0,tidb版本号为8.0以上。数据库表的字段是text类型,需要存储的内容含有换行符引起的问题。下面我先建数据库重现下问题。

java 复制代码
DROP TABLE IF EXISTS `test1`;
CREATE TABLE `test1`  (
  `id` int NOT NULL,
  `name` text CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of test1
-- ----------------------------
INSERT INTO `test1` VALUES (1, '123\r\n456\r\n78910');

现在已经插入好带换行的数据。

二、使用步骤

1.执行模糊查询语句

java 复制代码
select *from test1 where name like concat('%','123\n','%');

可以看到直接模糊查询123\n是查询不到内容的,需要把sql改成\r\n才能查询到数据。

2.问题解决

2.1 mysql解决办法

java代码如下(示例):

java 复制代码
    public static void main(String[] args) {
      // 例如输入是input 需要使用正则重新替换后再进行模糊查询
      String input ="xkjklfjl\njkjk\n";
      input = input.replaceAll("\n","\r\n");
    }
java 复制代码
然后再进行查询语句如下即可查出数据。
like concat('%',input,'%');

2.2 tidb解决办法

tidb直接让前端如果校验到用户有换行,替换成\n

然后执行查询语句如下

java 复制代码
然后再进行查询即可查出数据。
like concat('%',input,'%');

替换查询即可

总结

这里我只距离了mysql的存储方式,经过验证,mysql对于换行符的存储是 \r\n如果要模糊查询这些内容,需要替换成\r\n。如果是tidb就不用,直接是\n查询即可查出内容,感兴趣的朋友可以试试tidb的查询,这里就不举例了。

相关推荐
jiayou642 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满8782 天前
5.Mysql事务隔离级别与锁机制
mysql
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H3 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql