本文由 简悦 SimpRead 转码, 原文地址 cloud.tencent.com 腾讯云备案控制台开发者社区学习实践活动专区工具TVP
文章/答案/技术大牛搜索搜索关闭写文章提问登录/注册
全栈程序员站长
android 读取本地数据库db文件(Android sqlite)
转到我的清单专栏首页全栈程序员必看android 读取本地数据库db文件(Android sqlite)[](javascript:?[1](javascript:?[0](javascript:?[](javascript:;)分享
-
[](javascript:?
分享文章到朋友圈
-
[](javascript:;)分享文章到 QQ
-
[](javascript:;)分享文章到微博
-
[](javascript:;)复制文章链接到剪贴板
海报分享
海报分享
android 读取本地数据库db文件(Android sqlite)
发布于2022-09-03 17:58:38阅读 1.1K0
大家好,又见面了,我是你们的朋友全栈君。
我们知道Android中有四种数据存储方式:
今天我们主要说 本地数据库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:?
[举报](javascript:;)点赞 1分享
[登录](javascript:? 后参与评论_0_ 条评论
相关文章
-
Android数据读取之Sqlite数据库操作
咱们书接上文,继续来说说Android数据读取,这回,我们要讲的是Sqlite数据库的相关操作。以一个实例开始吧:
-
android读取sqlite数据库的数据并用listview显示
刚刚接触android,老师给了我了几个班级信息的excel,让我做一个考勤的系统出来,本篇仅记录了真机调试下,读取已有静态数据库并显示在listview中。
-
Android SQLite数据库
SQLiteOpenHelper 抽象类有两个抽象方法:onCreate() onUpgrade() 创建和升级数据库
-
基于 Android 读取微信本地 DB 数据 | 思维原理及技术分析
该移动端软件基于Android开发,是一个解析微信数据信息(包括微信个人资料、联系人、聊天记录等)并重装报文同步至服务端的一款应用。其实实属公司业务需要而开发的...
-
实现Android本地Sqlite数据库网络传输到PC端
在开发初期,当Android端嵌入在硬件中,并且本地数据库单机业务逻辑挺多,往往要分析数据是否处理正常,需要直接从数据库中查看,这时我们一般都是将数据库拷贝到P...
-
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...
-
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)
-
【Android 应用开发】Android 数据存储 之 SQLite数据库详解
转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19028665
作者介绍
全栈程序员站长
CTO关注专栏
精选专题
活动推荐
-
[
腾讯云 x ES 有奖征文
-
[
邀请好友加入自媒体分享计划
](https://cloud.tencent.com/developer/support-plan-invitation)
运营活动
关注
腾讯云_开发者_公众号将获得10元无门槛代金券洞察腾讯核心技术剖析业界实践案例
-
社区
-
活动
-
资源
-
关于
-
归档
腾讯云开发者
扫码关注腾讯云开发者
领取腾讯云代金券
热门产品
热门推荐
更多推荐
Copyright © 2013 - 2023 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 |京公网安备号11010802020287
扫描二维码
扫码关注腾讯云开发者
领取腾讯云代金券