SQLite -- 嵌入式关系型数据库

	1。SQLite的数据类型:Typelessness(无类型)
1,能够保存不论什么类型的数据到表的随意列中
2。支持常见的类型如: NULL, VARCHAR, TEXT, INTEGER, BLOB, CLOB等
3,唯一的例外:integer primary key 此字段仅仅能存储64位整数,即当主键被定义为integer时仅仅能存储64位整数 注意:SQLite数据库中列一旦创建不能改动,假设一定要改动,须要又一次创建表,拷贝数据 2,Android提供了一个SQLiteOpenHelper抽象类。该类用于管理数据库的版本号,经常使用的3个方法:
onCreate 数据库创建时运行(第一次连接数据库,获取数据库对象时运行) 注:数据库什么时候创建?第一次连接数据库时创建数据库(文件)。此时onCreate会被调用
openHelper.getReadableDatabase();
openHelper.getWritableDatebase(); getReadableDatabase()和getWritableDatabase()的差别:
查看源码可知:getReadableDatabase()在通常情况下返回的就是getWritableDatabase()拿到的数据库。仅仅有在抛出异常的时候才会以仅仅读方式打开 onUpgrade 数据库更新时运行(一般每次更新时都要改动版本号号)
onOpen 数据库每次打开时运行(每次打开数据库时调用,在onCreate,onUpgrade方法之后) 3,Android提供了一个SQLiteDatabase类,使用该类能够对数据进行CRUD的操作 注:和JDBC訪问数据库不同,操作SQLite数据库无需载入驱动,不用获取连接,直接使用SQLiteDatabase对象运行SQL语句 execSQL(String sql)方法能够运行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句;
execSQL(String sql, Object[] bindArgs)方法的第一个參数为SQL语句。第二个參数为SQL语句中占位符參数的值。參数值在数组中的顺序要和占位符的位置相应。
rawQuery()方法用于运行select语句。 SQLiteDatabase还封装了 insert()、delete()、update()、query()4个方法。也能够对数据库进行操作 Cursor是结果集游标。用于对结果集进行随机訪问,Cursor与JDBC中的ResultSet作用一样。使用moveToNext()方法能够将游标从当前行移动到下一行,假设已经移过了结果集的最后一行,返回结果为false。否则为true。 SQLiteDatabase中的事务控制: beginTransaction() 开启事务
setTransactionSuccessful() 设置事务成功标记
endTransaction() 结束事务 注:endTransaction()须要放在finally中运行,否则事务仅仅有到超时的时候才自己主动结束,会减少数据库并发效率

SQLite -- 嵌入式关系型数据库的更多相关文章

  1. 使用嵌入式关系型SQLite数据库存储数据

    除了可以使用文件或SharedPreferences存储数据,还可以选择使用SQLite数据库存储数据. 在Android平台上,集成了一个嵌入式关系型数据库—SQLite, 1.SQLite3支持 ...

  2. sqlite嵌入式数据库简介及特性

    p.p1 { margin: 0; font: 12px "Helvetica Neue"; color: rgba(69, 69, 69, 1) } p.p2 { margin: ...

  3. SQLite vs MySQL vs PostgreSQL:关系型数据库比较

    自1970年埃德加·科德提出关系模型之后,关系型数据库便开始出现,经过了40多年的演化,如今的关系型数据库种类繁多,功能强大,使用广泛.面对如此之多的关系型数据库,我们应该如何权衡找出适合自己应用场景 ...

  4. sqlite嵌入式数据库C语言基本操作(1)

    sqlite嵌入式数据库C语言基本操作(1) :first-child{margin-top:0!important}img.plugin{box-shadow:0 1px 3px rgba(0,0, ...

  5. Python信息采集器使用轻量级关系型数据库SQLite

    1,引言Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言.SQLite作为后端数据库,可以搭配Python建网站,或者为python网络爬虫存储数据.SQLite还在其它 ...

  6. SQLite/嵌入式数据库

    SQLite/嵌入式数据库 的项目要么不使用数据库(一两个文配置文件就可以搞定),要么就会有很多的数据,用到 postgresql,操练sqlite的还没有.现在我有个自己的小测试例子,写个数据库对比 ...

  7. 非关系型数据库(NoSql)

    最近了解了一点非关系型数据库,刚刚接触,觉得这是一个很好的方向,对于大数据 方面的处理,非关系型数据库能起到至关重要的地位.这里我主要是整理了一些前辈的经验,仅供参考. 关系型数据库的特点 1.关系型 ...

  8. 关系型数据库工作原理-时间复杂度(翻译自Coding-Geek文章)

    本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-dat ...

  9. 关系型数据库工作原理-事务管理(二)(翻译自Coding-Geek文章)

    本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-dat ...

随机推荐

  1. angular-Scope

    Scope(作用域) 是应用在 HTML (视图) 和 JavaScript (控制器)之间的纽带. Scope 是一个对象,有可用的方法和属性. Scope 可应用在视图和控制器上. 当你在 Ang ...

  2. 洛谷 P3912 素数个数

    P3912 素数个数 题目描述 求1,2,\cdots,N1,2,⋯,N 中素数的个数. 输入输出格式 输入格式: 1 个整数NN. 输出格式: 1 个整数,表示素数的个数. 输入输出样例 输入样例# ...

  3. dubbo知识点理解

    1.分布式服务架构关键在于:用于提高业务复用及整合的 分布式服务框架(RPC) 是关键.注册中心是关键,提供业务复用和整合. 2.dubbo在消费方,获取服务列表后提供软负载均衡.dubbo在消费方提 ...

  4. 【转载】黑客内核:编写属于你的第一个Linux内核模块

    黑客内核:编写属于你的第一个Linux内核模块

  5. D3js-绘制地图时出现过小, 设置scale还是无效 的解决方法

    使用d3绘制某个地市的地图时,把scale成非常大但是还是无法达到想要的效果. //---------------------------------------------------------- ...

  6. Android使用有道翻译API实如今线翻译功能

    在Android应用中,加入在线翻译的功能,这里调用的是有道翻译的API. 使用有道翻译API.首先要申请一个key,申请地址为:path=data-mode">有道翻译API申请地址 ...

  7. php,二维数组的输出出现了问题,提示:Notice: Array to string conversion

    <?php $arr=array(array("111","222","333"),array("444",&qu ...

  8. [jzoj 5343] [NOIP2017模拟9.3A组] 健美猫 解题报告 (差分)

    题目链接: http://172.16.0.132/senior/#main/show/5343 题目: 题解: 记旋转i次之后的答案为$ans_i$,分别考虑每个元素对ans数组的贡献 若$s_i& ...

  9. Mysqldump逻辑备份与恢复

    文档结构: mysqldump备份影响性能,可能会把内存里面的热数据给冲刷掉,5.7后,新增一个参数,innodb_buffer_pool_dump_pct,控制每个innodb_buffer中转存活 ...

  10. hiho160周 - 字符串压缩,经典dp

    题目链接 小Hi希望压缩一个只包含大写字母'A'-'Z'的字符串.他使用的方法是:如果某个子串 S 连续出现了 X 次,就用'X(S)'来表示.例如AAAAAAAAAABABABCCD可以用10(A) ...