文章目录
Android
安卓开发者指南:https://developer.android.google.cn/guide
1 SQLite数据库
SQLite是一个轻量级、零配置、可嵌入程序驱动的二进制文件,也是开源的关系型数据库,实现自包容、零配置、支持事务的SQL数据库引擎。特点是高度便携、使用方便、结构紧凑、高效、可靠。
Sqlite的使用场景
现在的主流移动设备像Android、iPhone 等都使用SQLite作为复杂数据的存储引擎,在为移动设备开发应用程序时,也许就要使用到SQLite来存储大量的数据,所以就需要掌握移动设备上的SQLite开发技巧。对于Android平台来说,系统内置了丰富的API来供开发人员操作SQLite,可以轻松的完成对数据的存取。
DDL(数据库定义语言):create table 表名 (列名 数据类型 约束,…)
DML(数据库操作语言):
insert into 表名(列1,列2) values (值1,值2)
insert into 表名 values(值1,值2,值3)
(插入:数据类型个数顺序对应;一定要包含所有非空列;自动增长列的值设置不存在的值或null)
delete from 表名 [where 删除条件]
update 表名 set 列名1=更新值1,列名2=更新值2,列名n=更新值n [where <更新条件>]
select * from 表名
1.1 Android中操作SQL语句
- 布局文件
- 实现增删改查点击事件
SQLiteOpenHelper抽象类
Android平台里一个数据库辅助类,用于创建或打开数据库,并且对数据库的创建和版本进行管理。回调方法onCreate()用于数据库以及表的创建,onUpgrade()用于数据库升级。
性别单选按钮的切换,设置默认值,private String genderStr = “男”;
新增:
查询所有:(stuList是一个ListView控件)
条件查询:
数据库设置ID列名为_id原因:SimpleCursorAdapter定义初期要求数据源(第三个参数)里面有_id列。
删除:
修改(操作完记得把输入框清空):
每次操作完应该添加一个人性化的操作提示,例如:Toast.makeText(this,“添加成功”,Toast.LENGTH_SHORT).show();
Sqlite数据库中获取数据库对象的两个方法
1)获取数据库实例时使用了 getWritableDatabase()方法。
2)在getReadableDatabase()方法中,首先判断是否已存在数据库实例并且是打开状态,如果是,则直接返回该实例,否则试图获取一个可读写模式的数据库实例,如果遇到磁盘空间已满等情况获取失败的话,再以只读模式打开数据库,获取数据库实例并返回,然后为数据库对象赋值为最新打开的数据库实例。
3) getReadableDatabase()一般都会返回和getWritableDatabase()一样的数据库实例,所以我们在DBManager构造方法中使用getWritableDatabase()获取整个应用所使用的数据库实例是可行的。
4)当调用SQLiteOpenHelper的getWritableDatabase()或者getReadableDatabase()方法获取用于操作数据库的SQLiteDatabase实例的时候,如果数据库不存在,Android系统会自动生成一个数据库,接着调用onCreate()方法。
5) onCreate()方法在初次生成数据库时才会被调用在onCreate()方法里可以生成数据库表结构及添加一些应用使用到的初始化数据。
6)onUpgrade()方法在数据库的版本发生变化时会被调用,一般在软件升级时才需改变版本号,而数据库的版本是由程序员控制的。
1.2 SQLiteDatabase操作数据库
用于管理和操作SQLite数据库,几乎所有的数据库操作,最终都将由这个类完成。
在Android平台上,SQLiteDatabase类下提供了两套方法操作数据:
- 方法一:需要正确的SQL语句
rawQuery():查询
execSQL():添加、删除、修改、创建 - 方法二:使用API封装方法,都不需要写sql语句,根据参数操作数据库:
查询:db.query(table, columns, selection, selectionArgs, groupBy, having, orderBy)
添加:db.insert(table, nullColumnHack, values)
删除:db.delete(table, whereClause, whereArgs):返回long型数据,表示受影响行数
修改:db.update(table, values, whereClause, whereArgs):返回long型数据,表示受影响行数
select count(*),age from info_tb group by age having age>23 order by age desc(降序)
1.3 使用面向对象思想封装操作
Student学生实体类:int id, String name, int age, String gender,无参/有参构造
Dao:data access object数据访问对象,对数据库的操作对象
StudentDao.java
最后在Activity中调用这个类的方法就可以了