zoukankan      html  css  js  c++  java
  • android之Android中的SQL查询语句LIKE绑定参数问题解决办法(sqlite数据库)

    由于考虑到数据库的安全性,不被轻易SQL注入,执行查询语句时,一般不使用直接拼接的语句,而是使用参数传递的方法。然后在使用参数传递的方法中时,发现当使用like方式查询数据时,很容易出现一个问题。

    错误案例:

    复制代码代码如下:
    String myname = "abc";
    String sql = "select * from mytable where name like '?%'";
    Cursor cursor = db.rawQuery(sql, new String[]{myname};


    运行提示如下错误:

    复制代码代码如下:
    java.lang.IllegalArgumentException: Cannot bind argument at index 1 because the index is out of range. The statement has 0 parameters.

    根据错误提示可知,sql语句中的?号没有被识别出来,从而new String[]{myname}没法替代sql中的?号。?号没有被识别出来的原因估计是?号外有单引号,但是在sql中like语句的值和%号需要用引号围着。

    为了解决sql中?号无法识别,必须去掉?号外的引号,那么%号也需要去掉。所以,得在后面代替?号的参数中添加上%号。

    所以,正确的案例如下:

    复制代码代码如下:

    String myname = "abc";
    String sql = "select * from mytable where name like ?";
    Cursor cursor = db.rawQuery(sql, new String[]{myname+"%"};
  • 相关阅读:
    php的date对象与javascript的Date对象区别
    window.open的popup-only-once问题(document.cookie)
    window.open详解
    顶级窗口问题window.top
    javascript中的this用法
    问题1:javascript的函数对象问题
    javascript中this的用法
    javacsript:在函数内访问全局变量
    bzoj1934
    bzoj1433
  • 原文地址:https://www.cnblogs.com/lee0oo0/p/4074424.html
Copyright © 2011-2022 走看看