本文实例讲述了Android SQLite数据库操作方法。分享给大家供大家参考,具体如下:

SQLite and Android
SQLite简介
SQLite是一个非常流行的嵌入式数据库,它支持SQL语言,并且只利用很少的内存就有很好的性能。此外,它还是开源的,任何人都可以使用它。
SQLite由以下几个组件组成:SQL编译器、内核、后端以及附件。SQLite通过利用虚拟机和虚拟数据库引擎(VDBE),使调试、修改和扩展SQLite的内核变得更加方便。
SQLite支持的数据类型包括:
1. TEXT (类似于Java的String)
2. INTEGER (类似于Java的long)
3. REAL (类似于Java的Double)
更多SQLite数据类型知识可以参考前面相关文章入:详解SQLite中的数据类型
SQLite In Android
Android在运行时集成了SQLite,因此在Android中使用SQLite数据库并不需要安装过程和获取数据库使用权限,你只需要定义创建和更新数据库的语句即可,其他的会由Android平台替你搞定。
操作SQLite数据库通常意味着操作文件系统,这种操作还是比较耗时的,因此建议将数据库操作异步执行。
你的应用创建一个SQLite数据库,数据在默认情况下,存储在/DATA/data/APP_NAME/databases/FILENAME。这里DATA是Environment.getDataDirectory()方法返回的值,APP_NAME是你的应用包名
Android开发中使用SQLite数据库
Activity可以使用Content Provider或者 Service访问一个数据库。
创建数据库
Android不自动提供数据库。在Android应用程序中使用SQLite,必须自己创建数据库,然后创建表、索引、填充数据。Android提供了一个SQLiteOpenHelper帮助你创建一个数据库,你只要继承 SQLiteOpenHelper 类,就可以轻松的创建数据库。
SQLiteOpenHelper 类根据开发应用程序的需要,封装了创建和更新数据库使用的逻辑。SQLiteOpenHelper 的子类,至少需要实现三个方法:
构造函数,调用父类SQLiteOpenHelper的构造函数。这个方法需要四个参数:上下文环境,数据库名字,一个可选的游标工厂(通常是NULL),一个代表你正在使用的数据库模型版本的整数。
onCreate()方法,它需要一个SQLiteDatabase对象作为参数,根据需要对这个对象填充表和初始化数据。
onUpgrade()方法,它需要三个参数,一个SQLiteDatabase对象,一个旧的版本号和一个新的版本号,这样你就可以清楚如何把一个数据库从旧的模型转变为新的模型。
首先,定义需要创建的表结构,使用类来进行抽象,这里示例定义一个新浪微薄的帐号类:
public class AccountTable {
public static final String TABLE_NAME = "account_table";
public static final String UID = "uid";
public static final String USERNAME = "username";
public static final String USERNICK = "usernick";
public static final String AVATAR_URL = "avatar_url";
public static final String PORTRAIT = "portrait";
public static final String OAUTH_TOKEN = "oauth_token";
public static final String OAUTH_TOKEN_SECRET = "oauth_token_secret";
public static final String INFOJSON = "json";
}
下面代码展示了如何继承SQLiteOpenHelper创建数据库,推荐使用单例类:
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import org.qii.weiciyuan.support.database.table.*;
class DatabaseHelper extends SQLiteOpenHelper {
private static DatabaseHelper singleton = null;
private static final String DATABASE_NAME = "weibo.db";
private static final int DATABASE_VERSION = 16;
static final String CREATE_ACCOUNT_TABLE_SQL = "create table " + AccountTable.TABLE_NAME
+ "("
+ AccountTable.UID + " integer primary key autoincrement,"
+ AccountTable.OAUTH_TOKEN + " text,"
+ AccountTable.OAUTH_TOKEN_SECRET + " text,"
+ AccountTable.PORTRAIT + " text,"
+ AccountTable.USERNAME + " text,"
+ AccountTable.USERNICK + " text,"
+ AccountTable.AVATAR_URL + " text,"
+ AccountTable.INFOJSON + " text"
+ ");";
DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_ACCOUNT_TABLE_SQL);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
switch (oldVersion) {
default:
deleteAllTable(db);
onCreate(db);
}
}
public static synchronized DatabaseHelper getInstance() {
if (singleton == null) {
singleton = new DatabaseHelper(GlobalContext.getInstance());
}
return singleton;
}
private void deleteAllTable(SQLiteDatabase db) {
db.execSQL("DROP TABLE IF EXISTS " + AccountTable.TABLE_NAME);
}
}
增删改查数据库
因为SQLite支持标准的SQL语句,因此我们可以用标准SQL语句才增删改查数据库,推荐使用占位符的sql语句,看起来更加清爽,下面是我的代码示例:
package com.hw.droid.hwcatalog;
public class DatabaseManager {
private static DatabaseManager singleton = null;
private SQLiteDatabase wsd = null;
private SQLiteDatabase rsd = null;
private DatabaseManager() {
}
public static DatabaseManager getInstance(Context context) {
if (singleton == null) {
synchronized (DatabaseManager.class) {
if (singleton == null) {
DatabaseHelper databaseHelper = DatabaseHelper.getInstance(context);
singleton = new DatabaseManager();
singleton.wsd = databaseHelper.getWritableDatabase();
singleton.rsd = databaseHelper.getReadableDatabase();
}
}
}
return singleton;
}
public void initAccountTable(List<AccountData> listDatas) {
if (listDatas == null || listDatas.size() <= 0) {
return;
}
wsd.beginTransaction();
try {
for (AccountData data : listDatas) {
insertAccountTable(data);
}
wsd.setTransactionSuccessful();
} finally {
wsd.endTransaction();
}
}
private void insertAccountTable(AccountData accData) {
String sql = "insert into " + AccountTable.TABLE_NAME + "(" + AccountTable.USERNAME + ", "
+ AccountTable.USERNICK + ", " + AccountTable.AVATAR_URL + ", " + AccountTable.PORTRAIT + ", "
+ AccountTable.OAUTH_TOKEN + ", " + AccountTable.OAUTH_TOKEN_SECRET + ", " + AccountTable.INFOJSON
+ " " + ")" + " values(?, ?, ?, ?, ?, ?, ?)";
wsd.execSQL(sql,
new Object[] { accData.getUserName(), accData.getUserNick(), accData.getUrl(), accData.getPort(),
accData.getToken(), accData.getSecret(), accData.getJson(), accData.getThreads(), });
}
public List<AccountData> getAccountDatas() {
List<AccountData> listDatas = selectAccountData();
return listDatas;
}
private List<AccountData> selectAccountData() {
List<AccountData> listAccountData = new ArrayList<AccountData>();
String querySql = "select " + AccountTable.USERNAME + ", " + AccountTable.USERNICK + ", " + AccountTable.AVATAR_URL + ", " + AccountTable.PORTRAIT + ", " + AccountTable.OAUTH_TOKEN + ", " + AccountTable.OAUTH_TOKEN_SECRET + ", " + AccountTable.INFOJSON " " + " from " + BbsForumsTable.TABLE_NAME;
Cursor cursor = rsd.rawQuery(querySql, null);
if (cursor.moveToFirst()) {
do {
AccountData data = new AccountData();
data.setUserName(cursor.getString(cursor.getColumnIndex(AccountTable.USERNAME)));
data.setUserNick(cursor.getString(cursor.getColumnIndex(AccountTable.USERNICK)));
data.setUrl(cursor.getString(cursor.getColumnIndex(AccountTable.AVATAR_URL)));
data.setPort(cursor.getString(cursor.getColumnIndex(AccountTable.PORTRAIT)));
data.setToken(cursor.getString(cursor.getColumnIndex(AccountTable.OAUTH_TOKEN)));
data.setSecret(cursor.getString(cursor.getColumnIndex(AccountTable.OAUTH_TOKEN_SECRET)));
data.setJson(cursor.getString(cursor.getColumnIndex(AccountTable.INFOJSON)));
listAccountData.add(data);
} while (cursor.moveToNext());
}
cursor.close();
return listAccountData;
}
public void deleteBbsDatas() {
String delSql = "delete from " + AccountTable.TABLE_NAME;
wsd.execSQL(delSql);
}
}
事物(DBTransaction)
Android中经常会用到数据库缓存,特别是wifi情况下遇到数据不一致情况需要更新缓存数据,这个时候就需要用到事物处理,保证操作的完整性和速度。Android中使用SQLite保证事务完整性示例如下:
public void initAccountTable(List<AccountData> listDatas) {
if (listDatas == null || listDatas.size() <= 0) {
return;
}
wsd.beginTransaction();
try {
for (AccountData data : listDatas) {
insertAccountTable(data);
}
wsd.setTransactionSuccessful();
} finally {
wsd.endTransaction();
}
}
通过beginTransaction()开启事务,endTransaction()结束事务,并且设置事务执行成功标识setTransactionSuccessful().
更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作SQLite数据库技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结》
希望本文所述对大家Android程序设计有所帮助。
# Android
# SQLite数据库
# 操作方法
# Android SQLite事务处理结合Listview列表显示功能示例
# Android开发笔记SQLite优化记住密码功能
# Android利用listview控件操作SQLite数据库实例
# Android批量插入数据到SQLite数据库的方法
# Android SQLite数据库基本操作方法
# Android使用SQLite数据库的示例
# android SQLite数据库总结
# Android SQLite数据库版本升级的管理实现
# 操作技巧
# 类似于
# 推荐使用
# 个旧
# 创建一个
# 应用程序
# 进阶
# 情况下
# 几个
# 很好
# 相关内容
# 子类
# 就有
# 可以用
# 其他的
# 感兴趣
# 相关文章
# 帐号
# 给大家
# 这个时候
相关文章:
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
如何在Windows虚拟主机上快速搭建网站?
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
山东网站制作公司有哪些,山东大源集团官网?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
教学论文网站制作软件有哪些,写论文用什么软件
?
,在苏州找工作,上哪个网站比较好?
如何配置FTP站点权限与安全设置?
如何获取免费开源的自助建站系统源码?
历史网站制作软件,华为如何找回被删除的网站?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
东莞专业制作网站的公司,东莞大学生网的网址是什么?
如何通过PHP快速构建高效问答网站功能?
建站之星在线客服如何快速接入解答?
如何快速生成橙子建站落地页链接?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
如何用AWS免费套餐快速搭建高效网站?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何快速生成可下载的建站源码工具?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
SQL查询语句优化的实用方法总结
一键网站制作软件,义乌购一件代发流程?
音乐网站服务器如何优化API响应速度?
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
如何用西部建站助手快速创建专业网站?
淘宝制作网站有哪些,淘宝网官网主页?
广州营销型建站服务商推荐:技术优势与SEO优化解析
微信小程序 input输入框控件详解及实例(多种示例)
定制建站如何定义?其核心优势是什么?
如何通过商城自助建站源码实现零基础高效建站?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
临沂网站制作公司有哪些,临沂第四中学官网?
如何零基础在云服务器搭建WordPress站点?
如何通过山东自助建站平台快速注册域名?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何选择香港主机高效搭建外贸独立站?
网站制作网站,深圳做网站哪家比较好?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
表情包在线制作网站免费,表情包怎么弄?
开心动漫网站制作软件下载,十分开心动画为何停播?
建站之星各版本价格是多少?
c++ stringstream用法详解_c++字符串与数字转换利器
实现虚拟支付需哪些建站技术支撑?
css网站制作参考文献有哪些,易聊怎么注册?
网站制作说明怎么写,简述网页设计的流程并说明原因?
家庭服务器如何搭建个人网站?
如何在IIS服务器上快速部署高效网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。