gpt4 book ai didi

java - 直接在 SQLite 数据库中使用 getter 和 setter

转载 作者:行者123 更新时间:2023-11-30 00:58:23 26 4
gpt4 key购买 nike

我有一个应用程序需要跨各种 fragment 和 Activity 进行大量用户输入。现在我在一个类中拥有所有变量,我们称之为“报告”,我传递主键以确切知道我在什么“报告”中。(开始时有一个 ListView,用户可以在其中选择他们想要的报告进行更改)由于所有用户输入最终都必须写入数据库我有一个想法 - 为什么不从 Report 中删除所有变量并用静态最终列名替换它们,只留下主键变量,然后使用 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.
}
}

在 Activity/fragment 中我会这样做

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 中保存当前的主键(从 ListView 中选择的一个用户),然后在我需要使用它的每个 Activity/fragment 中从中创建一个新的报告,而不会占用太多内存

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

    <
  • 对于每个 Activity/fragment ,只有实际显示在屏幕上的字段会在 onCreate 中从数据库中检索

  • 更少的代码? (例如,我的数据库助手中只需要 get/setInt 和 get/setString 方法,我不需要在 Activity/fragment 之间传递任何东西,只需要一个 TextWatcher 类)

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

  • 持续读取和写入数据库 - 电池使用和速度可能有问题?

  • ???

最佳答案

目前你是:

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

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

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

关于java - 直接在 SQLite 数据库中使用 getter 和 setter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39813872/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com