首页
学习
活动
专区
圈层
工具
发布

Android SMS(二)—— 读取短信保存到 SQLite

Android 之 SMS 短信在Android系统中是保存在SQLite数据库中的,但不让其它程序访问(Android系统的安全机制) 现在我们在读取手机内的SMS短信,先保存在我们自己定义的SQLite...数据库中,然后读取SQLite数据库提取短信,并显示 SMS短信SQLite存取代码: package com.homer.sms; import java.sql.Date; import java.text.SimpleDateFormat...; import android.database.sqlite.SQLiteDatabase; import android.graphics.Color; import android.net.Uri...; import android.widget.TableRow.LayoutParams; import android.widget.TextView; /** * 读取手机短信, 先保存到SQLite...desc"; return db.rawQuery(sql, null); } // 获取 SQLite 数据库中的最新 size 条短信 public Cursor querySMSInDatabase

1.9K30

Android 中 SQLite 性能优化

数据库是应用开发中常用的技术,在Android应用中也不例外。Android默认使用了SQLite数据库,在应用程序开发中,我们使用最多的无外乎增删改查。...索引的解释 重温一下我们小时候查字典的过程: 对于已经知道拼音的字,比如中这个字,我们只需要在拼音索引里面找到zhong,就可以确定这个字在词典中的页码。...然而正如西方谚语 “There are two sides of a coin”,索引亦有缺点: 对于增加,更新和删除来说,使用了索引会变慢,比如你想要删除字典中的一个字,那么你同时也需要删除这个字在拼音索引和部首索引中的信息...编译SQL语句 SQLite想要执行操作,需要将程序中的sql语句编译成对应的SQLiteStatement,比如select * from record这一句,被执行100次就需要编译100次。...statement.bindLong(1, System.currentTimeMillis()); statement.executeInsert(); } } 显式使用事务 在Android

1.5K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQLite在NDK中的重生

    经过一番搜索,找到了问题的原因,点此查看原文(http://ericsink.com/entries/sqlite_android_n.html),具体的原因是,Android N 以后,不再允许直接调用...再深入讲一句,其实 libdl.so 也无法再使用了,也就是说,在 NDK 中 dlopen 和 dlsym 这类函数也已被禁用。...这一步很简单,下载 SQLite 源码后,将它编译成适用于 Android 的 libsqlite.a。 ?...另一处崩溃在于 Android 老版本的兼容,在 Android M 以后,调用 NDK 时,不再检查 __aeabi_d2ulz 和 __aeabi_d2lz(虽然这两个函数具体做了什么我也不知道,但是反编译看函数体...这样就完成了对老版本 Android 的兼容。到了这一步,在 Android N 以上以 NDK 调用 SQLite 即告完成。 会!

    2K10

    在 Android Studio 上调试数据库 ( SQLite )

    以前 Eclipse 时代,调试 SQLite 都是将数据库文件导出到电脑,然后再用软件打开查看。现在我们用 Android Studio,有没有更方便的方法呢?...加载 成功安装后重启 Android Studio,会发现右边的侧边栏出现了 SQLite Exporer,展开后点击「+」会出现三个选项: image.png 我们从下往上说吧。...Local SQLite Database 如果要调试的数据库已经导出在电脑里了,就选择这一项来加载。...module 的 build.gradle 里面添加: compile 'com.idescout.sql:sqlscout-server:2.0'复制代码 在启动的 Activity 的 onCreate...,就会看到一个这样的界面: image.png 很容易理解,里面几个栏目分别是: Query:写 SQL 语句的地方 Databases:数据库 Tables:数据库中的表 Data:表中的数据,支持编辑

    4.2K21

    Android教程-保存数据-在SQL数据库中保存数据

    协议类让你可以在同一个包的所有其它类那里使用相同的常量. 这让你可以在一个地方对列名称的改变传播到你所有的代码. 组织一个协议类最好的方式是将对你的整个数据库全局可用的定义放置到类的根一级别 ....它也不是一定要有的,但它有助于你的数据库同Android框架更加的协调 .... 内部存储 中的文件, Android 将你的数据库保存在同应用程序相关联的私有磁盘空间上....注意: 以为它们可以是耗时较长的,请确保你是在一个后台线程中调用的 getWritableDatabase() 和 getReadableDatabase(), 使用诸如 AsyncTask 或者 IntentService...第二个参数提供在 ContentValues 为空的事件中,框架可以向其中插入NULL的一列的名称 (如果你将此设置为 "null", 那么在没有值的时候框架将不会插入一行 ).

    2.5K30

    sqlite在Android上的一个bug:SQLiteCantOpenDatabaseException when nativeExecuteForCursorWindow

    (AbstractCursor.java:258) 先给出结论, 这是sqlite在Android系统上的一个bug,在需要建立索引的sql语句频繁执行时,会发生这个异常。...catch住这个Exception后是可以继续执行一些DB查询的, 于是全都上了try – catch 重现路径 分析用户日志,发现用户的一些共性,由于业务保密限制这里总结一下,共性是DB中数据量很大...为了在sqlite native层打log,编译sqlite,使用sqlite3_log来输出自己想观察的信息。...即环境变量里没有设置这两个值, 而另外三个目录/var/tmp,/usr/tmp,/tmp在Android系统里都是应用不可写的, 所以会返回0给unixGetTemp, 于是unixGetTemp使用了...中会进入 OP_IdxInsert分支,然后   会调用sqlite3BtreeInsert,向B树中插入一个节点,   此时如果pPage满了,会执行balance平衡B树,   在这里面就会btreeGetPage

    2.2K90

    sqlite在Android上的一个bug:SQLiteCantOpenDatabaseException when nativeExecuteForCursorWindow

    (AbstractCursor.java:258) 先给出结论, 这是sqlite在Android系统上的一个bug,在需要建立索引的sql语句频繁执行时,会发生这个异常。...catch住这个Exception后是可以继续执行一些DB查询的, 于是全都上了try – catch 重现路径 分析用户日志,发现用户的一些共性,由于业务保密限制这里总结一下,共性是DB中数据量很大...为了在sqlite native层打log,编译sqlite,使用sqlite3_log来输出自己想观察的信息。...即环境变量里没有设置这两个值, 而另外三个目录/var/tmp,/usr/tmp,/tmp在Android系统里都是应用不可写的, 所以会返回0给unixGetTemp, 于是unixGetTemp使用了...中会进入 OP_IdxInsert分支,然后   会调用sqlite3BtreeInsert,向B树中插入一个节点,   此时如果pPage满了,会执行balance平衡B树,   在这里面就会btreeGetPage

    1.1K20

    sqlite在Android上的一个bug:SQLiteCantOpenDatabaseException when nativeExecuteForCursorWindow

    (AbstractCursor.java:258) 先给出结论, 这是sqlite在Android系统上的一个bug,在需要建立索引的sql语句频繁执行时,会发生这个异常。...catch住这个Exception后是可以继续执行一些DB查询的, 于是全都上了try – catch 重现路径 分析用户日志,发现用户的一些共性,由于业务保密限制这里总结一下,共性是DB中数据量很大...为了在sqlite native层打log,编译sqlite,使用sqlite3_log来输出自己想观察的信息。...即环境变量里没有设置这两个值, 而另外三个目录/var/tmp,/usr/tmp,/tmp在Android系统里都是应用不可写的, 所以会返回0给unixGetTemp, 于是unixGetTemp使用了...中会进入 OP_IdxInsert分支,然后   会调用sqlite3BtreeInsert,向B树中插入一个节点,   此时如果pPage满了,会执行balance平衡B树,   在这里面就会btreeGetPage

    93810

    Kotlin 协程和 Android SQLite API 中的线程模型

    在我们为 Room 添加协程的支持期间,我们遇到并解决了在协程模型和 Android SQL API 中没想到的一些问题。在本篇文章中,我们会向您阐述我们遇到的这些问题,以及我们的解决方案。...的 SQLite 事务受制于单个线程 上述代码中的问题在于 Android 的 SQLite 事务是受制于单个线程的。...在协程中使用数据库事务操作可能会引起死锁 简单实现 为了解决 Android SQLite 的这个限制,我们需要一个类似于 runInTransaction 这样可以接受挂起代码块的 API,这个 API...中 SQLite 的线程限制是合理的,这在 Kotlin 还没出现时已然如此设计了。...直接取消 Android 线程对 SQLite 事务的限制是不可行的,因为我们希望提供一个向后兼容的解决方案,而上述这些方法的组合最终让我们在使用协程和 Fluent API 的解决方案中发挥了创造性。

    2.4K20
    领券