Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/312.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

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/200.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 安卓&/sqlite:游标导致问题_Java_Android_Sqlite - Fatal编程技术网

Java 安卓&/sqlite:游标导致问题

Java 安卓&/sqlite:游标导致问题,java,android,sqlite,Java,Android,Sqlite,与sqlite相关的游标出现此错误。我使用子类SQLiteOpenHelper来访问数据库。然后,我访问数据库,然后直接关闭光标。然而,当我关闭活动时,这会导致一个错误: 代码如下所示: String sql = "SELECT * FROM table_bla LIMIT 1"; Cursor cursor = dbHelper.getWritableDatabase().rawQuery(sql, null); cursor.moveToFirst(); String x = cursor

与sqlite相关的游标出现此错误。我使用子类SQLiteOpenHelper来访问数据库。然后,我访问数据库,然后直接关闭光标。然而,当我关闭活动时,这会导致一个错误:

代码如下所示:

String sql = "SELECT * FROM table_bla LIMIT 1";
Cursor cursor = dbHelper.getWritableDatabase().rawQuery(sql, null);

cursor.moveToFirst();
String x = cursor.getString(cursor.getColumnIndex("x"));
cursor.close();
我明白了:

03-14 15:34:55.945: E/Database(3825): close() was never explicitly called on database '/data/data/my.project/databases/myDB.db' 
03-14 15:34:55.945: E/Database(3825): android.database.sqlite.DatabaseObjectNotClosedException: Application did not close the cursor or database object that was opened here
03-14 15:34:55.945: E/Database(3825):   at android.database.sqlite.SQLiteDatabase.<init>(SQLiteDatabase.java:1847)
03-14 15:34:55.945: E/Database(3825):   at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:820)
03-14 15:34:55.945: E/Database(3825):   at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:854)
03-14 15:34:55.945: E/Database(3825):   at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:847)
03-14 15:34:55.945: E/Database(3825):   at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:572)
03-14 15:34:55.945: E/Database(3825):   at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203)
03-14 15:34:55.945: E/Database(3825):   at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:118)
03-14 15:34:55.945: E/Database(3825):   at my.project.StartScreen.onResume(StartScreen.java:35)
03-14 15:34:55.945: E/Database(3825):   at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1150)
03-14 15:34:55.945: E/Database(3825):   at android.app.Activity.performResume(Activity.java:3832)
03-14 15:34:55.945: E/Database(3825):   at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2231)
03-14 15:34:55.945: E/Database(3825):   at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2256)
03-14 15:34:55.945: E/Database(3825):   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1789)
03-14 15:34:55.945: E/Database(3825):   at android.app.ActivityThread.access$1500(ActivityThread.java:123)
03-14 15:34:55.945: E/Database(3825):   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:939)
03-14 15:34:55.945: E/Database(3825):   at android.os.Handler.dispatchMessage(Handler.java:99)
03-14 15:34:55.945: E/Database(3825):   at android.os.Looper.loop(Looper.java:130)
03-14 15:34:55.945: E/Database(3825):   at android.app.ActivityThread.main(ActivityThread.java:3835)
03-14 15:34:55.945: E/Database(3825):   at java.lang.reflect.Method.invokeNative(Native Method)
03-14 15:34:55.945: E/Database(3825):   at java.lang.reflect.Method.invoke(Method.java:507)
03-14 15:34:55.945: E/Database(3825):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
03-14 15:34:55.945: E/Database(3825):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
03-14 15:34:55.945: E/Database(3825):   at dalvik.system.NativeStart.main(Native Method)
03-14 15:34:55.945:E/Database(3825):从未对数据库“/data/data/my.project/databases/myDB.db”显式调用close()
03-14 15:34:55.945:E/Database(3825):android.Database.sqlite.DatabaseObjectNotClosedException:应用程序未关闭在此打开的光标或数据库对象
03-14 15:34:55.945:E/Database(3825):位于android.Database.sqlite.SQLiteDatabase.(SQLiteDatabase.java:1847)
03-14 15:34:55.945:E/Database(3825):位于android.Database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:820)
03-14 15:34:55.945:E/Database(3825):位于android.Database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:854)
03-14 15:34:55.945:E/Database(3825):位于android.Database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:847)
03-14 15:34:55.945:E/Database(3825):在android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:572)
03-14 15:34:55.945:E/Database(3825):位于android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203)
03-14 15:34:55.945:E/Database(3825):位于android.Database.sqlite.SQLiteOpenHelper.getwriteabledatabase(SQLiteOpenHelper.java:118)
03-14 15:34:55.945:E/数据库(3825):在my.project.StartScreen.onResume(StartScreen.java:35)
03-14 15:34:55.945:E/数据库(3825):在android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1150)
03-14 15:34:55.945:E/数据库(3825):在android.app.Activity.performResume(Activity.java:3832)
03-14 15:34:55.945:E/数据库(3825):位于android.app.ActivityThread.performResumeActivity(ActivityThread.java:2231)
03-14 15:34:55.945:E/数据库(3825):位于android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2256)
03-14 15:34:55.945:E/数据库(3825):位于android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1789)
03-14 15:34:55.945:E/数据库(3825):位于android.app.ActivityThread.access$1500(ActivityThread.java:123)
03-14 15:34:55.945:E/数据库(3825):位于android.app.ActivityThread$H.handleMessage(ActivityThread.java:939)
03-14 15:34:55.945:E/Database(3825):在android.os.Handler.dispatchMessage(Handler.java:99)上
03-14 15:34:55.945:E/数据库(3825):在android.os.Looper.loop(Looper.java:130)上
03-14 15:34:55.945:E/数据库(3825):位于android.app.ActivityThread.main(ActivityThread.java:3835)
03-14 15:34:55.945:E/Database(3825):位于java.lang.reflect.Method.Invokenactive(本机方法)
03-14 15:34:55.945:E/Database(3825):位于java.lang.reflect.Method.invoke(Method.java:507)
03-14 15:34:55.945:E/Database(3825):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847)
03-14 15:34:55.945:E/Database(3825):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605)
03-14 15:34:55.945:E/数据库(3825):位于dalvik.system.NativeStart.main(本机方法)

有人知道这是什么原因吗?

请像这样重写代码:

String sql = "SELECT * FROM table_bla LIMIT 1";
SQLiteDatabase database = dbHelper.getWritableDatabase();
Cursor cursor = database.rawQuery(sql, null);

cursor.moveToFirst();
String x = cursor.getString(cursor.getColumnIndex("x"));
cursor.close();
database.close();

否则,您将获得一个从未关闭的数据库连接,这将导致问题。

将代码改写为:

String sql = "SELECT * FROM table_bla LIMIT 1";
SQLiteDatabase database = dbHelper.getWritableDatabase();
Cursor cursor = database.rawQuery(sql, null);

cursor.moveToFirst();
String x = cursor.getString(cursor.getColumnIndex("x"));
cursor.close();
database.close();

否则,您将获得一个从未关闭的数据库连接,这将导致问题。

这是因为您需要在退出应用程序之前关闭对de DB的访问,我认为此代码不会强制关闭

这是因为您需要在退出应用程序之前关闭对de DB的访问,我认为此代码不会强制关闭

您是否关闭了数据库对象?您是否关闭了数据库对象?此外,他应该获得一个可读数据库而不是可写数据库,因为他没有对数据库进行任何修改。这并不重要-
getReadableDatabase()
将在可能的情况下为您提供一个可写数据库。编辑:请求一个可读的数据库更安全,因为它更难获得一个数据库。此外,他应该获得一个可读的数据库,而不是一个可写的数据库,因为他没有对数据库进行任何修改。这并不真的重要-
getReadableDatabase()
将在可能的情况下为您提供一个可写的数据库。编辑:请求一个可读的数据库更安全,因为它更难获得一个数据库。