如何在Android应用程序中嵌入sqlite数据库文件

时间:2012-12-12 11:11:19

标签: android sqlite embedded-database

我基本上正在开发一个基本的android-sqlite-database应用程序。我已成功运行它。它获取“名称”和“电话号码”并添加到数据库“data / data / com.android.databaseapp” 现在我想把数据库放到应用程序中,我已经按照教程但没有成功。请在这里给我一些详细的指示 我已经在资产中添加了.db文件,并为此注意了2个toturials,但assets / .db文件没有得到更新。只有“data / data / com.android.databaseapp / .db”文件才会更新 我的DatabaseHadler类是:

private static final int DATABASE_VERSION = 1;

private static final String DATABASE_NAME = "contactsManager";

private static final String TABLE_CONTACTS = "contacts";

private static final String KEY_ID = "id";
private static final String KEY_NAME = "name";
private static final String KEY_PH_NO = "phone_number";

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

// Creating Tables
@Override
public void onCreate(SQLiteDatabase db) {
    String CREATE_CONTACTS_TABLE = "CREATE TABLE " + TABLE_CONTACTS + "("
            + KEY_ID + " INTEGER PRIMARY KEY," + KEY_NAME + " TEXT,"
            + KEY_PH_NO + " TEXT" + ")";
    db.execSQL(CREATE_CONTACTS_TABLE);
    db.close();
}

// Upgrading database
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // Drop older table if existed
    db.execSQL("DROP TABLE IF EXISTS " + TABLE_CONTACTS);

    // Create tables again
    onCreate(db);
    db.close();
}

Plzzz在这里指导我.....

2 个答案:

答案 0 :(得分:2)

Here是您在android

中创建和执行数据库的最佳教程

您也可以从此链接下载该示例并执行它。

(如果您想通过将数据库保存在资产文件夹中来执行数据库,请遵循此link

答案 1 :(得分:1)

如果将数据库放入assets文件夹,则需要在数据库连接器类中为其指定新路径。

创建一个类来处理与数据库的连接并使用SQLiteDatabase类中的openDatabase方法:

if(File.exists(databasePath))
{
    this.yourDataBase = 
        SQLiteDatabase.openDatabase( databasePath , 
                                     null, 
                                     SQLiteDatabase.OPEN_READWRITE);
}

确保databasePath指向您的...app/assets/database.db3文件