2012-02-21 108 views
0

我使用ormlite爲Android,我有以下型號Ormlite圖片更新問題

@DatabaseTable(tableName = DatabaseConstants.TABLE_ARTICLE) 
public class ArticleModel { 

@DatabaseField(generatedId = true, columnName = DatabaseConstants.ARTICLE_ID) 
public int id; 
@DatabaseField(columnName = DatabaseConstants.ARTICLE_NAME) 
public String name = ""; 

@DatabaseField(columnName = DatabaseConstants.ARTICLE_IMAGE_URL) 
public String imageUrl = ""; 

@DatabaseField(columnName = DatabaseConstants.ARTICLE_IMAGE,dataType= DataType.BYTE_ARRAY) 
public byte[] image; 

有可能如下更新的圖像:

ContentValues cv = new ContentValues(); 
cv.put(DatabaseConstants.ARTICLE_IMAGE, UtilBitmap.bitmapToByteArray(bitmap)); 

SQLiteDatabase sqLiteDatabase = this.baseHelper.getWritableDatabase(); 
sqLiteDatabase.update(DatabaseConstants.TABLE_ARTICLE, cv,   
DatabaseConstants.ARTICLE_MOBILE_IMAGE_URL + "= ?", new String[]{url}); 

不過是有一個ormlite方法更新到除以下代碼以外的字節數組:

updateBuilder.updateColumnValue(DatabaseConstants.ARTICLE_IMAGE,imageBytes); 
updateBuilder.where().eq(DatabaseConstants.ARTICLE_MOBILE_IMAGE_URL, url); 

問題是可以更新圖像u歌唱前一種方式,但不採用後一種方式,即使用後一種方式時,圖像未正確存儲在數據庫中。我使用sqliteviewer來檢查圖像是否存儲,並使用後一種方法失敗。有沒有更好的方法來更新字節數組(圖像)使用「ormlite」?

+0

我的回答有些幫助嗎?如果是的話,我會很感激+1和接受。 – Gray 2012-02-25 18:54:08

回答

0

你缺少的是使用ORMLiteSelectArg feature。當您看到指定SQL ?參數時,您使用SelectArg。所以,你的代碼將變成:

updateBuilder.updateColumnValue(DatabaseConstants.ARTICLE_IMAGE, 
    new SelectArg(imageBytes)); 
updateBuilder.where().eq(DatabaseConstants.ARTICLE_MOBILE_IMAGE_URL, url); 

SelectArg還允許你建立你的更新語句,然後多次設置參數執行SQL語句之前。因此,如果您反覆更新某個字段,則不必多次構建相同的更新語句。