MySQL运维实战(4.6) SQL_MODE之NO_BACKSLASH_ESCAPES

作者:俊达

在MySQL中,默认情况下,反斜杠(\)被用作转义字符,转义反斜杠(\)后一个字符;当设置NO_BACKSLASH_ESCAPES后,反斜杠(\)将不作为转义字符,而被视为普通字符。

下面是一个示例,说明了这两种情况的区别:
未设置NO_BACKSLASH_ESCAPES模式

sql 复制代码
mysql> create table t_escape(id int, a varchar(100));
Query OK, 0 rows affected (0.01 sec)

-- 默认情况,反斜杠是转义符,会改变后一个字符的含义。
mysql> set sql_mode='';
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t_escape values(1, 'a\'b');
Query OK, 1 row affected (0.00 sec)

mysql> insert into t_escape values(1, 'a\\b');
Query OK, 1 row affected (0.00 sec)

mysql> select * from t_escape;
+------+------+
| id   | a    |
+------+------+
|    1 | a'b  |
|    2 | a\b  |
+------+------+
2 rows in set (0.00 sec)

设置NO_BACKSLASH_ESCAPES

sql 复制代码
SET sql_mode = 'NO_BACKSLASH_ESCAPES';
-- 这个SQL中单引号不匹配,报语法错误
mysql> insert into t_escape values(3, 'a\'b');
    '> ';
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'b');
'' at line 1

-- 2个反斜杠都写入到表中
mysql> insert into t_escape values(4, 'a\\b');
Query OK, 1 row affected (0.01 sec)


-- 单引号不能用反斜杠转义,使用单引号转义单引号(使用2个单引号代表一个单引号)。
mysql> insert into t_escape values(5, 'a''b');
Query OK, 1 row affected (0.01 sec)

mysql> select * from t_escape;
+------+------+
| id   | a    |
+------+------+
|    1 | a'b  |
|    2 | a\b  |
|    4 | a\\b |
|    5 | a'b  |
+------+------+
4 rows in set (0.00 sec)

总之,NO_BACKSLASH_ESCAPES模式决定了反斜杠在MySQL中的转义行为。设置了该模式后,反斜杠将被视为普通字符,而不设置该模式则反斜杠用来转义后一个字符。通过设置NO_BACKSLASH_ESCAPES,可以避免过度使用反斜杠转义符,使操作更加简洁和易读。

更多技术信息请查看云掣官网https://yunche.pro/?t=yrgw

相关推荐
志栋智能29 分钟前
超自动化巡检:实现精细化运维管理的基础
运维·服务器·网络·人工智能·自动化
TOSUN同星30 分钟前
同星多工位自动化刷写台架,助力汽车电子高效量产与质量追溯
运维·自动化·汽车
夏日听雨眠40 分钟前
LInux(gcc处理器,库文件,动静态库)
linux·运维·服务器
神仙别闹42 分钟前
基于PHP+MySQL实现在线考试系统
开发语言·mysql·php
xingfujie44 分钟前
Ubuntu K8s 1.28 kubeadm 高可用集群部署实战
linux·运维·服务器·docker·kubernetes
实心儿儿1 小时前
Linux —— 进程间通信 - 命名管道
linux·运维·服务器
2501_921939261 小时前
MySQL(备份恢复、主从复制读写分离)
数据库·mysql
Agent手记1 小时前
多渠道订单数据处理自动化,落地步骤与ERP打通方案 | 2026企业级智能体实战手册
运维·人工智能·ai·自动化
呉師傅1 小时前
统信UOS如何安装本地打印机驱动以及URL查找网络打印机并安装驱动方法
运维·服务器·网络·windows·电脑
iFlow_AI1 小时前
构建自动化专属Paper库:用 Happy-Notes + iFlow-search-skill 搭建阅读写作流水线
运维·自动化·skill·心流·happy-notes