简体   繁体   English

Android SQLite不止一个WHERE

[英]Android SQLite more than one WHERE

I have been looking for it but I am unable to find what I need. 我一直在寻找它,但我无法找到我需要的东西。 I have a SQLite table in android, and I would like to know how the rawquery would be for more than one WHERE clause. 我在android中有一个SQLite表,我想知道rawquery如何用于多个WHERE子句。 I mean, I want to know all the records of a table and all columns of those WHERE the value of two colums are 1 for example. 我的意思是,我想知道一个表的所有记录以及那些WHERE的所有列,例如两个列的值是1。

How could I do this? 我怎么能这样做?

I've tried: 我试过了:

String selectQuery = "SELECT  * FROM " + TABLE_NAME 
        + " WHERE " + KEY_ONE + " = " + String.valueOf(var1)
        + " AND WHERE " + KEY_TWO + " = " + String.valueOf(Var2);

SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);

But it isn't working.. 但它不起作用..

Thanks for the help :D 谢谢你的帮助:D

Remove the second WHERE : 删除第二个WHERE

+ " AND " + KEY_TWO + " = " + String.valueOf(Var2);

Also note that strings must be enclosed in apostrophes: 另请注意,字符串必须用撇号括起来:

String selectQuery = "SELECT  * FROM " + TABLE_NAME 
    + " WHERE " + KEY_ONE + " = '" + String.valueOf(var1)
    + "' AND " + KEY_TWO + " = '" + String.valueOf(Var2) + "'";

Even better if you use this enhanced syntax: 如果您使用此增强语法更好:

String selectQuery = "SELECT  * FROM " + TABLE_NAME 
    + " WHERE " + KEY_ONE + " = ? AND " + KEY_TWO + " = ?";

SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery(selectQuery, new String[]{String.valueOf(var1), String.valueOf(var2)});

Please try as follows and remove the second WHERE clause 请尝试如下并删除第二个WHERE子句

String selectQuery = "SELECT  * FROM " + TABLE_NAME 
        + " WHERE " + KEY_ONE + " = " + String.valueOf(var1)
        + " AND " + KEY_TWO + " = " + String.valueOf(Var2);

SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM