IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android Studio导入外部数据库(使用Sqlite expert pro创建外部数据库) -> 正文阅读

[移动开发]Android Studio导入外部数据库(使用Sqlite expert pro创建外部数据库)

在各个博客网站查询了很多方法,虽然能够导入,但是表是空的,个人判断是外部数据库类型(如后缀为db,sql)的原因,改为sqlite类型的数据库就可以正常导入所有外部数据库的信息了,以下是导入的几个步骤:

方法一是使用虚拟机的目录的upload方法直接导入,具体步骤去查其他博主的吧,这里主要讲使用代码来写入外部的数据库:

在这里插入图片描述

方法二,代码导入:
1.创建外部数据库和数据表:

在这里插入图片描述
并把该数据库放到项目中的assets或者raw这两个目录中(自行创建的目录)
![在这里插入图片描述](https://img-blog.csdnimg.cn/944d682a2fec453fa1986aaa282abc36.png在这里插入图片描述在这里插入图片描述
在这里插入图片描述

2.创建IO流的封装类来写入数据库:

public class NationOpenDB {
    private final int BUFFER_SIZE = 400000;
    public static final String DB_BANE = "nations.sqlite";//保存的数据库文件名称
    public static final String PACKAGE_NAME = "com.example.test2";//应用的包名
    public static final String DB_PATH = "/data" + Environment.getDataDirectory().getAbsolutePath() + "/"
            + PACKAGE_NAME + "/databases";//在手机里存放数据库的位置
    private Context context;//组件的上下文

    public NationOpenDB(Context context) {
        this.context = context;
    }
    public SQLiteDatabase openDatabase(){
        try {
            File myDataPath = new File(DB_PATH);
            if (!myDataPath.exists()) {
                myDataPath.mkdirs();
            }
            String dbFile = myDataPath + "/" + DB_BANE;
            if (!(new File(dbFile).exists())) {
                InputStream is = context.getAssets().open(DB_BANE);
                //InputStream is = context.getResources().openRawResource(R.raw.nations);
                FileOutputStream fos = new FileOutputStream(dbFile);
                byte[] buffer = new byte[BUFFER_SIZE];
                int count = 0;
                while ((count = is.read(buffer)) !=-1) {
                    Log.e("test2", "写入"+String.valueOf(count));
                    fos.write(buffer, 0, count);
                }
                fos.flush();
                fos.close();
                is.close();
            }

            SQLiteDatabase db = SQLiteDatabase.openOrCreateDatabase(dbFile, null);
            return db;
        } catch (FileNotFoundException e) {
            Log.e("test2", "File not found!");
            e.printStackTrace();
        } catch (IOException e) {
            Log.e("test2", "IO exception");
            e.printStackTrace();
        }
        Log.e("test2", "没有??!");
        return null;
    }
}

注意这些成员变量:DB_NAME(使用sqlite文件类型的数据库),PACKAGE_NAME(应用包名)

3.创建存储各条数据的实体类和实现测试

public class Nations {
    public Integer id;
    public String nation;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getNation() {
        return nation;
    }

    public void setNation(String nation) {
        this.nation = nation;
    }
}
protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        NationOpenDB nation = new NationOpenDB(this);
        List<Nations> nationList = new ArrayList<Nations>();
        SQLiteDatabase sqLiteDatabase = nation.openDatabase();
        Cursor cursor = sqLiteDatabase.rawQuery("select *from china_nations", null);
        //Cursor cursor = sqLiteDatabase.query("china_nations", new String[]{"id", "nation"}, null, null, null, null, null);
        Log.e("test2", "cursor:" + String.valueOf(cursor.getCount()));
        while (cursor.moveToNext()) {
            Nations nations = new Nations();
            Integer id = cursor.getInt(cursor.getColumnIndex("id"));
            String nationName = cursor.getString(cursor.getColumnIndex("nation"));
            nations.setId(id);
            nations.setNation(nationName);
            nationList.add(nations);
        }
        for (Nations nations1 : nationList) {
            Log.e("test2",nations1.id + " " + nations1.nation);
        }
    }

4.Log结果
在这里插入图片描述

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 11:29:58  更:2022-05-05 11:32:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 23:57:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码