以論壇為例,只緩存最新的20條帖子 用到sqlite
流程:
1. 創建資料庫檔案和表
db.execSQL("CREATE TABLE table"
"(_id INTEGER PRIMARY KEY AUTOINCREMENT,subject VARCHAR(200),author VARCHAR(20), dateline VARCHAR(20),replies VARCHAR(20),tid VARCHAR(20)";
 
2. 查詢、插入、刪除
 
//插入
public static void insert(SQLiteDatabase db, ContentValues values)
{
db.insert(」reclist「, null, values);
}
//刪除
public static void delete(SQLiteDatabase db)
{
db.delete(」reclist「, null, null);
}
//查詢前先建PostInfo封裝類,把得到的資料添加到ArrayList容器裡
//查詢
public static ArrayList<PostInfo> query(SQLiteDatabase db)
{
Cursor cursor = db.query("reclist", null, null, null,
null, null, null);
ArrayList<PostInfo> data = new ArrayList<PostInfo>();
boolean hasNext = cursor.moveToFirst();
while (hasNext)
{
String author = cursor.getString(cursor
.getColumnIndex("author "));
String dateline = cursor.getString(cursor
.getColumnIndex("dateline"));
String replies = cursor.getString(cursor
.getColumnIndex("replies"));
String subject = cursor.getString(cursor
.getColumnIndex("subject"));
int tid = cursor.getInt(cursor
.getColumnIndex("tid"));
PostInfo info = new PostInfo(subject, author, dateline, replies,
tid);
data.add(info);
hasNext = cursor.moveToNext();
}
cursor.close();
return data;
}
 
 
3. 得到最新20條時,刪除資料庫表的內容 ,再插入
4. 啟動時查詢資料庫
5. 如果有網路,從網路獲取最新內容後,清空ListView,使用最新內容
 
 
 
//把查詢到的內容添加到集合去
ArrayList<PostInfo> query = DataBaseUtils.query(mDB);
if (query.size() > 0)
{
mPostInfoList.addAll(query);
}
//在jsonArray解析的時候刪除前面的內容
JSONArray array = new JSONArray(result);
if (array.length() > 0 && mPage == 1)
{
mPostInfoList.clear();
}
for (int i = 0; i < array.length(); i++)
{
JSONObject jsonObject = array.getJSONObject(i);
int tid = jsonObject.getInt("tid");
String hottopic_title = jsonObject.getString("subject");
String hottopic_name = jsonObject.getString("author");
String hottopic_shijian = jsonObject.getString("dateline");
String hottopic_huiying = jsonObject.getString("replies");
downloadData = new PostInfo(hottopic_title, hottopic_name,
hottopic_shijian, hottopic_huiying, tid);
mPostInfoList.add(downloadData);
}
if (mPage == 1)
{
//刪除舊的資料
DataBaseUtils.delete(mDB);

 

//將最新20條保存到資料庫中
for (int i = 0; i < mPostInfoList.size(); i++)
{
PostInfo info = mPostInfoList.get(i);
ContentValues values = new ContentValues();
values .put(TABLE_RECLIST.COLUMN_AUTHOR, info.getAuthor());
values.put(TABLE_RECLIST.COLUMN_DATELINE, info.getDateline());
values.put(TABLE_RECLIST.COLUMN_REPLIES, info.getReplies());
values.put(TABLE_RECLIST.COLUMN_SUBJECT, info.getSubject());
values.put(TABLE_RECLIST.COLUMN_TID, info.getTid());
DataBaseUtils.insert(mDB, values );
}
}
mAdapter.notifyDataSetChanged();
 
 
本文出自 “Android添加权限” 博客,请务必保留此出处http://henrytong.blog.51cto.com/8603737/1384090
創作者介紹
創作者 shadow 的頭像
shadow

資訊園

shadow 發表在 痞客邦 留言(0) 人氣()