Dears 我如何Android可以保存图像并从Sqlite数据库获取图像我使用Android Studio?Android保存并从Sqlite数据库中获取图像
1
A
回答
0
您可以查看本教程以在Android中实现Sqlite。 http://www.androidhive.info/2011/11/android-sqlite-database-tutorial/
而是与联系,例如工作,可以实现这样
public class Image{
String imagePath; //it is your absolute image file path
}
而且你DatabaseHandler
可以像下面
public class DatabaseHandler extends SQLiteOpenHelper {
// All Static variables
// Database Version
private static final int DATABASE_VERSION = 1;
// Database Name
private static final String DATABASE_NAME = "imagedb";
// Contacts table name
private static final String TABLE_IMAGE = "images";
// Contacts Table Columns names
private static final String KEY_ID = "id";
private static final String KEY_IMAGE_PATH = "name";
public DatabaseHandler(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
// Creating Tables
@Override
public void onCreate(SQLiteDatabase db) {
String sqlQuery = "CREATE TABLE " + TABLE_IMAGE + "("
+ KEY_ID + " INTEGER PRIMARY KEY," + KEY_IMAGE_PATH + " TEXT)";
db.execSQL(sqlQuery);
}
// Upgrading database
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// Drop older table if existed
db.execSQL("DROP TABLE IF EXISTS " + TABLE_IMAGE);
// Create tables again
onCreate(db);
}
// Adding new image
public void addImage(Image image) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(KEY_IMAGE_PATH, image.imagePath); // Image path
// Inserting Row
db.insert(TABLE_IMAGE, null, values);
db.close(); // Closing database connection
}
// Getting single image
public Image getImage(int id) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.query(TABLE_IMAGE, new String[] { KEY_ID,
KEY_IMAGE_PATH}, KEY_ID + "=?",
new String[] { String.valueOf(id) }, null, null, null, null);
if (cursor != null)
cursor.moveToFirst();
Image image = new Image(Integer.parseInt(cursor.getString(0)),
cursor.getString(1));
// return image
return image;
}
}
+0
我想他想存储整个图像对象进入数据库,而不是图像路径。 –
+0
谢谢@ᖷAIAAƸ。我以为他在问一个sqlite教程。 – thuongle
1
可能为时已晚来实现。但对未来的读者有用..
import android.content.Context;
import android.database.Cursor;
import android.database.DatabaseUtils;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteStatement;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import java.util.HashMap;
/**
* Created by Noorul on 23-05-2016.
*/
@SuppressWarnings("ALL")
public class DBSplash extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "SplashDB.db";
public static final String SPLASH_TABLE_NAME = "splash_db";
private HashMap hp;
public DBSplash(Context context) {
super(context, DATABASE_NAME, null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(
"create table " + SPLASH_TABLE_NAME + "(name TEXT, image BLOB)"
);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
db.execSQL("DROP TABLE IF EXISTS contacts");
onCreate(db);
}
public boolean insertImage(String name, Bitmap img) {
Bitmap storedBitmap = null;
String sql = "INSERT INTO " + SPLASH_TABLE_NAME + " (name,image) VALUES(?,?)";
SQLiteDatabase db = this.getWritableDatabase();
SQLiteStatement insertStmt = db.compileStatement(sql);
byte[] imgByte = getBitmapAsByteArray(img);
try {
storedBitmap = getImage(name);
} catch (Exception e) {
AppLog.exception(e);
}
if (storedBitmap == null) {
insertStmt.bindString(1, name);
insertStmt.bindBlob(2, imgByte);
insertStmt.executeInsert();
db.close();
}
return true;
}
public int numberOfRows() {
SQLiteDatabase db = this.getReadableDatabase();
int numRows = (int) DatabaseUtils.queryNumEntries(db, SPLASH_TABLE_NAME);
return numRows;
}
public Bitmap getImage(String name) {
String qu = "SELECT * FROM " + SPLASH_TABLE_NAME;
Cursor cur = null;
SQLiteDatabase db = this.getReadableDatabase();
try {
cur = db.rawQuery(qu, new String[]{});
} catch (Exception e) {
AppLog.exception(e);
}
if (cur != null) {
if (cur.moveToFirst()) {
int index = cur.getColumnIndexOrThrow("image");
byte[] imgByte = cur.getBlob(index);
cur.close();
return BitmapFactory.decodeByteArray(imgByte, 0, imgByte.length);
}
if (cur != null && !cur.isClosed()) {
cur.close();
}
}
return null;
}
public byte[] getBitmapAsByteArray(Bitmap bitmap) {
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.JPEG, 0, outputStream);
return outputStream.toByteArray();
}
}
使用此代码。但是将图像存储在数据库中并不是最佳实践。如果您需要未映射的图像,请更改图像大小。图像具有高内存的blob类型。手机是更小的设备。所以在sqlite数据库中存储很多图像意味着,这将是丑陋的。所以使用@thuongle方法
相关问题
- 1. 保存图像在SQLite数据库从web服务获取
- 2. Android设置并从列表中获取值并保存到数据库sqlite
- 3. 在SQLite数据库中保存图像
- 4. 如何保存并从Sqlite数据库检索图像?
- 5. 从数据库中获取图像android
- 6. 从Android的SQLite数据库保存图像
- 7. 从SQLite数据库中获取图像并将其显示到GridView Android Studio
- 8. 如何从MySQL中获取数据并存储在Sqlite数据库中android
- 9. android sqlite保存数据库或路径中的图像
- 10. 如何在android中将图像保存到SQLite数据库?
- 11. 使用PHP从远程SQL数据库获取图像到Android SQLite数据库
- 12. 从服务器URL保存图像在SQLite数据库中
- 13. 如何从sqlite数据库获取数据,并在Android的
- 14. 从android获取本地sqlite数据库
- 15. 从SD卡中获取图像并将其存储在Android数据库中
- 16. 阅读并保存图像到SQLite数据库
- 17. 保存图像android sqlite
- 18. 如何从中心数据库中获取数据并存储在android sqlite数据库中?
- 19. 将图像从UIImagePicker保存到Sqlite数据库
- 20. 将图像从URL保存到SQLITE数据库
- 21. Android:将图像保存到数据库
- 22. Android sqlite数据库从列表视图中获取ID
- 23. 如何从ANDROID中的sqlite数据库中获取数据?
- 24. 从sqlite数据库中获取图像并使用JavaScript在页面上显示
- 25. 从数据库中获取的图像
- 26. 从数据库中获取图像
- 27. 保存图像并从数据库中检索
- 28. 从服务器下载图像并保存到数据库中
- 29. Android的SQLite数据库保存
- 30. 无法从Android中的Sqlite数据库获取数据
将图像转换为** Base 64 String **,然后将其存储到数据库中,并在取图像时反之亦然。有关Android中的Base 64 API,请参阅[this](http://developer.android.com/reference/android/util/Base64.html)。 –
如果要将二进制文件存储到sqlite中,请将其保存为blob类型。 也许这个链接可以帮助你:http://stackoverflow.com/questions/7331310/how-to-store-image-as-blob-in-sqlite-how-to-retrieve-it – thuongle