Android 数据库随apk一起打包 及带参数跳转到拨号界面

大多数都是在网上copy下来的:

首先将数据库文件放在assets这个资源目录下,then...

其中databaseutil如下:

package com.sunmoon.db;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.util.Log;

import com.baoxiu123.getstuinfo.R;

public class DataBaseUtil {

	private Context context;
	public static String dbName = "stu.db";
	private static String DATABASE_PATH;
	
	
	public DataBaseUtil(Context context) {
		this.context = context;
		String packageName = context.getPackageName();
		DATABASE_PATH = "/data/data/"+packageName+"/databases/";
	}
    /** 
     * 判断数据库是否存在 
     *  
     * @return false or true 
     */  
    public boolean checkDataBase() {  
        SQLiteDatabase db = null;  
        try {  
            String databaseFilename = DATABASE_PATH + dbName;  
            db = SQLiteDatabase.openDatabase(databaseFilename, null,SQLiteDatabase.OPEN_READONLY);  
        } catch (SQLiteException e) {  
  
        }  
        if (db != null) {  
            db.close();  
        }  
        return db != null ? true : false;  
    } 
    
    /** 
     * 复制数据库到手机指定文件夹下 
     *  
     * @throws IOException 
     */  
    public void copyDataBase() throws IOException {  
        String databaseFilenames = DATABASE_PATH + dbName;  
        File dir = new File(DATABASE_PATH);  
        if (!dir.exists())// 判断文件夹是否存在,不存在就新建一个  
            dir.mkdir();  
        FileOutputStream os = new FileOutputStream(databaseFilenames);// 得到数据库文件的写入流  
        InputStream is = context.getResources().getAssets().open(dbName);// 得到数据库文件的数据流  
        byte[] buffer = new byte[8192];  
        int count = 0;  
        while ((count = is.read(buffer)) > 0) {  
            os.write(buffer, 0, count);  
            os.flush();  
        }  
        is.close();  
        os.close();  
    }  
	
}
然后再写出调用函数:

// 检查数据库是否已经存在
	public void check_db() {
		Log.i("TAG", "clicked..");

		boolean hasSDCard = Environment.getExternalStorageState().equals(
				Environment.MEDIA_MOUNTED);
		if (hasSDCard) {
			copyDataBaseToPhone();
		} else {
			Toast.makeText(MainActivity.this, "未检测到SDCard", 0).show();
		}
	}

	private void copyDataBaseToPhone() {
		DataBaseUtil util = new DataBaseUtil(this);
		// 判断数据库是否存在
		boolean dbExist = util.checkDataBase();

		if (dbExist) {
			Log.i("tag", "The database is exist.");
		} else {// 不存在就把raw里的数据库写入手机
			try {
				util.copyDataBase();
			} catch (IOException e) {
				throw new Error("Error copying database");
			}
		}
	}
在需要用的地方调用check_db就可以了


带参数跳转到拨号界面这个很简单,用一个intent就好

Intent intent = new Intent(Intent.ACTION_DIAL, Uri.parse("tel:"
				+ "1570035xxoo"));

		intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
		startActivity(intent);


你可能感兴趣的:(Android 数据库随apk一起打包 及带参数跳转到拨号界面)