[英]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.