• 技术文章 >Java >java教程

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

    黄舟黄舟2017-06-18 10:06:40原创664
    这篇文章主要给大家介绍了关于通过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对反斜杠”\“转义的测试详解的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:mysql Java 斜杠 连接 关于
    上一篇:Java中字节流与基本数据类型如何转换的实例代码的分析 下一篇:Java中关于反射机制的示例代码分享(图)
    PHP编程就业班

    相关文章推荐

    • JAVA-5NIO之Selector• 打造高性能Java应用需掌握的5大知识• Java开发中的23种设计模式详解• MyBatis整体预览(一)• Java基础之类和对象、单例模式、继承

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网