2017-12-11 5 views
0

私はこの質問をたくさん検索しましたが、実際には答えが見つからないようです。私のクイズアプリはうまくいきますが、一度に50の質問が多すぎることに気付きました。質問を別のグループに分ける

私のアプリは、「開始」と表示されているクイズを入力するボタンをクリックした人が動作します。クイズの後、彼らが間違っているすべての質問が正解で示されます。しかし、私がしたいのは、これらを10の質問にグループ化することです。そのため、「質問セット1」ボタン、「質問セット2」ボタンなどを選択してください。この質問セットに含まれる質問。

私は実際に質問を分けて、ロジックがまだ機能するようにはしていません。以下はデータベースヘルパークラスに含まれています。私はそれを短縮するために質問のほとんどを免除しました。どうもありがとうございます!

public class DbHelper extends SQLiteOpenHelper { 
    private static final int DATABASE_VERSION = 1; 
    // Database Name 
    private static final String DATABASE_NAME = "realEstateQuiz"; 
    // tasks table name 
    private static final String TABLE_QUEST = "quest"; 
    // tasks Table Columns names 
    private static final String KEY_ID = "questionId"; 
    private static final String KEY_QUES = "question"; 
    private static final String KEY_ANSWER = "answer"; // correct option 
    private static final String KEY_OPTA = "opta"; // option a 
    private static final String KEY_OPTB = "optb"; // option b 
    private static final String KEY_OPTC = "optc"; // option c 
    private static final String KEY_OPTD = "optd"; // option d 

    private SQLiteDatabase dbase; 

    public DbHelper(Context context) { 
     super(context, DATABASE_NAME, null, DATABASE_VERSION); 
    } 

    @Override 
    public void onCreate(SQLiteDatabase db) { 
     dbase = db; 
     String sql = "CREATE TABLE IF NOT EXISTS " + TABLE_QUEST + " (" + KEY_ID 
       + " INTEGER PRIMARY KEY AUTOINCREMENT, " + KEY_QUES + " TEXT, " + KEY_ANSWER + " TEXT, " + KEY_OPTA 
       + " TEXT, " + KEY_OPTB + " TEXT, " + KEY_OPTC + " TEXT," + KEY_OPTD + " TEXT)"; 
     db.execSQL(sql); 
     addQuestions(db); 
     // db.close(); 
    } 

    private void addQuestions(SQLiteDatabase db) { 
     Question q1 = new Question(
       "When a real estate professional exaggerates " + "about a parcel of property, they are likely:", 
       "Misrepresenting the property", "Guilty of fraud", "Puffing", "All of the above", "Puffing"); 
     this.addQuestion(q1, db); 

    } 

    @Override 
    public void onUpgrade(SQLiteDatabase db, int oldV, int newV) { 
     // Drop older table if existed 
     db.execSQL("DROP TABLE IF EXISTS " + TABLE_QUEST); 
     // Create tables again 
     onCreate(db); 
    } 

    // Adding new question 
    public void addQuestion(Question quest, SQLiteDatabase db) { 
     ContentValues values = new ContentValues(); 
     values.put(KEY_QUES, quest.getQuestion()); 
     values.put(KEY_ANSWER, quest.getAnswer()); 
     values.put(KEY_OPTA, quest.getOpta()); 
     values.put(KEY_OPTB, quest.getOptb()); 
     values.put(KEY_OPTC, quest.getOptc()); 
     values.put(KEY_OPTD, quest.getOptd()); 

     // Inserting Row 
     db.insert(TABLE_QUEST, null, values); 
    } 

    public List<Question> getAllQuestions() { 
     List<Question> quesList = new ArrayList<Question>(); 
     // Select All Query 
     String selectQuery = "SELECT * FROM " + TABLE_QUEST; 
     dbase = this.getReadableDatabase(); 
     Cursor cursor = dbase.rawQuery(selectQuery, null); 
     // looping through all rows and adding to list 
     if (cursor.moveToFirst()) { 
      do { 
       Question quest = new Question(); 
       quest.setQuestionId(cursor.getInt(0)); 
       quest.setQuestion(cursor.getString(1)); 
       quest.setAnswer(cursor.getString(2)); 
       quest.setOpta(cursor.getString(3)); 
       quest.setOptb(cursor.getString(4)); 
       quest.setOptc(cursor.getString(5)); 
       quest.setOptd(cursor.getString(6)); 
       quesList.add(quest); 
      } while (cursor.moveToNext()); 
     } 
     // return quest list 
     cursor.close(); 
     dbase.close(); 
     return quesList; 
    } 

    public int rowcount() { 
     int row = 0; 
     String selectQuery = "SELECT * FROM " + TABLE_QUEST; 
     SQLiteDatabase db = this.getWritableDatabase(); 
     Cursor cursor = db.rawQuery(selectQuery, null); 
     row = cursor.getCount(); 

     cursor.close(); 
     return row; 
    } 
} 
+0

単純に整数列( 'QuestionSet')を追加して、質問だけを取得することができます。... WHERE QuestionSet =?'、質問セットを渡します。明らかに、10の質問は1の値を持ち、他の10は2の値を持ちます。または0から始めることもできます(ただし、それは個人的な味であり、必ずしも機能的ではありません) –

答えて

0

あなたのQuestionオブジェクトと対応するテーブルには、それらがどの質問セットに属しているかを示す追加フィールドが含まれているようです。あなたのDbHelperクラスは、質問によって質問することができます。あるいは、あなたはすべての質問をjavaコードのセットで並べ替えることができますが、私はその質問をd​​bに任せています。

あなたは10のセットにすべての質問を分割したい場合しかし、あなたは次のようなものを試みることができる:

List<Set<Question>> questionSets = new ArrayList<Set<Question>>(); 
Set<Question> questionSet = new HashSet<Question>(); 
questionSets.add(questionSet); 

int counter = 0; 
for(Question question : dbHelper.getAllQuestions()){ 
    if(++counter > 10){ 
    counter = 0; 
    questionSet = new HashSet<Question>(); 
    questionSets.add(questionSet);    
    } 

    questionSet.add(question); 
} 

これがセットに10個の質問を収集し、質問のリストに追加されます設定します。そのリストから各質問セットにアクセスできます。