如何将图片存入sqlite数据库

前两天有人在校论坛上问过,我搜了些相关信息,然后自己总结了一个做法,记录如下,以备日后使用

 

1.将图片转化为byte数组
2.将byte数组放入contentvalues
3.执行数据库的insert操作,将contentvalues里面的值存入sqlite
代码大致如下:
//转换
Bitmap bm = BitmapFactory.decodeResource(getResources(), R.drawable.icon);
         ByteArrayOutputStream baos = new ByteArrayOutputStream();    
         bm.compress(Bitmap.CompressFormat.PNG, 100, baos);    
         byte[] result = baos.toByteArray();  
//装入
ContentValues values = new ContentValues();
values.put("image", result);
//插入数据库
db.insert("image_info", "image", values);

要将数据存入SQLite数据库,您可以按照以下步骤操作: 1. 首先,在您的Android Studio项目中创建一个SQLite数据库的帮助类(SQLiteOpenHelper)。 2. 创建一个数据模型类,该类包含要存储的数据的属性。 3. 在数据库帮助类中,创建一个表格,该表格定义了数据模型类的属性以及它们的数据类型。 4. 实现向数据库中插入数据的方法,该方法将使用SQLiteOpenHelper的getWritableDatabase()方法打开数据库并将数据插入到表格中。 以下是一个示例代码,展示了如何将数据存入SQLite数据库: 首先,创建一个数据模型类,例如Person.java: ``` public class Person { private int id; private String name; private int age; public Person(int id, String name, int age) { this.id = id; this.name = name; this.age = age; } public int getId() { return id; } public String getName() { return name; } public int getAge() { return age; } } ``` 然后,在数据库帮助类中,创建一个表格,例如PersonTable.java: ``` public class PersonTable { public static final String TABLE_NAME = "person"; public static final String COLUMN_ID = "id"; public static final String COLUMN_NAME = "name"; public static final String COLUMN_AGE = "age"; public static final String CREATE_TABLE = "CREATE TABLE " + TABLE_NAME + " (" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_NAME + " TEXT, " + COLUMN_AGE + " INTEGER)"; } ``` 最后,在数据库帮助类中,实现向数据库中插入数据的方法,例如DBHelper.java: ``` public class DBHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "mydatabase.db"; private static final int DATABASE_VERSION = 1; public DBHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(PersonTable.CREATE_TABLE); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // Upgrade logic here } public void addPerson(Person person) { SQLiteDatabase db = getWritableDatabase(); ContentValues values = new ContentValues(); values.put(PersonTable.COLUMN_NAME, person.getName()); values.put(PersonTable.COLUMN_AGE, person.getAge()); db.insert(PersonTable.TABLE_NAME, null, values); db.close(); } } ``` 现在,您可以在应用程序的任何地方创建一个DBHelper对象,并调用addPerson()方法,将Person对象插入到数据库中: ``` DBHelper dbHelper = new DBHelper(context); Person person = new Person(1, "John", 30); dbHelper.addPerson(person); ``` 这是将数据存入SQLite数据库的基本过程。请注意,在实际应用中,您可能需要使用更复杂的查询来检索数据,或者使用更复杂的数据模型来存储数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值