android studio sqlitedatabase,在SQLite数据库Android Studio上使用预填充数据库

本问题已经有最佳答案,请猛点这里访问。

在这里,我想使用我预先填充的SQLite数据库到我的Android应用程序。 因此,首次运行时,它会自动从assets文件夹中复制数据库,并在我的Android应用程序中将其用作数据库。

到目前为止,我已经做了这些事:

public class DatabaseHelper extends SQLiteOpenHelper {

public static final String MyVillageSoftware ="MyVillageSoftware";

public static final String table_Question ="table_question";

private static final String DATABASE_PATH="/Users/ever_ncn/Documents/Project/PsikologiKarakter/app/src/main/assets/";

private static final String DATABASE_NAME="question.db";

//TOL for transaction Coloumn

SQLiteDatabase db;

Context context;

private static final String TAG = DatabaseHelper.class.getSimpleName();

public DatabaseHelper(Context context) {

super(context, DATABASE_NAME, null, 1);

this.context=context;

}

@Override

public void onCreate(SQLiteDatabase db) {

}

public void createDatabase(){

createDB();

}

public void createDB(){

boolean dbExist = DBExist();

if(!dbExist){

this.getReadableDatabase();

copyDBFromResource();

}

}

private boolean DBExist(){

SQLiteDatabase db = null;

try{

String databasePath = DATABASE_PATH+DATABASE_NAME;

db=SQLiteDatabase.openDatabase(databasePath, null,

SQLiteDatabase.OPEN_READWRITE);

db.setLocale(Locale.getDefault());

db.setLockingEnabled(true);

db.setVersion(1);

}catch(SQLiteException e){

Log.e("SqlHelper","Database nda ada babi");

}

if(db != null){

db.close();

}return db != null ? true : false;

}

private void copyDBFromResource(){

InputStream inStream=null;

OutputStream outStream = null;

String dbFilePath=DATABASE_PATH+DATABASE_NAME;

try{

inStream=context.getAssets().open(DATABASE_NAME);

outStream=new FileOutputStream(dbFilePath);

byte[] buffer = new byte[1024];

int length;

while((length=inStream.read(buffer))>0){

outStream.write(buffer, 0 , length);

}

outStream.flush();

outStream.close();

inStream.close();

}catch (IOException e){

throw new Error("Problem cuk");

}

}

public List getAllCategory() {

List AllCategoryList = new ArrayList();

List AllCategIdList = new ArrayList();

String selectQuery ="SELECT * FROM" + table_Question;

SQLiteDatabase db = this.getReadableDatabase();

Cursor cursor = db.rawQuery(selectQuery, null);

if (cursor.moveToFirst()) {

do {

String Id = cursor.getString(0);

String A = cursor.getString(1);

String B = cursor.getString(2);

String C = cursor.getString(3);

String D = cursor.getString(4);

String aExplain = cursor.getString(5);

String bExplain = cursor.getString(6);

String cExplain = cursor.getString(7);

String dExplain = cursor.getString(8);

} while (cursor.moveToNext());

}

cursor.close();

db.close();

return AllCategoryList;

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

db.execSQL("DROP TABLE IF EXISTS" + table_Question);

onCreate(db);

}

}

但我得到一个这样的错误信息:

10-28 07:18:38.988 2425-2425/gook.psikologikarakter E/SQLiteLog﹕ (14) cannot open file at line 30046 of [9491ba7d73]

10-28 07:18:38.988 2425-2425/gook.psikologikarakter E/SQLiteLog﹕ (14) os_unix.c:30046: (2) open(/Users/ever_ncn/Documents/Project/PsikologiKarakter/app/src/main/assets/question.db) -

10-28 07:18:38.989 2425-2425/gook.psikologikarakter E/SQLiteDatabase﹕ Failed to open database '/Users/ever_ncn/Documents/Project/PsikologiKarakter/app/src/main/assets/question.db'.

android.database.sqlite.SQLiteCantOpenDatabaseException: unknown error (code 14): Could not open database

at android.database.sqlite.SQLiteConnection.nativeOpen(Native Method)

at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:209)

at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:193)

at android.database.sqlite.SQLiteConnectionPool.openConnectionLocked(SQLiteConnectionPool.java:463)

at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:185)

at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:177)

at android.database.sqlite.SQLiteDatabase.openInner(SQLiteDatabase.java:806)

at android.database.sqlite.SQLiteDatabase.open(SQLiteDatabase.java:791)

at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:694)

at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:669)

at gook.psikologikarakter.DatabaseHelper.DBExist(DatabaseHelper.java:65)

at gook.psikologikarakter.DatabaseHelper.createDB(DatabaseHelper.java:52)

at gook.psikologikarakter.DatabaseHelper.createDatabase(DatabaseHelper.java:48)

at gook.psikologikarakter.MainActivity.onCreate(MainActivity.java:59)

at android.app.Activity.performCreate(Activity.java:5990)

at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2390)

at android.app.ActivityThread.access$800(ActivityThread.java:151)

at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303)

at android.os.Handler.dispatchMessage(Handler.java:102)

at android.os.Looper.loop(Looper.java:135)

at android.app.ActivityThread.main(ActivityThread.java:5257)

at java.lang.reflect.Method.invoke(Native Method)

at java.lang.reflect.Method.invoke(Method.java:372)

at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

我不知道到底发生了什么,但我想我无法打开数据库文件。 但我不知道该怎么办。 请高手帮帮我。

谢谢你。

您不能使用assets文件夹中的数据库。您希望在首次运行时将数据库复制到/ data / data / YOUR_PACKAGE / databases /。这将有所帮助:stackoverflow.com/questions/513084/…

是的先生,我的意思是,所以我的问题是如何在第一次启动应用程序时将数据库从assets文件夹复制到data / data / your_package / databases /?

我的朋友就像复制你使用java的任何其他文件一样简单。以下是专门针对您的案例:stackoverflow.com/a/20592481/1371041

但是我在这个先生上得到了错误:private String DATABASE_PATH = context.getApplicationInfo()。dataDir +"/ databases /";我收到错误"非法转发参考"

@ChallengeAccepted谢谢先生,它运作良好

很高兴解决了你的问题。至于"非法前向引用"你确定它是在构造函数中吗?你做了什么来解决你的错误?

我使用另一个模式代码来做那个先生。我使用此代码先生,private void copyDatabase(File dbFile)抛出IOException {InputStream is = context.getAssets()。open(DATABASE_NAME); OutputStream os = new FileOutputStream(dbFile); byte [] buffer = new byte [1024]; while(is.read(buffer)> 0){os.write(buffer); os.flush(); os.close(); is.close(); }

private static final String DATABASE_PATH="/Users/ever_ncn/Documents/Project/PsikologiKarakter/app/src/main/assets/";

这是本地文件系统上的路径,而不是运行时设备上文件的路径。 使用getResources().getAssets().openFile(...)获取文件的InputStream。

代码就像这先生一样?。context.getResources()getAssets()中openFile(DATABASE_NAME)。 但我在openFile()上遇到错误;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/507645.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用container的嵌套_ElementUI 技术揭秘(4)— Container 布局容器组件的设计与实现。...

前言上一篇文章我们分析了 Layout 布局组件的设计和实现,它的应用场景通常是局部布局。对于整个页面的布局,element-ui 提供了 Container 布局容器组件,专门用于 PC 管理后台页面的整体布局。需求分析我们先通过几幅图看一下页面的常见布局。…

推荐系统最新研究进展

算法相关的综述 从200多篇顶会论文看推荐系统前沿方向与最新进展 基于强化学习的推荐系统相关研究进展、经典论文整理分享 推荐系统去偏(Debiased Recommendation)研究进展概述 Deep Learning Based Recommender System: A Survey and New Perspectives…

html自动生成在线试题,HTML5测试题整理Ⅰ

1.在 HTML5 中,哪个元素用于组合标题元素?答案:2.HTML5 中不再支持哪个元素?答案:,,,,,,,,,,,3.在 HTML5 中,onblur 和 onfocus 是?答案:事件属性4.在 HTML5 中,新多媒体…

2021年第3周推荐系统方向的周报

1、如何快速进入研究状态 (1)研究方向对应的研究内容 综述性文献 (2)熟悉写文章的规范 表达能力、创新、编码、写作的规范(Latex、如何写标题、如何写摘要、如何画图。。。。),最好是接手师兄师…

python唯一映射类型_Python基础:04映射类型

字典是Python语言中唯一的映射类型。一个字典对象是可变的,它是一个容器类型,能存储任意个数的Python对象。字典中的数据是无序排列的。映射类型也可被称做哈希表,哈希表的算法是获取键,对键执行一个叫做哈希函数的操作&#xff0…

宝马屏幕共享android,宝马屏幕共享功能怎么用

【太平洋汽车网】使用宝马屏幕共享要先打开车载电脑多媒体功能,再选择屏幕共享手机投屏,勾掉宝马互联选项,然后再打开手机wifi,选择BMW输入密码即可使用屏幕共享。车手机互联映射即车机互联,就是将手机投屏到车载显示器…

“用于无监督图像生成解耦的正交雅可比正则化”论文解读

Tikhonov regularization terms https://blog.csdn.net/jiejinquanil/article/details/50411617 本文是对博客https://baijiahao.baidu.com/s?id1710942953471566583&wfrspider&forpc的重写。 1 简介 本文是对发表于计算机视觉和模式识别领域的顶级会议 ICCV 2021 的…

html带正方形项目列表,5种简单实用的css列表样式实例,可以直接用到项目中。...

谁不希望有一个好看而又干净的列表?这篇文章中我们给出几个实用的例子,你可以把他们直接用到自己的工作中。我们从一个带有动画效果的垂直列表开始,接着是一个图文混排的例子,然后是一个只有图片的list例子跟一个水平菜单的例子&a…

python变量和常量_python 变量与常量 - 刘江的python教程

变量与常量阅读: 17356评论:7变量:在程序运行过程中,值会发生变化的量常量:在程序运行过程中,值不会发生变化的量无论是变量还是常量,在创建时都会在内存中开辟一块空间,用于保存它的值。Python…

代价敏感多标签主动学习的代码开发跟踪

1 简介 代价敏感多标签主动学习目前是闵老师小组正在进行的一个开发项目,目的是将代价敏感和主动学习思想应用到多标签学习中。整个Java代码涵盖了很多技术:并行计算、batch处理。本文就是在学习这个代码后的一些总结。学习方法采用的至顶向下。 2 Cma…

pb 打印html页面,用PB开发WEB应用

用PB开发WEB应用用PB开发WEB应用烟台教育学院网络中心 孙连三一、PB Window plug -in 的用途PowerBuilder Window plug -in 的用途是在HTML 页面中插入PowerBuilder 中定义的窗口对象,此窗口对象上定义的功能在浏览器中一样被执行&#xff0…

python上传文件接口_python程序的web接口:上传和下载文件

我正在尝试制作一个简单的web应用程序,其中可以上载一个文件并将该文件提供给python脚本。烧瓶似乎适合这种用途。然后,用户可以从脚本下载文件输出。请告诉我如何解析python脚本中的文件并获得输出。到目前为止,我成功地完成了以下上载文件的…

两列布局 html5,CSS两列布局的N种实现

原理:两个元素都设置dislpay:inline-block,为了消除html空格的影响,父元素的font-size需要设置为0,右侧自适应元素的宽度使用calc函数计算。如果两个元素的高度不一样,可以给元素设置vertical-align:top调整。缺点&…

python如何提取图片特征向量_在python中计算图像的特征向量

我正在尝试将二维高斯拟合到图像中。噪声很低,所以我试图旋转图像,使两个主轴不同时变化,算出最大值,然后计算两个维度的标准偏差。选择的武器是Python。。然而,我一直在寻找图像的特征向量——numpy.linalg.py假设离散…

2021年9月24日和学生隆兴的学术讨论

QRCode: (1)做实验 (2)了解它的基本原理 调包侠 语言: (1)程序设计语言(交流,不规范) (2)数学(语言) &#x…

html加上百度统计,vue单页面应用加入百度统计

版权声明:本文为CSDN博主「钟文辉」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/qq_39753974/article/details/80322643在单页面中,要是只加在head中的话那…

推荐系统:猜你喜欢

0 简介 网络的迅速发展带来了信息超载(information overload)问题。解决信息超载问题一个非常有潜力的办法是推荐系统,它根据用户的信息需求、兴趣等,将用户感兴趣的信息、产品等推荐给用户。推荐系统最典型应用领域是电子商务领…

量子计算机九章能否预测未来,张礼立 : 中国 “九章”量子计算机到底厉害在哪?...

原标题:张礼立 : 中国 “九章”量子计算机到底厉害在哪?【背景信息】12月4日,《科学》杂志公布了 中国 “九章” 的重大突破。 这台由中国科学技术大学潘建伟、陆朝阳等学者研制的76个光子的量子计算原型机,推动全球量…

python的继承用法_python中继承有什么用法?python继承的用法详解

本篇文章给大家带来的内容是关于python中继承有什么用法?python继承的用法详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。面向对象三大特征1.封装:根据职责将属性和方法封装到一个抽象的类中2.继…

利用GAN实现QR Code超分辨率的研究

文章目录1 传统方案2 基于CNN的实现方案2.1 SRCNN2.2 WeChat AI3 基于GAN的实现方案3.1 SRGAN3.2 ESRGAN3.3 Real-ESRGAN4 基于GAN的QR Code的实现方案1 传统方案 https://blog.csdn.net/caomin1hao/article/details/81092134?utm_mediumdistribute.pc_relevant.none-task-bl…