Android :这是一份详细 全面的 SQLlite数据库 使用手册
其中,SQLite
数据库的存储方式 非常常用
- 今天我将带大家全面了解关于
Android
SQLite
数据库的操作(增、删、查、改)
目录
1. SQLlite数据库 简介
2. SQLiteOpenHelper类
2.1 简介
2.2 SQLiteOpenHelper类 常用方法
/**
- 创建数据库
*/
// 1. 创建 or 打开 可读/写的数据库(通过 返回的SQLiteDatabase对象 进行操作)
getWritableDatabase()
// 2. 创建 or 打开 可读的数据库(通过 返回的SQLiteDatabase对象 进行操作)
getReadableDatabase()
// 3. 数据库第1次创建时 则会调用,即 第1次调用 getWritableDatabase() / getReadableDatabase()时调用
// 在继承SQLiteOpenHelper类的子类中复写
onCreate(SQLiteDatabase db)
// 4. 数据库升级时自动调用
// 在继承SQLiteOpenHelper类的子类中复写
onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
// 5. 关闭数据库
close()
/**
- 数据库操作(增、删、减、查)
*/
// 1. 查询数据
(Cursor) query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)
// 查询指定的数据表返回一个带游标的数据集。
// 各参数说明:
// table:表名称
// colums:列名称数组
// selection:条件子句,相当于where
// selectionArgs:条件语句的参数数组
// groupBy:分组
// having:分组条件
// orderBy:排序类
// limit:分页查询的限制
// Cursor:返回值,相当于结果集ResultSet
(Cursor) rawQuery(String sql, String[] selectionArgs)
//运行一个预置的SQL语句,返回带游标的数据集(与上面的语句最大的区别 = 防止SQL注入)
// 2. 删除数据行
(int) delete(String table,String whereClause,String[] whereArgs)
// 3. 添加数据行
(long) insert(String table,String nullColumnHack,ContentValues values)
// 4. 更新数据行
(int) update(String table, ContentValues values, String whereClause, String[] whereArgs)
// 5. 执行一个SQL语句,可以是一个select or 其他sql语句
// 即 直接使用String类型传入sql语句 & 执行
(void) execSQL(String sql)
3. 具体使用
- 使用步骤 = 自定义数据库子类(继承
SQLiteOpenHelper
类)、创建数据库 & 操作数据库(增、删、查、改) - 下面,我将逐一介绍每个步骤
3.1 自定义数据库子类(继承 SQLiteOpenHelper 类)
/**
- 创建数据库子类,继承自SQLiteOpenHelper类
- 需 复写 onCreat()、onUpgrade()
*/
public class DatabaseHelper extends SQLiteOpenHelper {
// 数据库版本号
private static Integer Version = 1;
/**
- 构造函数
- 在SQLiteOpenHelper的子类中,必须有该构造函数<