一,sqlite简介
sqlite是一个无服务器的,零配置的,事务性的sql数据库引擎。无服务器,意味着使用sqlite不需要联网;不需要配置,意味着不需要安装和管理;同时sqlite遵循acid原则。sqlite是一款轻型的数据库,占用资源非常低,在嵌入式设备中,可能只需几百k的内存。
二,sqlite在android中的使用
android中使用sqlitedatabase代表数据库,并提供了一系列方法来操作数据库。对于常用的增删改查操作,既可以使用execsql()方法直接执行sql语句,也可以使用android提供的方法,由于execsql()方法返回void,无法判断是否执行成功,所以除创建表之外的操作通常使用android提供的一系列方法。
1,打开或者创建数据库
使用openorcreatedatabase()打开或者创建一个数据库,如果数据库存在则打开数据库,反之则创建一个数据库。创建成功则返回sqlitedatabase对象,否则抛出异常。使用时需提供创建路径和一个游标工厂;
private void initdatabase() { string filepath = getfilesdir().getabsolutepath() + "worddb.db"; db = sqlitedatabase.openorcreatedatabase(filepath, null); log.i("db", "数据库初始化成功!"); }
2,创建表
表的创建可以通过sqlitedatabase的exexsql()方法直接执行sql语句来创建;
private void inittable() { string table = "create table tb_word(" + "id integer primary key autoincrement," + "word varchar(20) not null," + "translation varchar(20) not null);"; db.execsql(table); }
3,插入数据
- table:所要执行的表名;
- nullcolumnhack:在此处指定一个列名,当数据为空时,会向该列插入一个null。一般设为null;
- values:要插入的内容;
private void insert() { //所要插入的数据 contentvalues contentvalues = new contentvalues(); contentvalues.put("word", word); contentvalues.put("translation", translation); //执行插入 long id = worddb.insert("tb_word", null, contentvalues); if(id > 0){ toast.maketext(this, "录入成功!", toast.length_short).show(); } }
4,删除数据
- table:表名;
- whereclause:修改条件,也就是sql语句中where后的内容,可以使用占位符,如"id=?";
- whereargs:修改条件参数,当whereclause使用占位符时,在此处填入条件参数,形式为字符串数组;
private void delete() { //删除条件 string whereclause = "word = ?"; //删除条件参数 string[] whereargs = {string.valueof(words.getword())}; //执行删除 int row = worddb.delete("tb_word", whereclause, whereargs); if(row > 0){ log.i("delete", "删除成功"); }else { log.i("delete", "删除失败"); } }
5,修改数据
- table:表名;
- values:修改的内容;
- whereclause:修改的条件,与delete的一致;
- whereargs:修改条件参数;
private void update(){ //修改的内容 contentvalues values = new contentvalues(); values.put("translation", translation); //修改条件 string whereclause = "word=?"; //修改条件参数 string[] whereargs = {word}; //执行修改 int row = worddb.update("tb_word", values, whereclause, whereargs); if(row > 0){ log.i("update", "更新成功"); }else { log.i("update", "更新失败"); } }
6,查询数据
在android中查询数据是通过cursor类来实现的,当我们使用sqlitedatabase.query()方法时,会得到一个cursor对象,cursor指向的就是每一条数据。
- table:表名;
- columns:列名称数组,指定从哪些列寻找;
- selection:查询的条件,相当于where后的内容;
- selectionargs:查询条件的参数;
- groupby:分组列;
- having:分组条件;
- orderby:排序列;
- limit:分页查询限制;
cursor游标类常用方法:
private void searchword() { //查询条件 string selection = "word=?"; //查询条件参数 string[] selectionargs = { string.valueof(word) }; //执行查询,获取游标类 cursor cursor = worddb.query("tb_word", null, selection, selectionargs , null, null, null); stringbuffer result = new stringbuffer(); while(cursor.movetonext()){ int idofword = cursor.getcolumnindex("word"); string word1 = cursor.getstring(idofword); int idoftranslation = cursor.getcolumnindex("translation"); string translation = cursor.getstring(idoftranslation); result.append(word1 + ": " + translation + "\n"); } tv_words.settext(result.tostring()); }
三,sqliteopenhelper类
android提供sqliteopenhelper类来管理数据库。主要负责数据库的创建、版本更新,一般情况通过创建它的子类并扩展oncreate()和onupgrade()方法来实现。
sqliteopenhelper类常用方法:
- abstract void oncreate():第一次创建数据库时回调;
- abstract void onupgrade():数据库版本更新时回调;
- sqlitedatabase getwritabledatabase():获得可读/写的数据库;
- sqlitedatabase getreadabledatabase():获得可读的数据库;
- void close():关闭所有打开的sqlitedatabase;
(1)创建sqliteopenhelper的子类,并重写方法:
public class mysqlitehelper extends sqliteopenhelper { public mysqlitehelper(@nullable context context, @nullable string name, @nullable sqlitedatabase.cursorfactory factory, int version) { super(context, name, factory, version); } @override public void oncreate(sqlitedatabase db) { string table = "create table tb_word(" + "id integer primary key autoincrement," + "word varchar(20) not null," + "translation varchar(20) not null);"; db.execsql(table); } @override public void onupgrade(sqlitedatabase db, int oldversion, int newversion) { } }
(2)通过子类来创建数据库:
private void initdatabasehelper() { mysqlitehelper = new mysqlitehelper( this, "worddb.db", null, 1 ); sqlitehelperutil.worddb = mysqlitehelper.getwritabledatabase(); log.i("worddb", "数据库初始化成功!"); }
四,sqlite中事务的处理
sqlite采用如下方法来处理事务:
- begintransaction():开启事务;
- settransactionsuccessful():标记事务成功;
- endtransaction():提交事务,当事务执行失败时,可调用此方法回滚事务;
db.begintransaction(); try { // 执行事务中的sql语句 db.settransactionsuccessful(); } finally { db.endtransaction(); } }
到此这篇关于sqlite数据库在android中的使用的文章就介绍到这了,更多相关android sqlite数据库内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论