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())中出错,“我不知道我必须把它们放在哪里。