android创建sqlite数据库及在SD卡上创建数据库
2013-05-15 18:15
267 查看
一、在手机的/data/data/应用程序包名/ 目录下创建数据库
如果创建的数据库的大小比较小的话,可以用android自带的SQLiteOpenHelper类直接将数据库生成在手机的
/data/data/应用程序包名/目录下,方法如下:
写一个MySQLiteOpenHelper类继承自SQLiteOpenHelper类,并重写onCreate和onUpdate方法。
public class MyDatabaseHelper extends MySQLiteOpenHelper {
//数据库名称
public final static String DATABASE_NAME="db";
//数据库版本
public final static int DATABASE_VERSION=1;
MyDatabaseHelper(final Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
//创建数据库表
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
if(newVersion!=oldVersion){
//更新数据库
}
oldVersion=newVersion;
}
}
------------如下实例-----------
package com.iaiai.activity;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DatabaseOpenHelper extends SQLiteOpenHelper {
private static final String DBNAME = "iaiai"; // 数据库名子
private static final int VERSION = 1; // 版本
public DatabaseOpenHelper(Context context) {
// 第三个参数CursorFactory指定在执行查询时获得一个游标实例的工厂类,设置为null,代表使用系统默认的工厂类
super(context, DBNAME, null, VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
// 创建表
db.execSQL("CREATE TABLE ADMIN (ID INTEGER PRIMARY KEY AUTOINCREMENT, NAME VARCHAR(50), PHONE VARCHAR(20))");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 升级更新
db.execSQL("DROP TABLE IF EXISTS ADMIN");
onCreate(db);
}
}
但是,用此方法生成的数据库是保存在手机的/data/data文件夹下的,这会带来两问题:1、如果手机本身的存储
空间较小,则对创建的数据库的大小进行了限制;2、如果无法获取手机的Root权限,则无法直接查看创建的数据库
文件。鉴于以上问题,通常情况下把数据库放在存储卡上是一个较好的选择。
二、在SD卡上创建数据库
通过android的SQLiteOpenHelper类的源码,可以看到SQLiteOpenHelper类的getWritableDatabase
这个接口实际上调用的是Context的openOrCreateDatabase方法,而这个方法是不支持带路径的数据库名
称的,也就是说,用这个方法创建的数据库只能放在/data/data/包名称/ 目录下;要想在SD卡上创建数据库
,我们可以调用SQLiteDatabase类的openOrCreateDatabase方法,这个方法是支持带路径的数据库名称的。
那么下面的问题就是如何判断是否存在SD卡,已经如何获取SD卡的路径了?
判断是否存在SD卡:
android.os.Environment.MEDIA_MOUNTED.equals(
android.os.Environment.getExternalStorageState());
获取SD卡路径:String dbPath=android.os.Environment.getExternalStorageDirectory()
.getAbsolutePath();
在SD卡上创建数据库方法如下:
String dbPath=android.os.Environment.getExternalStorageDirectory()
.getAbsolutePath()+"/database";
File dbp=new File(dbPath);
File dbf=new File(dbPath+"/"+"test.db");
if(!dbp.exists()){
dbp.mkdir();
}
//数据库文件是否创建成功
boolean isFileCreateSuccess=false;
if(!dbf.exists()){
try{
isFileCreateSuccess=dbf.createNewFile();
}
catch(IOException ioex){
}
}
else{
isFileCreateSuccess=true;
}
if(isFileCreateSuccess)
db = SQLiteDatabase.openOrCreateDatabase(dbf, mFactory);
为了简便起见,我们可以用上述方法重写SQLiteOpenHelper类的getWritableDatabase方法,
其他逻辑参照SQLiteOpenHelper类即可。最后别忘了,加入SD卡的读写权限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>。
如果创建的数据库的大小比较小的话,可以用android自带的SQLiteOpenHelper类直接将数据库生成在手机的
/data/data/应用程序包名/目录下,方法如下:
写一个MySQLiteOpenHelper类继承自SQLiteOpenHelper类,并重写onCreate和onUpdate方法。
public class MyDatabaseHelper extends MySQLiteOpenHelper {
//数据库名称
public final static String DATABASE_NAME="db";
//数据库版本
public final static int DATABASE_VERSION=1;
MyDatabaseHelper(final Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
//创建数据库表
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
if(newVersion!=oldVersion){
//更新数据库
}
oldVersion=newVersion;
}
}
------------如下实例-----------
package com.iaiai.activity;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DatabaseOpenHelper extends SQLiteOpenHelper {
private static final String DBNAME = "iaiai"; // 数据库名子
private static final int VERSION = 1; // 版本
public DatabaseOpenHelper(Context context) {
// 第三个参数CursorFactory指定在执行查询时获得一个游标实例的工厂类,设置为null,代表使用系统默认的工厂类
super(context, DBNAME, null, VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
// 创建表
db.execSQL("CREATE TABLE ADMIN (ID INTEGER PRIMARY KEY AUTOINCREMENT, NAME VARCHAR(50), PHONE VARCHAR(20))");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 升级更新
db.execSQL("DROP TABLE IF EXISTS ADMIN");
onCreate(db);
}
}
但是,用此方法生成的数据库是保存在手机的/data/data文件夹下的,这会带来两问题:1、如果手机本身的存储
空间较小,则对创建的数据库的大小进行了限制;2、如果无法获取手机的Root权限,则无法直接查看创建的数据库
文件。鉴于以上问题,通常情况下把数据库放在存储卡上是一个较好的选择。
二、在SD卡上创建数据库
通过android的SQLiteOpenHelper类的源码,可以看到SQLiteOpenHelper类的getWritableDatabase
这个接口实际上调用的是Context的openOrCreateDatabase方法,而这个方法是不支持带路径的数据库名
称的,也就是说,用这个方法创建的数据库只能放在/data/data/包名称/ 目录下;要想在SD卡上创建数据库
,我们可以调用SQLiteDatabase类的openOrCreateDatabase方法,这个方法是支持带路径的数据库名称的。
那么下面的问题就是如何判断是否存在SD卡,已经如何获取SD卡的路径了?
判断是否存在SD卡:
android.os.Environment.MEDIA_MOUNTED.equals(
android.os.Environment.getExternalStorageState());
获取SD卡路径:String dbPath=android.os.Environment.getExternalStorageDirectory()
.getAbsolutePath();
在SD卡上创建数据库方法如下:
String dbPath=android.os.Environment.getExternalStorageDirectory()
.getAbsolutePath()+"/database";
File dbp=new File(dbPath);
File dbf=new File(dbPath+"/"+"test.db");
if(!dbp.exists()){
dbp.mkdir();
}
//数据库文件是否创建成功
boolean isFileCreateSuccess=false;
if(!dbf.exists()){
try{
isFileCreateSuccess=dbf.createNewFile();
}
catch(IOException ioex){
}
}
else{
isFileCreateSuccess=true;
}
if(isFileCreateSuccess)
db = SQLiteDatabase.openOrCreateDatabase(dbf, mFactory);
为了简便起见,我们可以用上述方法重写SQLiteOpenHelper类的getWritableDatabase方法,
其他逻辑参照SQLiteOpenHelper类即可。最后别忘了,加入SD卡的读写权限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>。
相关文章推荐
- android创建sqlite数据库及在SD卡上创建数据库(二)
- android创建sqlite数据库及在SD卡上创建数据库
- android创建sqlite数据库及在SD卡上创建数据库
- android创建sqlite数据库及在SD卡上创建数据库(二)
- android创建sqlite数据库及在SD卡上创建数据库(一)
- Android——SQLite数据库(一)创建数据库、创建表、初始化数据
- android(16)_数据存储与访问_SQLite数据库_数据库的创建管理
- Android(java)学习笔记192:创建sqlite数据库和创建数据库的表
- Android数据库SD卡创建和图片存取操作
- Android数据库 之 SQLite数据库(创建与使用)
- 2014-10-27Android学习------SQLite数据库操作(二)-----数据库的创建--SQLiteHelper extends SQLiteOpenHelper
- Android基础-初识SQLite第2章SQLite数据库的操作 2-1数据库的创建
- Android-Sqlite数据库_创建数据库操作Demo
- Android -- 创建数据库到SD卡
- 安卓Android通过字段映射创建sqlite数据库,操作数据库,创建表,增、删、改查,通用方法,轻松编程(by寒冬)
- Android数据库SD卡创建,及图片存、取操作!!
- Android将sqlite数据库保存到SD卡以及数据库增删改查操作,模糊查询like or
- android开发:SD卡,Assets目录,data/data目录下,数据库的复制操作
- Android数据库的创建
- 【Android游戏开发十三】(保存游戏数据 [下文])详解SQLite存储方式,并把SQLite的数据库文件存储在SD卡中!!!