- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在做一些测试,每次我调用 SQLiteOpenHelper.close()然后我尝试重新打开数据库,例如 SQLiteOpenHelper.getWritableDatabase()我得到异常 java.lang.IllegalStateException: attempt to re-open an already-closed object: SQLiteDatabase
有什么方法可以重新打开数据库吗?或者我应该重新创建 SQLiteOpenHelper 对象?
这是代码,它在第二次调用方法 getNoteCount 时崩溃
public DBController(Context ctx) {
this.mContext = ctx.getApplicationContext();
mDbHelper = new OpenHelper(mContext);
}
public int getNoteCount(){
SQLiteDatabase mDb =mDbHelper.getWritableDatabase();
Cursor c= mDb.query("notes", null, null, null, null, null, null);
int result=c.getCount();
c.close();
mDb.close();
return result;
}
private static class OpenHelper extends SQLiteOpenHelper {
DatabaseHelper(Context ctx) {
super(ctx, DB_NAME, null, DB_VERSION);
}
............
}
我正在考虑做这样的事情:
public abstract class DBHelper {
private SQLiteOpenHelper openHelper;
private int openCount = 0;
protected abstract SQLiteOpenHelper newSQLiteOpenHelper();
public void openDatabase() {
open();
}
public void closeDatabase() {
close();
}
protected synchronized SQLiteDatabase open() {
if (openHelper == null) {
openHelper = newSQLiteOpenHelper();
}
openCount++;
return openHelper.getWritableDatabase();
}
protected synchronized void close() {
openCount--;
if (openCount == 0) {
openHelper.close();
openHelper = null;
}
}
}
然后这样使用
public class DBController extends DBHelper{
public DBController(Context ctx) {
this.mContext = ctx.getApplicationContext();
}
@Override
protected SQLiteOpenHelper newSQLiteOpenHelper() {
return new OpenHelper(mContext);
}
public int getNoteCount(){
SQLiteDatabase mDb =open();
Cursor c= mDb.query("notes", null, null, null, null, null, null);
int result=c.getCount();
c.close();
close();
return result;
}
}
最佳答案
据我所知,在应用程序被销毁之前,您不应该关闭数据库。参见 Android error - close() was never explicitly called on database
关于java - SQLiteOpenHelper 和关闭方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16615431/
我是 Android 开发的新手(坦率地说是整体开发),因此我一直在阅读 Commonsware Busy Coder 的指南。在阅读 SQLite 部分时,有几件事对我来说不是 %100 清楚。以下
我正在尝试在 Sqlite 数据库 中添加当前位置的纬度和经度。但是当我打开我的 Activity 时,它会崩溃并显示 android.database.sqlite.SQLiteOpenHelper
我无法理解我是如何错误地初始化数据库的: java.lang.NullPointerException at android.database.sqlite.SQLiteOpenHel
我有两个 Activity 和多个数据库类,我想在从 Activity1 到 Activity2 时传递附加信息中的数据库类名称,并在 Activity2 中加载 DatabaseAdapter 类。
我正在为我的(初学者/Android)应用程序实现一个数据库。 我不清楚是否 SQLiteOpenHelper 旨在创建数据库(物理上,写入.db/.sql 文件) super() 或者如果仍然由我来
我正在做一些测试,每次我调用 SQLiteOpenHelper.close()然后我尝试重新打开数据库,例如 SQLiteOpenHelper.getWritableDatabase()我得到异常 j
新手Q来自iPhone/MonoTouch C#背景 我有一个来自另一个项目的现有 SQLite 数据库文件。 我在哪里将数据库文件包含到我的 Eclipse 项目中以使其与应用程序一起部署。 我需要
我正在研究 Android SDK,以期为 friend 编写一个简单的应用程序(并且可能用于销售)。 此应用程序将在数据库中搜索关键字并将结果显示在屏幕上,我已经查看了 searchabul 词典和
如果一个应用程序中的多个 Activity 调用我的 SQLiteOpenHelper 的构造函数并将它们自己作为上下文参数,我可以确定它们都将访问同一个数据库吗? 例如,假设我有: package
我不知道是什么锁定了我的数据库。这个应用程序在生产中是全新的,我什至无法执行第一个将用户添加到数据库的操作。我有一个 DatabaseHandler 可以执行所有数据库操作。我的 Activity 正
通常,在 Activity 中,我是这样使用SQLiteOpenHelper DatabaseHandler mDbHelper = new DatabaseHandler(getBaseContex
我想用一些额外的方法(比如 getStreetsCursor)制作 SQLiteOpenHelper,这些方法从我的数据库返回数据。所以我写了这样的东西: public class DBHelper
我为学生创建了一个包含姓名、姓氏、分数字段的数据库,我确实成功地插入和查看了但我不知道如何进行更新和删除。 请在这里帮助我想根据ID进行更新和删除。 最佳答案 在 DatabaseHandler 类中
首先,我是 Android 应用程序的新手,并不是一个人在做这件事。我的队友在我处理这件事的同时进行了设计,并要求我设置数据库以及执行此操作的方法等等。 所以虽然大部分看起来没问题,但我说: Cont
为什么在 SQLiteOpenHelper 类变量的所有演示和教程中总是:public static final 看看: public static final String ORDER_ID
如果您扩展 SQLiteOpenHelper,您必须为构造函数使用上下文。我想知道是否有办法忽略它,并且能够在没有上下文的情况下使用数据库表。 或者至少是限制性的,我的意思是一种项目/类结构的方式,它
android.database.sqlite.SQLiteOpenHelper如果其构造函数的名称参数为 null,则提供使用内存数据库的能力: String: of the database fi
所以我想出了一些想法,我想知道它是否可以实现。 假设我有多个表(数据库模型),每个表都由某个类表示。我不习惯将单例模式与 open helper 一起使用,所以我创建了一些简单的类来提供数据库。我的想
我有一个即将发布的 Android 应用程序,我正在审查我的一些代码。我担心我的 SQLiteOpenHelper 的实现。具体来说,我想验证 onUpgrade 方法中的 oldVersion 和
我一直在使用 Android 和 SQLite 数据库开发应用程序。但我有一些问题。这是我的代码: SQLiteHelperMoney SQLiteHelperMoney1 = new
我是一名优秀的程序员,十分优秀!