直接使用SQLite DB使用getter和setter

时间:2016-10-02 04:29:08

标签: java android sqlite

我有一个应用程序,需要在各种片段和活动中输入大量用户。现在我将所有变量放在一个类中,然后调用它" Report"我绕过主键确切地知道"报告"我在。(在开始时有一个ListView,用户选择他们想要更改的报告) 由于最终必须将所有用户输入写入数据库,我有一个想法 - 为什么不从报告中删除所有变量并用静态最终列名替换它们,只留下主键变量,然后使用getter和setter来直接读取和写入数据库?这是一个很好的设计使用还是有任何我缺少的缺点? 作为一个相对缺乏经验的Android开发人员,我要求我提出任何建议。

示例(对不起,如果我从手机上写这个错误的话):

public class Report {
    private int primaryKey;
    private SQLiteDBHelper db;

    private static final String ColumnA = "columnA";
    private static final String ColumnB = "columnB";
    private static final String ColumnC = "columnC";
    // lets say columns A and B are Strings and C is an int

    public Report(int primaryKey, Context ctx) {
        this.primaryKey = primaryKey;
        this.db = new SQLiteDBHelper(ctx);
    }
    public String getColumnA() {
        return db.getString(primaryKey, ColumnA)
    }
    public boolean setColumnA(String value) {
        return db.setString(primaryKey, ColumnA, value);
    }
    public String getColumnB() {
        return db.getString(primaryKey, ColumnB)
    }
    public boolean setColumnB(String value) {
        return db.setString(primaryKey, ColumnB, value);
    }
    public String getColumnC() {
        return String.valueOf(db.getInt(primaryKey, ColumnC));
    }
    public boolean setColumnC(String value) {
        return db.setInt(primaryKey, ColumnC, Helper.tryParseInt(value));
    }
}

然后我可以像这样扩展TextWatcher:

public MyTextWatcher extends TextWatcher  {
    private View view;
    private Report report;
    public MyTextWatcher(View view, Report report) {
        this.view = view;
        this.report = report;
    }
    public void afterTextChanged(Editable editable) {
        String input = editable.toString();
        switch(view.getId()) {
            case R.id.columnA:
                if (!report.setColumnA(input)) {
                    // something went wrong
                }
            ... etc.
    }
}

在活动/片段中,我会这样做

int primaryKey = get from shared pref;
Report report = new Report(primaryKey, getApplication());
EditText columnA = (EditText) v.findViewById(R.id.columnA);
EditText columnB = (EditText) v.findViewById(R.id.columnB);
columnA.setText(report.getColumnA());
columnB.setText(report.getColumnB());
columnA.addTextChangedListener(new MyTextWatcher(columnA, report));
columnB.addTextChangedListener(new MyTextWatcher(columnB, report));

为什么我认为这是一个好主意:

  • 我可以在SharedPreferences中保存当前的primaryKey(从ListView中选择的一个用户),然后在我需要使用它的每个活动/片段中从中创建一个新报告,而不会占用太多内存

  • 我可以确保用户输入的内容与数据库中的内容之间不存在任何差异 - 例如,在EditTexts上,我可以为OnTextChanged侦听器中的每一列调用相应的setter

  • 对于每个活动/片段,只有在onCreate

  • 中从数据库中检索屏幕上实际显示的字段
  • 更少的代码? (比如我在DB帮助器中只需要get / setInt和get / setString方法,我不需要在活动/片段之间传递任何东西,只需要一个TextWatcher类)

为什么我认为这种做法可能不好:

  • 不断读取和写入数据库 - 电池使用情况和速度可能有问题吗?

  • ???

1 个答案:

答案 0 :(得分:1)

目前你是:

  • 每次文本更改时写入数据库 - 就像用户一样 键入每个字符或删除字符,记录正在 保存。这甚至不等待用户完成,这太过分了 保存文字。更好的选择是等到用户移动 到另一个小部件 - 暗示他已完成EditText上的输入。 您可以使用OnFocusChangeListener(更多信息: How can i know when a edittext lost focus

  • 在UI线程上对数据库进行大量写入调用。你
    如果可能的话,应该将其委托给后台。

  • 当用户主动与应用互动时,Android不会终止前台进程。您不必担心数据丢失。如果需要,您可以等待应用暂停。