13

我的数据库中有 2 个表,例如:Table1: id (PK), data1Table2: id (PK), id_table1 (FK), data2. 我怎样才能进行这样的查询:

SELECT * FROM Table1, Table2 WHERE Table1.id = Table2.id_table1 
GROUP BY Table1.data1

我正在使用SQLiteDatabase和它的query()方法。

Cursor mCursor = db.query(true, new String[] {"Table1","Table2"}, 
new String[] {"Table1.id","data1", "Table2.id", "id_table1", "data2"},
"Table1.id=Table2.id_table1", null, "Table1.data1", null,null,null);

但是第二个 arg 有一个问题 - 只能使用 String,而不是 String[] (like new String[] {"Table1","Table2})。我应该怎么做才能以这种方式从多个表中进行查询?

4

2 回答 2

29

试试这个:

Cursor mCursor = db.rawQuery("SELECT * FROM Table1, Table2 " +
                             "WHERE Table1.id = Table2.id_table1 " +
                             "GROUP BY Table1.data1", null);
于 2012-06-14T08:43:23.597 回答
14

所以当你需要JOIN表格时,你必须使用rawQuery而不是query. 所以你的陈述

String SELECT_QUERY = SELECT * FROM Table1 t1 INNER JOIN Table2 t2 ON t1.id = t2.id GROUP BY t1.data1;

我建议您使用JOIN,因为它比您的方法更快、更安全。那么你的rawQuery方法可以如下所示:

cursor = db.rawQuery(SELECT_QUERY, null);

看看 SQLiteDatabase 中的 rawQuery

问候

于 2012-06-14T08:53:14.560 回答