Android SQLiteOpenHelper
来源:互联网 发布:三体电影跳票知乎 编辑:程序博客网 时间:2024/05/21 10:52
引用的文章:
1.SQLiteOpenHelper
SQliteOpenHelper是一个抽象类,来管理数据库的创建和版本的管理。要使用它必须实现它的nCreate(SQLiteDatabase),onUpgrade(SQLiteDatabase, int, int)方法
onCreate:当数据库第一次被建立的时候被执行,例如创建表,初始化数据等。
onUpgrade:当数据库需要被更新的时候执行,例如删除久表,创建新表。
2.实现代码
import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.database.sqlite.SQLiteDatabase.CursorFactory; public class DBHelper extends SQLiteOpenHelper { //数据库版本 private static final int VERSION = 1; private static final String DBNAME = "customDB" private static DBHelper mInstance = null; //新建一个表 最好将表名和表字段放在一个常量类中, String sql = "create table if not exists TestUsers"+ "(id int primary key,name varchar,sex varchar)"; public static <span><span></span><span class="keyword">synchronized</span><span></span></span> getInstance() { if (null == mInstance) { mInstance = new DBHelper(getApplicationContext(), DBNAME, null, VERSION); } return mInstance; } private DBHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(sql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }3.SQLite的使用
Android提供了一个名为SQLiteDatabase的类,它封装了一些操作数据库的API。使用它能实现基本的CRUD操作,通过getWritableDatabase()和getReadableDatabase()可以获取数据库实例。
4.实现代码
// 只有关键代码,建议写一个manager类去封装对数据库的操作DBHelper helper = DBHelper.getInstance();SQLiteDatabase writeDatabase = helper.getWritableDatabase();SQLiteDatabase readerDatabase = helper.getReaderbleDatabase();/* getWritableDatabase() 和 getReaderbleDatabase()的区别其中getWritableDatabase()方法以读写方式打开数据库,一旦数据库的磁盘空间满了,数据库就只能读而不能写,倘若使用的是getWritableDatabase()方法就会出错。getReadableDatabase()方法则是先以读写方式打开数据库,如果数据库的磁盘空间满了,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。如果该问题成功解决,则只读数据库对象就会关闭,然后返回一个可读写的数据库对象。*///SQLdatabase类的方法很多,具体方法可以看源码,这里只介绍数据库的基本增、删、改、查的操作。// insert/** * ContentValues 就是键值对,与java中的map相同,只不过这里的key为表字段。 * 最主要介绍第二个参数,当values的值为空时,插入方法会失败,这时如果指定了第二个参数,android会插入一条只有该列的数据,值为null */// delete/** * whereClause: sql语句的where条件 * whereArgs: 条件的对应值 */public int delete(String table, String whereClause, String[] whereArgs)// update 后面两个参数是确定你要修改的具体记录public int update(String table, ContentValues values, String whereClause, String[] whereArgs)// query 参数熟悉sql语法的就会明白,见名知意public Cursor query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy)// SQLiteDatabase也提供了一个方法供程序员自己去书写sql语句,以应付复杂的查询public void execSQL(String sql) throws SQLException
0 0
- Android:SQLiteOpenHelper
- android:SQLiteOpenHelper
- android sqliteopenhelper
- Android-SQLiteOpenHelper
- Android SQLiteOpenHelper
- Android SQLiteOpenHelper
- Android:SQLiteOpenHelper,SqliteDatabase学习
- Android之SQLiteOpenHelper
- Android SQLiteOpenHelper使用示例
- Android:SQLiteOpenHelper 学习笔记
- Android如何使用SQLiteOpenHelper
- [android]SQLiteOpenHelper简介
- Android类参考---SQLiteOpenHelper
- Android SQLiteOpenHelper(手机数据库)
- android SQLiteOpenHelper使用示例
- android SQLiteOpenHelper详解
- android SQLiteOpenHelper使用示例
- android SQLiteOpenHelper使用示例
- java如何得到GET和POST请求URL和参数列表
- cocos自学笔记-酷跑demo(上)
- VJ【背包】
- 集合框架中LinkedList实现类代码分析
- 清华同方锋锐 u430 更换内存条教程
- Android SQLiteOpenHelper
- Java回调机制解析
- Maven+Spring+SpringMVC+MyBatis框架的搭建(二)
- Sublime Text常用快捷键总结附上gif图 更加清晰
- NSoperation和GCD的使用场景
- linux下如何检测程序是否运行并重启
- LeetCode:有效变形词(Valid Anagram)
- 利用NSCache提升效率
- 【Java】豆机