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

相关推荐
凉栀お_2 小时前
MySQL第五次作业(触发器,存储过程)
android·mysql·adb
wangchen_02 小时前
MySQL索引
数据库·mysql
哈__2 小时前
数据库迁移实操与金仓数据库技术优势:从语法兼容到自动化落地
数据库
蟹至之2 小时前
增删查改(其一) —— insert插入 与 select条件查询
数据库·mysql·增删查改
Yeats_Liao3 小时前
时序数据库系列(七):性能监控实战指标收集
数据库·后端·时序数据库
无心水3 小时前
【中间件:Redis】1、Redis面试核心:线程模型深度解析(6.0前后变化+工作流程)
数据库·redis·面试·redis面试·redis原理·redis线程模型·后端技术
milanyangbo3 小时前
从同步耦合到异步解耦:消息中间件如何重塑系统间的通信范式?
java·数据库·后端·缓存·中间件·架构
绛洞花主敏明4 小时前
Gorm(十四)的多条件叠加
数据库
枫叶丹44 小时前
【Qt开发】布局管理器(五)-> QSpacerItem 控件
开发语言·数据库·c++·qt