内容简介:通过Java连接mysql对反斜杠“\”转义的测试
在 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”筛选时,最好使用正则式转义
本文 《通过Java连接mysql对反斜杠“\"转义的测试》 来自www.juwends.com ,欢迎转载或CV操作,但请注明出处,谢谢!
以上所述就是小编给大家介绍的《通过Java连接mysql对反斜杠“\”转义的测试》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Roslyn/MSBuild 在编译期间处理路径中的斜杠与反斜杠(\)
- MySQL列名中包含斜杠或者空格的处理方法
- mysql语句插入含单引号或者反斜杠的值
- php – Laravel:如何使用尾部斜杠创建路由路由返回URL?
- PowerShell转义通配符
- XML 非法字符(转义字符)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
设计原本
Frederick P. Brooks, Jr. / InfoQ中文站、王海鹏、高博 / 机械工业出版社 / 2011-1-1 / 55.00元
无论是软件开发、工程还是建筑,有效的设计都是工作的核心。《设计原本:计算机科学巨匠Frederick P. Brooks的思考》将对设计过程进行深入分析,揭示进行有效和优雅设计的方法。 本书包含了多个行业设计者的特别领悟。Frederick P. Brooks, Jr.精确发现了所有设计项目中内在的不变因素,揭示 了进行优秀设计的过程和模式。通过与几十位优秀设计者的对话,以及他自己在几个设计......一起来看看 《设计原本》 这本书的介绍吧!