Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/220.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在Android中编写数据库CRUD操作的更有效方法_Java_Android_Crud_Dao - Fatal编程技术网

Java 在Android中编写数据库CRUD操作的更有效方法

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

我刚刚开始学习Android开发,我发现了一种在我的应用程序中编写模型、DAO和模式的非常好的方法。例如,我有一个
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;
    }
}