Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/75.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
android sqlite数据库错误游标_Android_Sql_Sqlite - Fatal编程技术网

android sqlite数据库错误游标

android sqlite数据库错误游标,android,sql,sqlite,Android,Sql,Sqlite,这里是代码和 错在哪里 package com.example.tasker; import java.util.ArrayList; import java.util.List; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import a

这里是代码和 错在哪里

package com.example.tasker;

import java.util.ArrayList;
import java.util.List;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class TaskerDbHelper extends SQLiteOpenHelper {

    private static final int DATABASE_VERSION = 1;

    // Database Name
    private static final String DATABASE_NAME = "Manager";

    // tasks table name
    private static final String TABLE_TASKS = "tasks";

    // tasks Table Columns names
    private static final String KEY_ID = "id";
    private static final String KEY_TASKNAME = "taskName";
    private static final String KEY_STATUS = "status";

    public TaskerDbHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {

        String sql = "CREATE TABLE IF NOT EXISTS " + TABLE_TASKS + " ( "
                + KEY_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + KEY_TASKNAME
                + " TEXT, " + KEY_STATUS + " INTEGER)";
        db.execSQL(sql);

        db.close();
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldV, int newV) {
        // Drop older table if existed
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_TASKS);
        // Create tables again
        onCreate(db);
    }

    // Adding new task
    public void addTask(Task task) {
        SQLiteDatabase db = this.getWritableDatabase();

        ContentValues values = new ContentValues();
        values.put(KEY_TASKNAME, task.getTaskName()); // task name
        // status of task- can be 0 for not done and 1 for done
        values.put(KEY_STATUS, task.getStatus());

        // Inserting Row
        db.insert(TABLE_TASKS, null, values);
        db.close(); // Closing database connection
    }

    public List<Task> getAllTasks() {
        List<Task> taskList = new ArrayList<Task>();
        // Select All Query
        String selectQuery = "SELECT  * FROM " + TABLE_TASKS;

        SQLiteDatabase db = this.getWritableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);

        // looping through all rows and adding to list

                if(cursor.getCount()>0){
                    Task task = new Task();
                    task.setId(cursor.getInt(0));
                    task.setTaskName(cursor.getString(1));
                    task.setStatus(cursor.getInt(2));
                    // Adding contact to list
                    taskList.add(task);
                    cursor.close();
                }else {
                    cursor.close();
                }return taskList;
        }


//              Task task = new Task();
//              task.setId(cursor.getInt(0));
//              task.setTaskName(cursor.getString(1));
//              task.setStatus(cursor.getInt(2));       
                // Adding contact to list
//              taskList.add(task);
//              
//          } else if (cursor.moveToNext()){
//              cursor.close();
//          }


        // return task list
//      return taskList;





    public void updateTask(Task task) {
        // updating row
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues values = new ContentValues();
        values.put(KEY_TASKNAME, task.getTaskName());
        values.put(KEY_STATUS, task.getStatus());
        db.update(TABLE_TASKS, values, KEY_ID + " = ?",new String[] {String.valueOf(task.getId())});
        db.close();
    }




}`
package com.example.tasker;
导入java.util.ArrayList;
导入java.util.List;
导入android.content.ContentValues;
导入android.content.Context;
导入android.database.Cursor;
导入android.database.sqlite.SQLiteDatabase;
导入android.database.sqlite.SQLiteDatabase.CursorFactory;
导入android.database.sqlite.SQLiteOpenHelper;
公共类TaskerDbHelper扩展了SQLiteOpenHelper{
私有静态最终int数据库_VERSION=1;
//数据库名称
私有静态最终字符串数据库\u NAME=“Manager”;
//任务表名称
私有静态最终字符串表\u TASKS=“TASKS”;
//任务表列名称
私有静态最终字符串密钥\u ID=“ID”;
私有静态最终字符串键\u TASKNAME=“TASKNAME”;
私有静态最终字符串密钥\u STATUS=“STATUS”;
公共TaskerDbHelper(上下文){
super(上下文、数据库名称、null、数据库版本);
}
@凌驾
public void onCreate(SQLiteDatabase db){
String sql=“创建不存在的表格”+表格任务+”(“
+KEY_ID+“整数主键自动递增”+“KEY_任务名”
+“文本,“+键状态+”整数“;
execSQL(sql);
db.close();
}
@凌驾
public void onUpgrade(SQLiteDatabase db、intoldv、intnewv){
//删除旧表(如果存在)
db.execSQL(“如果存在删除表”+表任务);
//再次创建表
onCreate(db);
}
//添加新任务
公共无效添加任务(任务任务){
SQLiteDatabase db=this.getWritableDatabase();
ContentValues=新的ContentValues();
value.put(KEY_TASKNAME,task.getTaskName());//任务名称
//任务状态-可以为0表示未完成,1表示已完成
value.put(KEY_STATUS,task.getStatus());
//插入行
插入(表任务,空,值);
db.close();//关闭数据库连接
}
公共列表getAllTasks(){
List taskList=new ArrayList();
//选择所有查询
String selectQuery=“SELECT*FROM”+表格任务;
SQLiteDatabase db=this.getWritableDatabase();
Cursor Cursor=db.rawQuery(selectQuery,null);
//循环遍历所有行并添加到列表
if(cursor.getCount()>0){
任务=新任务();
task.setId(cursor.getInt(0));
task.setTaskName(cursor.getString(1));
task.setStatus(cursor.getInt(2));
//将联系人添加到列表中
任务列表。添加(任务);
cursor.close();
}否则{
cursor.close();
}返回任务列表;
}
//任务=新任务();
//task.setId(cursor.getInt(0));
//task.setTaskName(cursor.getString(1));
//task.setStatus(cursor.getInt(2));
//将联系人添加到列表中
//任务列表。添加(任务);
//              
//}else if(cursor.moveToNext()){
//cursor.close();
//          }
//返回任务列表
//返回任务列表;
公共无效更新任务(任务){
//更新行
SQLiteDatabase db=this.getWritableDatabase();
ContentValues=新的ContentValues();
value.put(KEY_TASKNAME,task.getTaskName());
value.put(KEY_STATUS,task.getStatus());
更新(表任务,值,键ID+“=?”,新字符串[]{String.valueOf(task.getId())});
db.close();
}
}`
错误


07-17 15:49:51.889:E/AndroidRuntime(14450):由以下原因引起:java.lang.IllegalStateException:尝试重新打开已关闭的对象:SQLiteDatabase:/data/data/com.example.tasker/databases/Manager

从此代码中删除所有“db.close()”调用。您不必在每次使用后关闭数据库。

您可以在哪一行发布此异常?BTW:也许考虑使用DAO模式,它会使代码更加可读。因为我仍然是新手,我认为在“Curror。Cutoor())中出错,“我不知道我必须把它们放在哪里。