2016-09-15 3 views
0

В настоящее время я беру каждый столбец на основе запроса и изменяя переменные на основе текущей позиции курсора. Мне было интересно, если можно было бы сократить размер кода, делая что-то вроде этого, когда другой вызов функции будет сделан на основе столбца в курсоре, который в настоящее время ссылаются:Использование функционального вызова на основе позиции курсора - Android

do { 
    Ticket ticket = new Ticket(); 
    for(int i = 0; i < cursor.getColumnCount(); i++) 
    { 
     if (cursor.getString(0) != null) { 
     /*Where the array contains a list of function calls*/ 
     ticket.arrayList(i); 
    } 
}while(cursor.moveToNext()); 

Ниже это код, который у меня есть. Из того, что я знаю, в Java нет ничего, что работает, но я пытаюсь сократить количество строк здесь, так как в конечном итоге у меня будет около ста столбцов, которые будут втянуты в курсор.

public List<Ticket> getTickets(Context context, SQLiteDatabase db) 
{ 
    List<Ticket> ticketInfo = new ArrayList<>(); 
    String selectQuery = "SELECT * FROM " + TABLE_TICKET; 

    Cursor cursor = null; 


    try { 
     cursor = db.rawQuery(selectQuery, null); 
     if (cursor != null) { 
      try { 
       if (cursor.moveToFirst()) { 
        do { 
         Ticket ticket = new Ticket(); 
         //Set the ticket number 
         if (cursor.getString(0) != null) { 
          ticket.setTicketNr(Integer.parseInt(cursor.getString(0))); 
         } 
         //Set the ticket id 
         if (cursor.getString(1) != null) { 
          ticket.setTicketId(Integer.parseInt(cursor.getString(1))); 
         } 
         // 
         if (cursor.getString(2) != null) { 
          ticket.setServiceName(cursor.getString(2)); 
         } 
         // 
         if (cursor.getString(3) != null) { 
          ticket.setServiceHouseNr(Integer.parseInt(cursor.getString(3))); 
         } 
         // 
         if (cursor.getString(4) != null) { 
          ticket.setServiceDirectional(cursor.getString(4)); 
         } 
         // 
         if (cursor.getString(5) != null) { 
          ticket.setServiceStreetName(cursor.getString(5)); 
         } 
         // 
         if (cursor.getString(6) != null) { 
          ticket.setServiceCommunityName(cursor.getString(6)); 
         } 
         // 
         if (cursor.getString(7) != null) { 
          ticket.setServiceState(cursor.getString(7)); 
         } 
         // 
         if (cursor.getString(8) != null) { 
          ticket.setServiceZip1(Integer.parseInt(cursor.getString(8))); 
         } 
         // 
         if (cursor.getString(9) != null) { 
          ticket.setServiceZip2(Integer.parseInt(cursor.getString(9))); 
         } 
         // 
         if (cursor.getString(10) != null) { 
          ticket.setTroubleReported(cursor.getString(10)); 
         } 
         // Adding exercise to list 
         if (ticket != null) { 
          ticketInfo.add(ticket); 
         } 

        } while (cursor.moveToNext()); 
       } else { 
        //No results from query 
        Toast.makeText(context.getApplicationContext(), "No tickets found", Toast.LENGTH_LONG).show(); 
       } 

      } finally { 
       if (cursor != null && !cursor.isClosed()) { 
        cursor.close(); 
       } 
      } 
     } 
    } 
    catch(SQLiteException exception)//If exception is found 
    { 
     Log.d(TAG, "Error", exception); 
     //Display exception 
     Toast.makeText(context.getApplicationContext(), exception.toString(), Toast.LENGTH_LONG).show(); 
    } 

    return ticketInfo; 
} 

Благодарим за понимание.

ответ

1

Я думаю, что это сделало бы это. Просто переместите курсор и передайте его в конструктор Ticket. Вы можете добавить некоторую проверку ошибок.

public class Ticket { 

    private static class Field { 
     int intValue; 
     String stringValue; 
     final Class type; 

     Field(Class fieldType){ 
      type = fieldType; 
     } 

     void set(String value){ 
      if(type.equals(String.class)){ 
       stringValue = value; 
      } 
      else { 
       intValue = Integer.parseInt(value); 
      } 
     } 
    } 

    private List<Field> fields = new ArrayList<>(); 

    private Field addField(Field field){ 
     fields.add(field); 
     return field; 
    } 

    // This solution relies on adding fields in the order they'll be retrieved in the cursor. 
    // Other options are possible such as a map by column index. 
    private Field ticketNumber = addField(new Field(Integer.class)); 
    private Field serviceName = addField(new Field(String.class)); 

    public Ticket(Cursor cursor){ 
     for(int i=0; i < fields.size(); i++){ 
      Field f = fields.get(i); 
      f.set(cursor.getString(i)); 
     } 
    } 
} 

public int getTicketNumber(){ 
    return ticketNumber.intValue; 
} 

// Don't know if you need setters 
public void setTicketNumber(int value){ 
    ticketNumber.intValue = value; 
} 

// etc for remaining fields 

Я также хотел бы использовать ORM, чтобы сделать этот материал проще, чем иметь дело с курсорами.

+0

Большое вам спасибо! С некоторыми изменениями в моем классе DatabaseHandler я смог заставить ваше решение работать. –