Java 在Android中编写数据库CRUD操作的更有效方法
我刚刚开始学习Android开发,我发现了一种在我的应用程序中编写模型、DAO和模式的非常好的方法。例如,我有一个Java 在Android中编写数据库CRUD操作的更有效方法,java,android,crud,dao,Java,Android,Crud,Dao,我刚刚开始学习Android开发,我发现了一种在我的应用程序中编写模型、DAO和模式的非常好的方法。例如,我有一个Category模型,其中包含表示数据库中表列的所有字段: public class Category { private int id; private String name; private String createdAt; // Getters and Setters } 然后,CategoryDao类将响应访问数据库并执行所有操作: p
Category
模型,其中包含表示数据库中表列的所有字段:
public class Category {
private int id;
private String name;
private String createdAt;
// Getters and Setters
}
然后,CategoryDao
类将响应访问数据库并执行所有操作:
package com.prettypenny.dao;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import com.prettypenny.model.Category;
import com.prettypenny.schema.CategorySchema;
import com.prettypenny.schema.DatabaseHandler;
import java.util.ArrayList;
/**
* Category D.A.O
*/
public class CategoryDao {
SQLiteOpenHelper helper;
SQLiteDatabase database;
private static final String[] columns = {
CategorySchema.COL_ID,
CategorySchema.COL_NAME,
CategorySchema.COL_CREATED_AT,
};
public CategoryDao(Context context) {
helper = new DatabaseHandler(context);
}
public void open() {
database = helper.getWritableDatabase();
}
public void close() {
helper.close();
}
/**
* Retrieve all Category
* @return ArrayList
*/
public ArrayList<Category> all() {
Cursor cursor = database.query(CategorySchema.TABLE_NAME, columns, null, null, null, null, null);
ArrayList<Category> categories = new ArrayList<>();
if (cursor.getCount() > 0) {
while (cursor.moveToNext()) {
Category category = new Category();
category.setId(cursor.getInt(cursor.getColumnIndex(CategorySchema.COL_ID)));
category.setName(cursor.getString(cursor.getColumnIndex(CategorySchema.COL_NAME)));
categories.add(category);
}
}
return categories;
}
/**
* Inserts a new Category
* @param category Category category to be inserted
* @return Category
*/
public Category insert(Category category) {
ContentValues values = new ContentValues();
values.put(CategorySchema.COL_NAME, category.getName());
database.insert(CategorySchema.TABLE_NAME, null, values);
return category;
}
/**
* Updates an existing Category
* @param category Category category to be updated
* @return int
*/
public int update(Category category) {
ContentValues values = new ContentValues();
values.put(CategorySchema.COL_NAME, category.getName());
return database.update(
CategorySchema.TABLE_NAME,
values,
CategorySchema.COL_ID + " = ?",
new String[] { String.valueOf(category.getId()) }
);
}
/**
* Deletes an existing Category
* @param id int id of the category to be deleted
*/
public void delete(int id) {
database.delete(
CategorySchema.TABLE_NAME,
CategorySchema.COL_ID + " = " + id,
null
);
}
}
例如,在
all()
方法中,现在的问题是要实例化的模型类,就像在CategoryDao中一样。all()
实例化Category
。是否可以在抽象类中实现,例如,执行类似于ArrayList
的操作,其中传递可能是任何类型的内容?使用任何语言处理数据库时,最大的挑战之一是数据库表和实体对象之间的关系映射
考虑到这一点,创建了称为ORM(对象关系映射)的库/框架
我的第一个建议是使用,但由于您已经使用SQLite,我的列表是:
- 糖类:
- ORM Lite:
- 绿岛:
- 活动Android:
- Android房间:(由Sajad Garshasbi建议)
您可以在和中找到它们之间的比较。我建议您看看谷歌的room方法。它仍然不稳定,你需要android studio 3.0,它仍然不稳定,但我没有注意到任何问题
与典型的备选方案相比,它具有非常有趣的优势,其中之一是在编译时检查SQL语句是否与db匹配。我不知道还有谁提供这个特殊功能 是否可以选择使用某种ORM,或者甚至是另一个便于实现的数据库?我有一些建议。我从未想过使用ORM,实际上我不知道有。但我实际上很想知道我的问题,如果可能的话,还有,对于我来说,学习Java更多。ORM是对象关系映射。它们是便于将实体作为对象进行管理的库。对于JavaEE来说,最流行的是Hibernate.search关于android Room如果你不想使用ORM,你可以通过反射来实现这一点,我认为这就是ORM的工作方式,所以你将重新发明轮子,但作为实验,这可能是一个很好的练习好的,有很多选择。我想通过反思来实现我的想法,以便更好地理解Java语言本身。谢谢。在Android上仔细思考。反思是缓慢和昂贵的。通常,在Android中,ORM使用代码生成来避免使用反射。祝你学习顺利。
abstract class Dao {
SQLiteOpenHelper helper;
SQLiteDatabase database;
public ArrayList<?> all(String tableName, String[] columns) {
Cursor cursor = database.query(tableName, columns, null, null, null, null, null);
ArrayList<?> entities = new ArrayList<>();
if (cursor.getCount() > 0) {
while (cursor.moveToNext()) {
// Oh shit.
}
}
return entities;
}
}