我应该使用哪种数据类型在sqlLite数据库表中存储图像?
以下是我的尝试:
@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
db.execSQL("CREATE TABLE" + MP_TABLE_NAME + " ( " +
BaseColumns._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
" NAME TEXT, " +
" LAT REAL, "+
" LNG REAL,"+
");"
);
}
Run Code Online (Sandbox Code Playgroud)
小智 10
试试这个..
使用BLOB列创建表:
CREATE TABLE storedImages (_id INTEGER PRIMARY KEY, myImage BLOB);
Run Code Online (Sandbox Code Playgroud)
使用HTTP下载图像并将其存储在表中:
DefaultHttpClient mHttpClient = new DefaultHttpClient();
HttpGet mHttpGet = new HttpGet("your image url");
HttpResponse mHttpResponse = mHttpClient.execute(mHttpGet);
if (mHttpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
HttpEntity entity = mHttpResponse.getEntity();
if (entity != null) {
// insert to database
ContentValues values = new ContentValues();
values.put(MyBaseColumn.MyTable.ImageField, EntityUtils.toByteArray(entity));
getContentResolver().insert(MyBaseColumn.MyTable.CONTENT_URI, values);
}
}
Run Code Online (Sandbox Code Playgroud)
将BLOB加载到ImageView中:
ImageView myImage = (ImageView) findViewById(R.id.myImage);
byte[] bb = cursor.getBlob(cursor.getColumnIndex(MyBaseColumn.MyTable.ImageField));
myImage.setImageBitmap(BitmapFactory.decodeByteArray(bb, 0, bb.length));
Run Code Online (Sandbox Code Playgroud)
小智 5
将图像保存到Sqlite是个坏主意.您应该将其路径保存到sqlite.与文本信息相比,图像的大小很大.
从sqlite保存和检索图像会很困难.
因此,我建议您将图像存储在外部文件夹中,并将其路径存储到sqlite数据库中.
| 归档时间: |
|
| 查看次数: |
24623 次 |
| 最近记录: |