时间:2021-05-19
前言
在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”筛选时,最好使用正则式转义
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
通过AJAX传到PHP的json字符串有时候加上反斜杠”\”来转义,PHP处理时需要先去掉反斜杠,然后再json_decode.$str=stripslashe
插入mysql时,如果内容中有引号等特殊符号,会报错,解决方法可以用反斜杠转义,还可以用pymysql的一个方法自动转义:c=''' 北京时间9月20日晚间9
c语言中的转义字符:\a响铃符\b退格\f换页符\n换行符\r回车符(回到该行的首位置)\v纵向制表符\\反斜杠\?问号(?经vs10测试可以直接打印)\"(\
Python转义字符在需要在字符中使用特殊字符时,python用反斜杠(\)转义字符。如下表:原始字符串有时我们并不想让转义字符生效,我们只想显示字符串原来的意
Python中转义字符正则表达式使用反斜杠”\“来代表特殊形式或用作转义字符,这里跟Python的语法冲突,因此,Python用”\\\\“表示正则表达式中的”