2015-10-04 115 views
1

我正在研究一个Android应用程序,该应用程序在从服务器获取数据后显示学生的成绩。退出时,应用会将数据保存在本地数据库中,以便在下次启动时重新加载数据。要存储我创建了两个表的数据,学生和课程。学生课程表有一对多的关系应用程序不显示从Android数据库加载的数据

我创建了一个自定义的AsyncTaskLoader来加载数据。两个类扩展了这个自定义加载器,一个叫做StudentLoader,它从学生表中加载学生数据,另一个叫CourseLoader,它从课程表中为特定学生加载课程(在课程表中有一个学生ID外键)。

下面是自定义的加载类

//Student Loader Class 
public class StudentLoader extends DataLoader<Student> { 

    private String mSid; 
    private StudentDbAdapter dbAdapter; 


    public StudentLoader(Context context, String sid) { 
     super(context); 
     mSid = sid; 
     dbAdapter = new StudentDbAdapter(context); 
    } 


    @Override 
    public Student loadInBackground() { 
     return dbAdapter.queryStudent(mSid); 
    } 
} 

//Course Loader class 
public class CoursesLoader extends DataLoader<ArrayList<Course>> { 

    private long mId; 
    private StudentDbAdapter dbAdapter; 

    public CoursesLoader(Context context, long id) 
    { 
     super(context); 
     mId = id; 
     dbAdapter = new StudentDbAdapter(context); 
    } 

    @Override 
    public ArrayList<Course> loadInBackground() { 
     return dbAdapter.getCourses(mId); 
    } 
} 

在启动时,我用了两个LoaderCallback类异步(并分别)加载两个学生和课程数据和更新基于返回的结果的UI。我将LoaderCallback类放入显示学生成绩的片段中。

这里有LoaderCallback类

private class StudentLoaderCallbacks implements LoaderManager.LoaderCallbacks<Student>{ 


     @Override 
     public Loader<Student> onCreateLoader(int i, Bundle bundle) { 
      return new StudentLoader(getActivity(), mId); 
     } 

     @Override 
     public void onLoadFinished(Loader<Student> loader, Student student) { 
      mStudent = student; 
      Log.d(TAG, "Finished Loading data..."); 
      updateUI(mStudent); 
     } 

     @Override 
     public void onLoaderReset(Loader<Student> loader) { 

     } 
    } 

    private class CoursesLoaderCallbacks implements LoaderManager.LoaderCallbacks<ArrayList<Course>> 
    { 

     @Override 
     public Loader<ArrayList<Course>> onCreateLoader(int i, Bundle bundle) { 
      return new CoursesLoader(getActivity(), _id); 
     } 

     @Override 
     public void onLoadFinished(Loader<ArrayList<Course>> loader, ArrayList<Course> courses) { 
      mStudent.setCourses(courses); 
     } 

     @Override 
     public void onLoaderReset(Loader<ArrayList<Course>> loader) { 

     } 
    } 

应用程序加载,但不显示视图,只提出一个空白屏幕。这是updateUI方法,用于在数据加载后更新UI。

updateUI方法

private void updateUI(Student student) 
    { 
     if (student == null) 
     { 
      showProgressDialog(true); 
      return; 
     } 
     showProgressDialog(false); 
     ArrayList<StudentVm> studentVms = new ArrayList<>(); 
     ArrayList<Course> courses = student.getCourses(); 
     for (Course course : courses) { 
      StudentVm studentVm = new StudentVm(student.getmId(), course.getName(), Integer.valueOf(course.getCredit()).toString(), course.getGrade()); 
      studentVms.add(studentVm); 
     } 

     Log.d(TAG, "About to display data..."); 

     GradeListAdapter gradeAdapter = new GradeListAdapter(studentVms); 
     setListAdapter(gradeAdapter); 

    } 

什么是保持从显示数据的片段?有谁之前经历过这个吗?如何解决这个问题?

编辑1: 下面是从数据库中装载学生数据的方法:

public Student queryStudent(String id) 
    { 
     Student stu = new Student(); 
     Cursor cursor = db.query(DbConstants.STU_TABLE, 
       null, // all columns 
       DbConstants.STU_COLUMN_ID + "= ?", // look for a student ID 
       new String[]{id}, // with this value 
       null, // group by 
       null, // order by 
       null, // having 
       "1"); // limit 1 row) 

     cursor.moveToFirst(); 
     int _id = 0; 
     while (!cursor.isAfterLast()) 
     { 
      _id = cursor.getInt(cursor.getColumnIndex("_id")); 
      stu.setmId(cursor.getString(cursor.getColumnIndexOrThrow(DbConstants.STU_COLUMN_ID))); 
      stu.setFull_name(cursor.getString(cursor.getColumnIndexOrThrow(DbConstants.COLUMN_FNAME))); 
      stu.setAcademic_year(cursor.getInt(cursor.getColumnIndexOrThrow(DbConstants.COLUMN_ACYEAR))); 
      stu.setDepartment(cursor.getString(cursor.getColumnIndexOrThrow(DbConstants.COLUMN_DEPT))); 
      stu.setYear(cursor.getInt(cursor.getColumnIndexOrThrow(DbConstants.COLUMN_YEAR))); 
     } 

     cursor.close(); 
     stu.set_id(_id); 
     return stu; 
    } 

另外,logcat的持续显示以下消息之后我关闭该应用程序在模拟器。

Logcat message

+0

可能是数据库关闭了? – 2015-10-04 13:17:50

+0

你的意思是服务器数据库?如果是这样,我在首次启动时存储学生和课程数据后,从Android设备的本地数据库加载数据。我再次重新启动应用程序后出现问题。 – avidProgrammer

+0

当您再次重新启动应用程序时,数据未加载? – 2015-10-04 13:22:43

回答

0

后再次分析代码,我发现该错误是一个相当简单的错误这是我忘了在其中学生数据加载while循环添加cursor.moveToNext()。这导致了一个无限循环,它阻止了应用程序加载数据。

相关问题