8

我正在使用从流行的记事本示例中学到的标准方法来构建我的第一个应用程序。
但我陷入了一个奇怪的问题。
SQLite 数据库文件 (.db) 未在 /data/data/package/databases 中创建。我已经从 HeadFirst android dev 交叉检查了清单文件和 OpenHelper 文件。书(我将其用作参考)但我发现自己无法弄清楚为什么没有创建数据库文件。
是否有任何特殊权限或我们需要打开它才能使其工作?
奇怪的是,它对于预加载的示例工作正常。表示为记事本示例创建了“.db”文件,但是当我尝试时,它失败了。:(
这是我的文件。

包 - database.test

1.AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>

<uses-sdk android:minSdkVersion="10" />

<application
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name" >
    <activity
        android:name=".Database_testActivity"
        android:label="@string/app_name" >
    </activity>
</application>

2.TestOpenHelper.java

package database.test;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class TestOpenHelper extends SQLiteOpenHelper {

TestOpenHelper(Context context){
    super(context,"mydb.db",null,1);
}
@Override
public void onCreate(SQLiteDatabase database){
    database.execSQL("create table test_1 " + " (field1 integer primary key, field2 integer);");
}
public void onUpgrade (SQLiteDatabase database, int oldVersion, int newVersion){
    database.execSQL("drop table if exists test1");
    onCreate(database);
}
}

3.Database_testActivity.java

package database.test;

import android.app.Activity;
import android.os.Bundle;
import android.widget.ListView;

public class Database_testActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    ListView listview = (ListView)findViewById(R.id.test_list);
    TestAdapter ta = new TestAdapter();
    listview.setAdapter(ta);

    TestOpenHelper openHelper = new TestOpenHelper(this);
}
}   

我知道这是一个非常基本的问题,但过去十五天我一直在尝试解决这个问题,现在我完全感到沮丧。
请帮忙 ..

4

1 回答 1

24

改变这个:

database.execSQL("create table test_1 " + " (field1 integer primary key, field2 integer)");

这个TestOpenHelper openHelper = new TestOpenHelper(this);改变为SQLiteDatabase db = new TestOpenHelper(this).getWritableDatabase();

你真的没有创建数据库,你只创建了你的实例,SQLiteOpenHelper但要创建或打开数据库,你必须使用getWritableDatabase()orgetReadableDatabase()方法。

完全来自文档:

创建和/或打开将用于读取和写入的数据库。

于 2012-06-04T21:11:25.557 回答