android apk交换数据库,Android 数据库文件和apk一起发布

package com.lanxin;

import java.io.File;

import java.io.FileOutputStream;

import java.io.InputStream;

import java.io.OutputStream;

import java.io.UnsupportedEncodingException;

import android.app.Activity;

import android.content.Intent;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import android.os.Bundle;

public class DbtestActivity extends Activity implements Runnable {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_dbtest);

// com.lanxin 是程序的包名,请根据自己的程序调整

// /data/data/com.lanxin/

// databases 目录是准备放 SQLite 数据库的地方,也是 Android 程序默认的数据库存储目录

// 数据库名为 db_lanxin.db

String DB_PATH = "/data/data/com.lanxin/databases/";

String DB_NAME = "db_lanxin.db";

// 检查 SQLite 数据库文件是否存在

if ((new File(DB_PATH + DB_NAME)).exists() == false) {

// 如 SQLite 数据库文件不存在,再检查一下 database 目录是否存在

File f = new File(DB_PATH);

// 如 database 目录不存在,新建该目录

if (!f.exists()) {

f.mkdir();

}

try {

// 得到 assets 目录下我们实现准备好的 SQLite 数据库作为输入流

InputStream is = getBaseContext().getAssets().open(DB_NAME);

// 输出流

OutputStream os = new FileOutputStream(DB_PATH + DB_NAME);

// 文件写入

byte[] buffer = new byte[1024];

int length;

while ((length = is.read(buffer)) > 0) {

os.write(buffer, 0, length);

}

// 关闭文件流

os.flush();

os.close();

is.close();

} catch (Exception e) {

e.printStackTrace();

}

}

// 下面测试 /data/data/com.test.db/databases/ 下的数据库是否能正常工作

SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(DB_PATH

+ DB_NAME, null);

Cursor cursor = database.rawQuery("select * from SqlEmployee", null);

if (cursor.getCount() > 0) {

cursor.moveToFirst();

try {

// 解决中文乱码问题

byte test[] = cursor.getBlob(1);

String strtest = new String(test, "utf-8").trim();

// 看输出的信息是否正确

System.out.println(strtest);

} catch (UnsupportedEncodingException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

cursor.close();

try {

// 暂停6秒后跳转到MainActivity主页面

Thread.sleep(6000);

list();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

public void run() {

}

public void list() {

Intent intent = new Intent();

intent.setClass(DbtestActivity.this, MainActivity.class);

startActivity(intent);

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值