背景
我有一个安卓项目,其中包含两个表: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表?