Mysql常见报错解决分享-01-Invalid escape character in string.

所以

sql 复制代码
SET @form_json = '假如这个是你报错的字符串'
SET @form_json = REPLACE(@form_json, '\n', '\\n');
SET @form_json = REPLACE(@form_json, '\t', '\\t');
SET @form_json = REPLACE(@form_json, '\r', '\\r');

替换成对应的多加一个反斜杠符号的字符串就好了

其实也就是说报错的路径是

  • SQL解析器
    • 将'\n'解释为一个换行符
  • 是否是合法的JSON字符串
    • 由于JSON字符串中换行必须用\n表示,也就是说 原来的 字符串 在被 解析后 , 得到 的应该是 XXX\n XXX (合法的) ,但是由于没针对反斜杠符号 进行转义(也就是写成 \n 这样 解析后就会成 \n), 所以 直接被 解析成了换行符, 最终结果变成了
      XXX
      XXX (不合法)
相关推荐
0xDevNull5 分钟前
MySQL数据冷热分离详解
后端·mysql
科技小花21 分钟前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸22 分钟前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain24 分钟前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希1 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神1 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员1 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java1 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿2 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴2 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存