android程序启动时删除,每次启动应用程序时都会重新创建Android数据库

为什么每次我的应用程序启动时SQLiteOpenHelper都会调用onCreate() . 这是我的onCreate()代码

@Override

public void onCreate(SQLiteDatabase db) {

Log.i("onCreate()", "Enter");

//create cards table

db.execSQL(

"create table circles" +

"("+

"id integer primary key,"+

"x integer not null," +

"y integer not null"+

")"

);

Log.i("onCreate()", "Exit");

}

我在扩展的SQLiteOpenHelper类周围有一个外部类,当我查询时,我这样做:

Cursor cursor = openHelper.getWritableDatabase().rawQuery("select * from circles", null);

并且因为这个if语句而跳过这个块

if (cursor.moveToFirst()) {...}

这是我的整个数据库包装类:

package db.main;

import java.util.ArrayList;

import android.content.Context;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteOpenHelper;

import android.util.Log;

import testing.main.Circle;

public class DBWrapper {

private static final String DATABASE_NAME = "circles.db";

private static final int DATABASE_VERSION = 1;

private static final String[] TABLES = new String[] { "circles"};

private Context context;

private OpenHelper openHelper;

public DBWrapper(Context context) {

context.deleteDatabase(DATABASE_NAME);

this.context = context;

this.openHelper = new OpenHelper(this.context);

}

public void insertCircle(Circle c)

{

String sql = "insert into circles (x, y) values (" + c.getX() + ", " + c.getY() + ")";

Log.i("DBWrapper::insertCircle()", "Executing sql: " + sql);

openHelper.getWritableDatabase().execSQL(sql);

}

public void clearCircles()

{

String sql = "delete * from circles";

Log.i("DBWrapper::clearCircles()", "Executing sql: " + sql);

openHelper.getWritableDatabase().execSQL(sql);

}

public ArrayList getCircles()

{

ArrayList circles = new ArrayList();

Cursor cursor = openHelper.getWritableDatabase().query(TABLES[0], null, null, null, null, null, null);

//Cursor cursor = openHelper.getWritableDatabase().rawQuery("select * from circles", null);

Log.i("DBWrapper::getCircles()", "move to first1");

if (cursor.moveToFirst()) {

Log.i("DBWrapper::getCircles()", "move to first");

do {

Log.i("DBWrapper::getCircles()", "Creating circle: " + cursor.getString(1) + ", " + cursor.getString(2));

circles.add(new Circle(Integer.parseInt(cursor.getString(1)),

Integer.parseInt(cursor.getString(2))));

} while (cursor.moveToNext());

}

if (cursor != null && !cursor.isClosed()) {

cursor.close();

}

return circles;

}

private static class OpenHelper extends SQLiteOpenHelper {

OpenHelper(Context context) {

super(context, DATABASE_NAME, null, DATABASE_VERSION);

}

@Override

public void onCreate(SQLiteDatabase db) {

Log.i("OpenHelper::onCreate()", "Enter");

//create cards table

db.execSQL(

"create table circles" +

"("+

"id integer primary key,"+

"x integer not null," +

"y integer not null"+

")"

);

Log.i("OpenHelper::onCreate()", "Exit");

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

Log.w("Example", "Upgrading database, this will drop tables and recreate.");

for(String s: TABLES)

{

db.execSQL("DROP TABLE IF EXISTS " + s);

}

onCreate(db);

}

}}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值