Android 数据库SQLite 写入SD卡的方法

 更新时间:2016年04月01日 12:00:32   作者:虫葛尔Chongger  
如果手机没有root,数据库文件是无法查看到的,不方便调试。最好的办法是把数据库写进SD卡。通过本文给大家介绍Android 数据库SQLite 写入SD卡的方法,需要的朋友参考下吧

如果手机没有root,数据库文件是无法查看到的,不方便调试。

最好的办法是把数据库写进SD卡。

修改的地方有两处:

1.在你的helper类中把数据库文件名称 DATABASE_NAME 由原来的一个文件名,修改成路径的形式。

修改前:DATABASE_NAME = "demo.db"

public class MyDBHelper extends SQLiteOpenHelper {
public static final int VERSION = 1; //数据库版本号
public static final String DATABASE_NAME = "demo.db"; //数据库名称
public static final String TABLE_NAME = "mytag"; //数据表名称,一个数据库可以包含多张数据表,类似于excel中的sheet1,sheet2
//MyDBHelper 的构造函数,我们关心的是名称DATABASE_NAME和版本VERSION
public MyDBHelper(Context context) {
super(context, DATABASE_NAME, null, VERSION);
}

修改后:DATABASE_NAME = "/mnt/sdcard/demo.db"

public class MyDBHelper extends SQLiteOpenHelper {
public static final int VERSION = 1; //数据库版本号
public static final String DATABASE_NAME = "/mnt/sdcard/demo.db"; //数据库名称
public static final String TABLE_NAME = "mytag"; //数据表名称,一个数据库可以包含多张数据表,类似于excel中的sheet1,sheet2
//MyDBHelper 的构造函数,我们关心的是名称DATABASE_NAME和版本VERSION
public MyDBHelper(Context context) {
super(context, DATABASE_NAME, null, VERSION);
}

因为如果只是一个单独的文件名,最后创建的数据库文件就是保存在手机内部存储卡(不是运行内存,也不是SD卡)的/data/data/包名称/databases 目录下,而没有root的手机,这个/data根文件夹是进不去的,用adb shell方式也打不开。

2.最后,千万别忘了修改权限!

Android手机是有着严格的安全管控的,SD卡属于外部存储器,访问上面的文件需要添加权限。

在AndroidManifest.xml 中添加两条SD卡读写权限即可:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> 

如果没有添加权限,那么程序就会异常终止。

以上所述是针对Android 数据库SQLite 写入SD卡的方法,希望对大家有所帮助!

相关文章

  • Android实现多线程断点下载

    Android实现多线程断点下载

    大家好,本篇文章主要讲的是Android实现多线程断点下载,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • Android振动器使用方法详解

    Android振动器使用方法详解

    这篇文章主要为大家详细介绍了Android振动器使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • AsyncTask的三个属性值和四个步骤

    AsyncTask的三个属性值和四个步骤

    本文主要介绍了AsyncTask的三个属性值和四个步骤,具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Flutter应用框架搭建实现屏幕适配方案详解

    Flutter应用框架搭建实现屏幕适配方案详解

    移动设备多样性,特别是Android的碎片化严重,存在各种各样的分辨率,flutter跨平台开发又需要同时支持Android和IOS,为尽可能的还原设计图效果提升用户的体验,根据设计稿设计屏幕ui的时候我们需要考虑到屏幕适配的问题
    2022-11-11
  • Android开发实现高仿优酷的客户端图片左右滑动切换功能实例【附源码下载】

    Android开发实现高仿优酷的客户端图片左右滑动切换功能实例【附源码下载】

    这篇文章主要介绍了Android开发实现高仿优酷的客户端图片左右滑动切换功能,结合实例形式分析了Android基于ViewPager实现图片切换效果的相关操作技巧,并附带完整工程源码供读者下载参考,需要的朋友可以参考下
    2017-11-11
  • Android设置控件阴影的三种方法

    Android设置控件阴影的三种方法

    这篇文章主要为大家详细介绍了Android设置控件阴影的三种方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • android surfaceView实现播放视频功能

    android surfaceView实现播放视频功能

    这篇文章主要为大家详细介绍了android surfaceView实现播放视频功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • Android仿微信实现下拉列表

    Android仿微信实现下拉列表

    这篇文章主要介绍了Android仿微信实现下拉列表的相关资料,需要的朋友可以参考下
    2015-12-12
  • JetPack Compose底部导航栏的实现方法详解

    JetPack Compose底部导航栏的实现方法详解

    开发一个新项目,底部导航栏一般是首页的标配,在以前的xml布局中,我们可以很轻松的是用谷歌提供的BottomNavigationView或者自定义来实现底部导航的功能,在Compose中也有也提供了一个类似的控件androidx.compose.material.BottomNavigation
    2022-09-09
  • Android实现扩展Menu的方法

    Android实现扩展Menu的方法

    这篇文章主要介绍了Android实现扩展Menu的方法,涉及Android操作menu菜单的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10

最新评论