最佳答案
我有一个 Android 项目,有一个数据库与两个表: tbl_question
和 tbl_alternative
。
为了用问题和备选方案填充视图,我使用了游标。在尝试连接这两个表之前,获取所需的数据没有任何问题。
Tbl_question ------------- _id question categoryid
Tbl_alternative --------------- _id questionid categoryid alternative
我想要这样的东西:
SELECT tbl_question.question, tbl_alternative.alternative where
categoryid=tbl_alternative.categoryid AND tbl_question._id =
tbl_alternative.questionid.`
这是我的尝试:
public Cursor getAlternative(long categoryid) {
String[] columns = new String[] { KEY_Q_ID, KEY_IMAGE, KEY_QUESTION, KEY_ALT, KEY_QID};
String whereClause = KEY_CATEGORYID + "=" + categoryid +" AND "+ KEY_Q_ID +"="+ KEY_QID;
Cursor cursor = mDb.query(true, DBTABLE_QUESTION + " INNER JOIN "+ DBTABLE_ALTERNATIVE, columns, whereClause, null, null, null, null, null);
if (cursor != null) {
cursor.moveToFirst();
}
return cursor;
我发现这种方式比常规 SQL 更难以形成查询,但是我得到了使用这种方式的建议,因为它更少出错。
如何在应用程序中连接两个 SQLite 表?