android 读取本地数据库db文件(Android sqlite)

发布时间 2023-04-14 16:24:14作者: cps666

本文由 简悦 SimpRead 转码, 原文地址 cloud.tencent.com 腾讯云备案控制台开发者社区学习实践活动专区工具TVP广告文章/答案/技术大牛搜索搜索关闭写文章提问登录/注册

全栈程序员站长

55.1K 篇文章

android 读取本地数据库db文件(Android sqlite)

转到我的清单专栏首页全栈程序员必看android 读取本地数据库db文件(Android sqlite)[](javascript:?[1](javascript:?[0](javascript:?[](javascript:;)分享

  • [](javascript:?Scan me!

    分享文章到朋友圈

  • [](javascript:;)分享文章到 QQ

  • [](javascript:;)分享文章到微博

  • [](javascript:;)复制文章链接到剪贴板

海报分享Scan me!

海报分享

android 读取本地数据库db文件(Android sqlite)

发布于2022-09-03 17:58:38阅读 1.1K0

大家好,又见面了,我是你们的朋友全栈君。

我们知道Android中有四种数据存储方式:

  1. SharedPreference存储
  2. content provider
  3. SQLite数据库存储
  4. 文件存储

今天我们主要说 本地数据库sqlite这种方式,实现读取一个本地数据库db文件的功能。为了方便说明,我举个例子来讲:

我们创建一个本地数据库,里面包含两张表 一个用户表user 一个性别表 gender

要求:1.将用户表中用户查询出来,性别需要显示男女,用listView展示出来。

2.修改 将用户表中 王杰修改为李四

3.增加长按删除功能

非常简单的功能,那么我们实现这个需要做以下几步操作。

1.将本地数据库db文件拷贝到项目中

2.将项目中db文件写入到本地文件夹中

3.增加打开数据库以及数据读取逻辑

4.增加删除逻辑 ,增加修改逻辑。

需要注意的有几点:

1)拷贝数据库涉及到读写 ,所以权限这块需要注意,如果是22以上的需要申请权限,否则会报错。

2)assets文件夹是在main文件夹下面建和res是平级,之前很多来面试的还把文件夹都放错了。

3)读取用户时候,性别一栏是需要做关联查询的 ,因为用户表性别用的是字典值。

Android拷贝逻辑代码

package com.example.testdemo.util;

import android.content.Context;
import android.os.Environment;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

public class FileUtil {

    private static String mWorkPath = null;
    private static String mRootPath = null;
    private static Boolean mGetSDpath = false;
    private final static String DB_PATH_NAME = "database/";
    public static long copyTime = 0;

    private static Context mContext;

    public static String getRootPath() {
        if (!mGetSDpath || mRootPath == null) {
            mGetSDpath = true;
            boolean sdCardExist = Environment.getExternalStorageState().equals(
                    Environment.MEDIA_MOUNTED); // 判断sd卡是否存在
            if (sdCardExist) {
                File sdDir = Environment.getExternalStorageDirectory();// 获取跟目录
                mRootPath = sdDir.toString();
            } else {
                mRootPath = mContext.getFilesDir().toString();
            }
        }
        if (!mRootPath.endsWith("/"))
            mRootPath += "/";
        return mRootPath;
    }

    /**
     * 设置工作目录
     *
     * @param context app context,不然会造成内存泄漏
     * @param path
     */
    public static void setWorkPath(Context context, String path) {
        mContext = context;
        if (null != getRootPath()) {
            mWorkPath = mRootPath + path;
        }
        if (!mWorkPath.endsWith("/")) {
            mWorkPath += "/";
        }

        File file = new File(mWorkPath);
        if (!file.exists()){
            boolean b = file.mkdirs();
        }
    }

    public static String getDBpath() {
        File file = new File(mWorkPath + DB_PATH_NAME);
        if (!file.exists())
            file.mkdirs();
        return mWorkPath + DB_PATH_NAME;
    }

    public static void copyAccessDB(Context context) {
        try {
            String[] dbNames = context.getAssets().list("db");
            for (String dbName : dbNames) {
                long startTime = System.currentTimeMillis();
                String filePath = FileUtil.getDBpath() + dbName;
                File dbFile = new File(filePath);
                if (!dbFile.exists()) {
                    FileOutputStream fos = null;
                    try {
                        dbFile.createNewFile();
                    }catch (Exception e){
                    }
                    InputStream is = context.getAssets().open("db/" + dbName);
                    fos = new FileOutputStream(dbFile);

                    byte[] buffer = new byte[2048];
                    int len = -1;
                    while ((len = is.read(buffer)) != -1) {
                        fos.write(buffer, 0, len);
                    }
                    fos.close();
                    long endTime = System.currentTimeMillis();
                    long useTime = endTime - startTime;
                    copyTime += useTime;
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

复制

Android 本地 操作数据库逻辑(查,删,改)

package com.example.testdemo.util;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Environment;

import com.example.testdemo.bean.User;

import java.util.ArrayList;
import java.util.List;

public class DBManager {

    private Context mContext;
    private SQLiteDatabase mDB;
    private static String dbPath = FileUtil.getDBpath() + "/Test.db";
    private static DBManager instance = null;

    public DBManager() {
    }

    public static DBManager getInstance() {
        if (instance == null) {
            instance = new DBManager();
        }
        return instance;
    }

    /**
     * 打开数据库
     */
    private void openDB() {
        if (isSDCard()) {
            if (mDB == null || !mDB.isOpen())
                mDB = SQLiteDatabase.openDatabase(dbPath, null,
                        SQLiteDatabase.OPEN_READWRITE);
        }
    }
    private boolean isSDCard() {
        return Environment.getExternalStorageState().equals(
                Environment.MEDIA_MOUNTED);
    }

    //查询选择题
    public List<User> queryUser() {
        List<User> userList = new ArrayList<User>();
        User user= null;
        openDB();
        try {
            String sql = " select a.id,a.name,a.age,a.phoneNum,b.name as sexName from user a,gender b where a.sex= b.type";
            Cursor cursor = mDB.rawQuery(sql, null);
            while (cursor.moveToNext()) {
                String id = cursor.getString(cursor.getColumnIndex("id"));
                String name = cursor.getString(cursor.getColumnIndex("name"));
                String sex = cursor.getString(cursor.getColumnIndex("sexName"));
                String age = cursor.getString(cursor.getColumnIndex("age"));
                String phoneNum = cursor.getString(cursor.getColumnIndex("phoneNum"));
                user= new User();
                user.setId(id);
                user.setName(name);
                user.setAge(age);
                user.setPhoneNum(phoneNum);
                user.setSex(sex);
                userList.add(user);
            }
            cursor.close();
            return userList;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    public void updateUser() {
        openDB();
        String sql = " update  user  set name = '李四' where name = '王杰' ";
        mDB.execSQL(sql);
    }

    public void deleteUser(String id) {
        openDB();
        mDB.delete("user", " id = ? ", new String[]{id});
    }


}

复制

基本最核心的就这些代码,不是很复杂,贴上效果图。

我知道有的小伙伴需要完整的DEMO,所以我就整理了一个 ,在这里DEMO下载

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/138369.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体分享计划 ,欢迎热爱写作的你一起参与!本文分享自作者个人站点/博客:[复制](javascript:void(0);)如有侵权,请联系 cloudcommunity@tencent.com 删除。[展开阅读全文](javascript:?

数据库sqlandroidhttpsjava

[举报](javascript:;)点赞 1分享

[登录](javascript:? 后参与评论_0_ 条评论

相关文章

  • Android数据读取之Sqlite数据库操作

    咱们书接上文,继续来说说Android数据读取,这回,我们要讲的是Sqlite数据库的相关操作。以一个实例开始吧:

    lzugis

  • android读取sqlite数据库的数据并用listview显示

    刚刚接触android,老师给了我了几个班级信息的excel,让我做一个考勤的系统出来,本篇仅记录了真机调试下,读取已有静态数据库并显示在listview中。

    全栈程序员站长

  • Android SQLite数据库

    SQLiteOpenHelper 抽象类有两个抽象方法:onCreate() onUpgrade() 创建和升级数据库

    SakuraTears

  • 基于 Android 读取微信本地 DB 数据 | 思维原理及技术分析

    该移动端软件基于Android开发,是一个解析微信数据信息(包括微信个人资料、联系人、聊天记录等)并重装报文同步至服务端的一款应用。其实实属公司业务需要而开发的...

    AlicFeng

  • 实现Android本地Sqlite数据库网络传输到PC端

    在开发初期,当Android端嵌入在硬件中,并且本地数据库单机业务逻辑挺多,往往要分析数据是否处理正常,需要直接从数据库中查看,这时我们一般都是将数据库拷贝到P...

    Vaccae

  • Android SQLite 数据库学习

      SQLite 是一个轻量级数据库,它是D. Richard Hipp建立的公有领域项目,在2000年发布了第一个版本。它的设计目标是嵌入式的,而且占用资源非...

    星哥玩云

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

    Android 之 SMS 短信在Android系统中是保存在SQLite数据库中的,但不让其它程序访问(Android系统的安全机制)

    阳光岛主

  • android r文件丢失_读取文件

    在用Eclipse做开发的时候,总是无缘无故缺少R文件,让整个项目报废,在网上查了资料后现在做一下整理。

    全栈程序员站长

  • 【Android 逆向】使用 DB Browser 查看并修改 SQLite 数据库 ( 从 Android 应用数据目录中拷贝数据库文件 | 使用 DB Browser 工具查看数据块文件 )

    进入 /data/data/com.qidian.QDReader/databases 目录 , 拷贝 2 个 sqlite3 数据库文件到 sd 卡中 ;

    韩曙亮

  • 读取本地数据库文件[通俗易懂]

    有时候我们能够将类似省份城市的数据库文件存放在assets/目录名/××.sql下。当程序在创建数据库时读取该数据库文件,并运行其内的sql语句

    全栈程序员站长

  • Android开发实现读取assets目录下db文件的方法示例

    本文实例讲述了Android开发实现读取assets目录下db文件的方法。分享给大家供大家参考,具体如下:

    砸漏

  • Android之ListView,AsyncTask,GridView,CardView,本地数据存储,SQLite数据库

    补充上一节,使用ListView是用来显示列表项的,使用ListView需要两个xml文件,一个是列表布局,一个是单个列表项的布局。如我们要在要显示系统所有ap...

    达达前端

  • Android SQLite数据库基本操作

    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–...

    指点

  • Android中SQLite数据库小计

    2016-03-16 Android数据库支持 本文节选并翻译《Enterprise Android - Programing Android Database...

    用户1172465

  • Android SQLite数据库基本用法详解

    public class DBHelper extends SQLiteOpenHelper{

    奶油话梅糖

  • android之SQLite数据库insert操作

    long android.database.sqlite.SQLiteDatabase.insert(String table, String nullColu...

    全栈程序员站长

  • 【Android 逆向】使用 DB Browser 查看并修改 SQLite 数据库 ( 下载 DB Browser 安装包 | 安装 DB Browser 工具 )

    DB Browser 官网 : http://www.sqlitebrowser.org/

    韩曙亮

  • 【Android】数据存储(三) 数据库(SQLite)

    Gavin-ZYX

  • 【Android 应用开发】Android 数据存储 之 SQLite数据库详解

    转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19028665

    韩曙亮

更多文章

作者介绍

全栈程序员站长

CTO关注专栏

精选专题

活动推荐

运营活动

活动名称广告[关闭](javascript:?

关注

腾讯云_开发者_公众号将获得10元无门槛代金券洞察腾讯核心技术剖析业界实践案例腾讯云开发者公众号二维码

腾讯云开发者

扫码关注腾讯云开发者

领取腾讯云代金券

热门产品

热门推荐

更多推荐

Copyright © 2013 - 2023 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有

深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569

腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 |京公网安备号11010802020287

扫描二维码

扫码关注腾讯云开发者

领取腾讯云代金券