设为首页 收藏本站
查看: 872|回复: 0

[经验分享] Android中SQLite操作示例

[复制链接]

尚未签到

发表于 2016-11-29 10:23:48 | 显示全部楼层 |阅读模式
  Android中SQLite操作示例

  在Android中对SQLite数据库的操作,涉及以下几个方面:

  1、确认数据库文件,即.db文件;

  2、通过android.database.sqlite.
SQLiteDatabase类的openOrCreateDatabase()方法打开数据库;

   3、数据库操作:

  A、开始事务:
SQLiteDatabase.beginTransaction();

  B、执行sql语句;

  C、结束事务:
SQLiteDatabase.endTransaction();

  具体代码可参考如下:


static boolean installDefaultSitesToDB(Context cxt) {
// 确认目标数据库文件
File path = cxt.getDir("databases", Context.MODE_WORLD_WRITEABLE);
path = new File(path, "db_name.db");

SQLiteDatabase db = null;
try {
// 打开数据库
 db = openDB(path.getAbsolutePath());
if (db == null) {
//Log.e("tag", "open db_name.db ERROR~");
return false;
}
db.beginTransaction();//开始事务
boolean bool = doInstallData(db);//执行sql语句,插入数据
//设置事务标志
if (bool) {
db.setTransactionSuccessful();// 设置事务标志
} else {
//Log.w("tag", "doInstall.DEFAULT_SITES Fail~!");
}
return bool;
} finally {
if (db != null) {
//结束事务
if (db.inTransaction()) {db.endTransaction();}
db.close();
}
}
}
private static SQLiteDatabase openDB(String file) {
try {
//SQLiteDatabase.openOrCreateDatabase(file, null);
int flag = SQLiteDatabase.OPEN_READWRITE;
flag = flag | SQLiteDatabase.CREATE_IF_NECESSARY;
flag = flag | SQLiteDatabase.NO_LOCALIZED_COLLATORS;
SQLiteDatabase db = SQLiteDatabase.openDatabase(file, null, flag);
return db;
} catch (Throwable e) {
//Log.e("tag","openDatabase error:" + e.getMessage());
return null;
}
}
//
private static boolean doInstallData(SQLiteDatabase db) {
try {
//create table
String sql = "CREATE TABLE IF NOT EXISTS Permissions (origin TEXT UNIQUE NOT NULL, allow INTEGER NOT NULL)";
db.execSQL(sql);
ContentValues cv = new ContentValues();
for (String site : DEFAULT_SITES) {
cv.clear();
cv.put("origin", site);
cv.put("allow", 1);
long ret = db.insertOrThrow("Permissions", null, cv);
Log.d("tag", "db.insert.RET:" + ret);
}
return true;
} catch (SQLException se) {
String msg = "doInstall.error:[%s].%s";
Log.d("tag",String.format(msg, se.getClass(),se.getMessage()));
return false;
}
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307111-1-1.html 上篇帖子: SQLite区分大小写查询 下篇帖子: android SQLite使用介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表