SQLiteOpenHelper的使用,对数据库操作的封装

SQLiteOpenHelper封装

继承SQLiteOpenHelper类,在构造方法中分别需要传入Context,数据库名称,CursorFactory(一般传入null,为默认数据库),数据库版本号(不能为负数)。在SQLiteOpenHelper中首先执行的是onCreate方法(当shujk第一次被创建时)。在构造函数时并没有真正创建数据库,而在调用getWritableDatabase或者getReadableDatabase方法时才真正去创建数据库,返回一个SQLiteDatabase对象。

public class MyDataBaseAdapter
{
   
// 用于打印log
   
private static final String TAG = "MyDataBaseAdapter";

   
// 表中一条数据的名称
   
public static final String KEY_ID = "_id";

   
// 表中一条数据的内容
   
public static final String KEY_NUM = "num";
   
// 表中一条数据的id
   
public static final String KEY_DATA = "data";

   
// 数据库名称为data
   
private static final String DB_NAME = "Examples_06_06.db";
       
   
// 数据库表名
   
private static final String DB_TABLE = "table1";
       
   
// 数据库版本
   
private static final int DB_VERSION = 1;

   
// 本地Context对象
   
private Context mContext = null;
       
   
//创建一个表
   
private static final String DB_CREATE = "CREATE TABLE " + DB_TABLE + " (" + KEY_ID + " INTEGER PRIMARY KEY," + KEY_NUM + " INTERGER,"+ KEY_DATA + " TEXT)";

   
// 执行open()打开数据库时,保存返回的数据库对象
   
private SQLiteDatabase mSQLiteDatabase = null;

   
// 由SQLiteOpenHelper继承过来
   
private DatabaseHelper mDatabaseHelper = null;
       
       
   
private static class DatabaseHelper extends SQLiteOpenHelper{

     
/* 构造函数-创建一个数据库 */
     
DatabaseHelper(Context context){

         
//当调用getWritableDatabase()
         
//或 getReadableDatabase()方法时
         
//则创建一个数据库
         
super(context, DB_NAME, null, DB_VERSION);
     
}

     
/* 创建一个表 */
     
@Override
     
public void onCreate(SQLiteDatabase db){

         
// 数据库没有表时创建一个
         db
.execSQL(DB_CREATE);
     
}

     
/* 升级数据库 */
     
@Override
     
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){

         db
.execSQL("DROP TABLE IF EXISTS notes");
         onCreate
(db);
     
}
   
}
       
   
/* 构造函数-取得Context */
   
public MyDataBaseAdapter(Context context){

         mContext
= context;
   
}


   
// 打开数据库,返回数据库对象
   
public void open() throws SQLException{

         mDatabaseHelper
= new DatabaseHelper(mContext);
         mSQLiteDatabase
= mDatabaseHelper.getWritableDatabase();
   
}


   
// 关闭数据库
   
public void close(){

         mDatabaseHelper
.close();
   
}

   
/* 插入一条数据 */
   
public long insertData(int num, String data){

         
ContentValues initialValues = new ContentValues();
         initialValues
.put(KEY_NUM, num);
         initialValues
.put(KEY_DATA, data);

         
return mSQLiteDatabase.insert(DB_TABLE, KEY_ID, initialValues);
   
}

   
/* 删除一条数据 */
   
public boolean deleteData(long rowId){

         
return mSQLiteDatabase.delete(DB_TABLE, KEY_ID + "=" + rowId, null) > 0;
   
}

   
/* 通过Cursor查询所有数据 */
   
public Cursor fetchAllData(){

         
return mSQLiteDatabase.query(DB_TABLE, new String[] { KEY_ID, KEY_NUM, KEY_DATA }, null, null, null, null, null);
   
}

   
/* 查询指定数据 */
   
public Cursor fetchData(long rowId) throws SQLException{

     
Cursor mCursor = mSQLiteDatabase.query(true, DB_TABLE, new String[] { KEY_ID, KEY_NUM, KEY_DATA }, KEY_ID + "=" + rowId, null, null, null, null, null);

     
if (mCursor != null){

         mCursor
.moveToFirst();
     
}
     
return mCursor;

   
}

   
/* 更新一条数据 */
   
public boolean updateData(long rowId, int num, String data){

     
ContentValues args = new ContentValues();
      args
.put(KEY_NUM, num);
      args
.put(KEY_DATA, data);

     
return mSQLiteDatabase.update(DB_TABLE, args, KEY_ID + "=" + rowId, null) > 0;
   
}
       
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLite 是一个轻量级的关系型数据库,常用于移动应用和嵌入式系统中。以下是 SQLite 数据库使用要点: 1. 创建数据库:可以使用 SQLiteOpenHelper 类来创建和管理数据库。这个类提供了 onCreate() 和 onUpgrade() 方法来创建和更新数据库。 2. 创建表:可以使用 SQL 语句来创建表,在 onCreate() 方法中执行 CREATE TABLE 语句即可。 3. 插入数据:使用 INSERT INTO 语句插入数据,可以使用 SQLiteStatement 或 ContentValues 来构造插入语句。 4. 查询数据:使用 SELECT 语句查询数据,可以使用 SQLiteDatabase 的 query() 方法或 rawQuery() 方法来执行查询。 5. 更新数据:使用 UPDATE 语句更新数据,可以使用 SQLiteDatabase 的 update() 方法来执行更新操作。 6. 删除数据:使用 DELETE 语句删除数据,可以使用 SQLiteDatabase 的 delete() 方法来执行删除操作。 下面是一个使用 SQLiteOpenHelper 的示例: ```java public class MyDatabaseHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "mydb.db"; private static final int DATABASE_VERSION = 1; public MyDatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL("CREATE TABLE mytable (_id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER)"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL("DROP TABLE IF EXISTS mytable"); onCreate(db); } } ``` 在这个例子中,我们创建了一个名为 "mytable" 的表,包含三个字段:_id、name 和 age。在 onCreate() 方法中执行了 CREATE TABLE 语句,如果数据库版本升级,会先执行 onUpgrade() 方法中的 DROP TABLE 语句,然后再重新创建表。 使用 SQLiteOpenHelper 创建和管理数据库是一个相对简单和方便的方法,它封装了创建、升级和打开数据库的过程,可以让我们更专注于数据库操作本身。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值