关于通过Java连接mysql对反斜杠”\\“转义的测试详解

作者:Juwend 时间:2024-01-27 06:52:59 

前言

在java中,反斜杠“\”转义是“\”,因此表示一个“\”要使用“\\”,如果是正则表达式,那么表示一个“\”需要用“\\\\”,在mysql中,反斜杠转义依然是“\”,和java相同。

现在问题是:如果mysql中一个字段的内容包含反斜杠,然后通过java连接mysql去筛选这个字段所在的条目,要怎么写才能将该字段筛选出来呢?下面就是一个实验:

1,先建立测试数据:


CREATE TABLE `test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
);
insert into test (name) values ('\\'), ('\\\\');

向数据库中插入2条数据,name的值分别是“\”和“\\”。

2,使用jdbc连接mysql,然后测试筛选条件:


Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root");
PreparedStatement pstmt = conn.prepareStatement("select * from test where *条件"); // “*条件”见下文
pstmt.setString(1, "*筛选值"); // “*筛选值”见下文
ResultSet rs = pstmt.executeQuery();
while (rs.next()) {
System.out.println(rs.getString("name"));
}

3,测试:

i.

*条件 为:name = ?

*筛选值 为:

“\\”可以筛选出name为“\”的数据

“\\\\”可以筛选出name为“\\”的数据

这个看起来是比较正常的

ii.

*条件 为:name like ?

*筛选值 为:

“\\”或“”\\\\可以筛选出name为“\”的数据

“\\\\\\”或“\\\\\\\\”可以筛选出name为“\\”的数据

开始不变得奇怪了…

iii.

*条件 为:name like ‘%' ?

*筛选值 为:

“\\”或“\\\\”可以筛选出name为“\”和“\\”的数据

“\\\\\\”或“\\\\\\\\”可以筛选出name为“\\”的数据

和 ii. 有点类似

iv.

*条件 为:name like ? ‘%'

*筛选值 为:

“\\\\”可以筛选出name为“\”和“\\”的数据

“\\\\\\\\”可以筛选出name为“\\”的数据

又变得好像正常了…类似正则中的转义

v.

*条件 为:name like ‘%' ? ‘%'

*筛选值 为:

“\\\\”可以筛选出name为“\”和“\\”的数据

“\\\\\\\\”可以筛选出name为“\\”的数据

和 iv. 类似了

4,分析:

使用“=”方式筛选貌似就是常规理解中的转义,但是一旦使用了“like”就开始变得奇怪了,从测试来看,使用“like”筛选有些类似正则式,不过没有使用“%”占位符的筛选中常规转义依然有效,另外,奇怪的是 ii. 和 iii. 中的6根反斜杠是个什么鬼…完全不能理解…

5,结论:

sql语句是“=”筛选时,java就使用常规转义即可

sql语句是“like”筛选时,最好使用正则式转义

来源:https://www.juwends.com/tech/java/java_connect_mysql_for_back_slash.html

标签:java,mysql,反斜杠转义
0
投稿

猜你喜欢

  • Python sublime安装及配置过程详解

    2021-07-06 19:57:47
  • Tensorflow与RNN、双向LSTM等的踩坑记录及解决

    2021-04-29 21:25:55
  • Python函数基础(定义函数、函数参数、匿名函数)

    2022-04-24 05:21:41
  • Tensorflow读取并输出已保存模型的权重数值方式

    2023-09-15 10:07:49
  • 使用已经得到的keras模型识别自己手写的数字方式

    2021-04-03 17:41:11
  • Vue编写炫酷的时钟插件

    2023-07-02 16:32:27
  • thinkphp在模型中自动完成session赋值示例代码

    2024-05-03 15:51:32
  • 技巧/诀窍:在ASP.NET中重写URL

    2007-09-23 12:21:00
  • Python 使用 pip 安装 matplotlib 模块的方法

    2021-08-22 02:42:52
  • pyecharts结合flask框架的使用

    2022-12-01 18:37:25
  • Pain 全世界最小最简单的PHP模板引擎 (普通版)

    2023-11-18 09:12:06
  • python 下划线的多种应用场景总结

    2021-12-19 10:51:54
  • Python识别快递条形码及Tesseract-OCR使用详解

    2022-10-20 01:32:32
  • Pycharm配置autopep8实现流程解析

    2021-08-23 05:34:40
  • Python 用__new__方法实现单例的操作

    2023-05-22 08:22:41
  • Python使用多进程运行含有任意个参数的函数

    2023-10-14 23:22:12
  • Python实现批量执行同目录下的py文件方法

    2022-01-23 21:20:39
  • pygame+opencv实现读取视频帧的方法示例

    2021-01-04 23:41:27
  • python 二维数组90度旋转的方法

    2021-05-18 20:16:19
  • JSONObject使用方法详解

    2024-05-03 15:06:47
  • asp之家 网络编程 m.aspxhome.com