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的查询,这里就不举例了。

相关推荐
瀚高PG实验室12 小时前
ERROR: invalid input syntax for type integer: “a“
数据库·瀚高数据库
S1998_1997111609•X12 小时前
论next/js在打击省份及犯罪行为集团的系统分析[特殊字符]设计
网络·数据库·百度·ssh·开闭原则
dfdfadffa12 小时前
如何创建仅在首次订阅时执行一次计算的 RxJS 懒加载 Observable
jvm·数据库·python
Irene199112 小时前
Oracle 中:为什么 from 子查询后面需要一个别名
数据库·oracle
m0_6245785912 小时前
SQL分组后如何计算移动平均值_利用窗口函数AVG配合ROWS
jvm·数据库·python
2401_8242226913 小时前
如何修复待办事项列表无法添加任务的 JavaScript 错误
jvm·数据库·python
地球资源数据云13 小时前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
tang&13 小时前
【MySQL】索引创建与B+树原理:MySQL性能优化的核心一课
b树·mysql·性能优化
sitellla13 小时前
MySQL 入门:最流行的开源关系型数据库介绍
数据库·mysql·其他·开源
精益数智工坊13 小时前
拆解制造业仓库物料管理流程:如何通过标准化仓库物料管理流程解决账实不符难题
大数据·前端·数据库·人工智能·精益工程