http://www.eoeandroid.com/thread-54654-1-1.html
要在Android系统中操作sqlite@R_301_457@,是通过Android的核心类sqliteDatabase类来实现的,通常情况下为了@R_301_457@升级的需要以及使用方便,我们会选择继承sqliteOpenHelper抽像类,但是sqliteOpenHelper会将@R_301_457@文件创建在一个固定的目录(内存的/data/data/<package name/databases>目录中),如果你想使用已经存在的@R_301_457@文件也就是说@R_301_457@会和程序一起发布,就得通过使用sqliteDabase的静态方法OpenOrCreateDatabase()方法来得到sqliteDabase对象,下面是一个具体操作类:
package net.my.dao;import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import net.my.jokebook.R;
import android.app.Activity;
import android.content.Context;
import android.database.sqlite.sqliteDatabase;
public class DBHelper {
//得到SD卡路径
private final String DATABASE_PATH = android.os.Environment
.getExternalStorageDirectory().getAbsolutePath()
+ "/joke";
private final Activity activity;
//@R_301_457@名
private final String DATABASE_FILENAME;
public DBHelper(Context context) {
// TODO Auto-generated constructor stub
//这里直接给@R_301_457@名
DATABASE_FILENAME = "jokebook.db3";
activity = (Activity)context;
}
//得到操作@R_301_457@的对象
publicsqliteDatabase openDatabase()
{
try
boolean b = false;
//得到@R_301_457@的完整路径名
String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
//将@R_301_457@文件从资源文件放到合适地方(资源文件也就是@R_301_457@文件放在项目的res下的raw目录中)
//将@R_301_457@文件复制到SD卡中 File dir = new File(DATABASE_PATH);
if (!dir.exists())
b = dir.mkdir();
//判断是否存在该文件
if (!(new File(databaseFilename)).exists())
{
//不存在得到@R_301_457@输入流对象
InputStream is = activity.getResources().openRawResource(
R.raw.jokebook);
//创建输出流
FileOutputStream fos = new FileOutputStream(databaseFilename);
//将数据输出
byte[] buffer = new byte[8192];
int count = 0;
while ((count = is.read(buffer)) > 0)
{
fos.write(buffer,count);
}
//关闭资源
fos.close();
is.close();
}
//得到sqlDatabase对象
sqliteDatabase database = sqliteDatabase.openOrCreateDatabase(
databaseFilename,null);
return database;
catch (Exception e)
System.out.println(e.getMessage());
return null;
写完这个类之后,就能得到sqliteDatabase对象,就能对@R_301_457@操作了