2024年Android最全android 读取本地数据库db文件(Android sqlite),2024年最新字节跳动 面试难度

分享读者

作者2013年java转到Android开发,在小厂待过,也去过华为,OPPO等大厂待过,18年四月份进了阿里一直到现在。

被人面试过,也面试过很多人。深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长,而且极易碰到天花板技术停滞不前!

我们整理了一份阿里P7级别的Android架构师全套学习资料,特别适合有3-5年以上经验的小伙伴深入学习提升。

主要包括腾讯,以及字节跳动,阿里,华为,小米,等一线互联网公司主流架构技术。

腾讯T3架构师学习专题资料

如果你觉得自己学习效率低,缺乏正确的指导,可以一起学习交流!

我们致力打造一个平等,高质量的Android交流圈子,不一定能短期就让每个人的技术突飞猛进,但从长远来说,眼光,格局,长远发展的方向才是最重要的。

35岁中年危机大多是因为被短期的利益牵着走,过早压榨掉了价值,如果能一开始就树立一个正确的长远的职业规划。35岁后的你只会比周围的人更值钱。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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 {

最后

最后这里放上我这段时间复习的资料,这个资料也是偶然一位朋友分享给我的,里面包含了腾讯、字节跳动、阿里、百度2019-2021面试真题解析,并且把每个技术点整理成了视频和PDF(知识脉络 + 诸多细节)。

还有 高级架构技术进阶脑图、高级进阶架构资料 帮助大家学习提升进阶,也可以分享给身边好友一起学习。

一起互勉~

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

(img-tV5b0EPq-1714826925265)]

[外链图片转存中…(img-ilJmZP19-1714826925265)]

一起互勉~

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值