sqlite怎么创建和打数据库在指定的路径

sqlite怎么创建和打数据库在指定的路径,第1张

要在Android系统中 *** 作SQLite数据库,是通过Android的核心类SQLiteDatabase类来实现的,通常情况下为了数据库升级的需要以及使用方便,会选择继承SQLiteOpenHelper抽像类,但是SQLiteOpenHelper会将数据库文件创建在一个固定的目录(内存的/data/data/<package name/databases>目录中),如果想使用已经存在的数据库文件也就是说数据库会和程序一起发布,就得通过使用SQLiteDabase的静态方法OpenOrCreateDatabase()方法来得到SQLiteDabase对象,下面是一个具体 *** 作类:

package net.my.dao

import java.io.File

import java.io.FileOutputStream

import java.io.InputStream

import net.my.jokebook.R

import android.app.Activity

import android.content.Context

import android.database.sqlite.SQLiteDatabase

public class DBHelper {

//得到SD卡路径

private final String DATABASE_PATH = android.os.Environment

.getExternalStorageDirectory().getAbsolutePath()

+ "/joke"

private final Activity activity

//数据库名

private final String DATABASE_FILENAME

public DBHelper(Context context) {

// TODO Auto-generated constructor stub

//这里直接给数据库名

DATABASE_FILENAME = "jokebook.db3"

activity = (Activity)context

}

//得到 *** 作数据库的对象

public SQLiteDatabase openDatabase()

{

try

{

boolean b = false

//得到数据库的完整路径名

String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME

//将数据库文件从资源文件放到合适地方(资源文件也就是数据库文件放在项目的res下的raw目录中)

//将数据库文件复制到SD卡中 File dir = new File(DATABASE_PATH)

if (!dir.exists())

b = dir.mkdir()

//判断是否存在该文件

if (!(new File(databaseFilename)).exists())

{

//不存在得到数据库输入流对象

InputStream is = activity.getResources().openRawResource(

R.raw.jokebook)

//创建输出流

FileOutputStream fos = new FileOutputStream(databaseFilename)

//将数据输出

byte[] buffer = new byte[8192]

int count = 0

while ((count = is.read(buffer)) >0)

{

fos.write(buffer, 0, count)

}

//关闭资源

fos.close()

is.close()

}

//得到SQLDatabase对象

SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(

databaseFilename, null)

return database

}

catch (Exception e)

{

System.out.println(e.getMessage())

}

return null

}

}

写完这个类之后,就能得到SQLiteDatabase对象,就能对数据库 *** 作了。

 1、首先,查看MySQL的服务是否存在。如果不存在需要先安装服务。安装服务的方法是进入MySQL Server的安装目录,找到bin目录,然后找到文件mysqld.exe,使用命令行运行 mysqld --install MySQL57 安装服务(如果不成功尝试使用管理员方式运行,MySQL57是服务的名字,默认是MySQL)。

2、如果上述方法安装服务失败,则可采用下述方法安装(成功则跳过此步)。搜索程序“regedit.exe”,即注册表编辑器,打开后找到 “计算机”——"HKEY_LOCAL_MACHINE"——“SYSTEM”——“CurrentControlSet”——“Services”,然后在该目录下新建项MySQL57(服务的名字)即可成功建立项目。

3、找到新建的项,然后可以看到其中有ImagePath这一项,这其实是可执行文件的路径。因为MySQL服务是需要靠mysqld这个命令来启动的,所以检查下ImagePath的路径是否正确。路径错误导致启动服务时报错—“无法找到文件”。

4、修改ImagePath的内容为正确的路径值,正确的值是"D:\MySQL\MySQL Server 5.7\bin\mysqld" --defaults-file="D:\MySQL\MySQL Server 5.7\my.ini" MySQL 是这种形式的,对照一下,如果路径不对,修改过来。

5、重启计算机,再次启动服务,并可以成功运行MySQL服务。

要找的sqlite数据库 文件,默认情况下存储在这个位置

C:\Documents and Settings\Administrator\.android\avd\

虚拟机名字.avd/userdata.img这个镜像文件中。

如果想不打开虚拟机就找到你的数据库文件,已经试过ultraiso无法识别这种镜像格式。而且这样做是没有什么意义的。

当虚拟机载入这个镜像中的信息并成功启动后,可以理解为你的SQLite数据库文件被读入到了内存中。

但是所做的任何修改都会被保存在上述的镜像文件中,所以实质上数据库文件还是存放在硬盘中的。

虚拟机就是利用了当前计算机的硬件资源,模拟出来一个目的主机,一般情况下你是不能,也不应该通过除了虚拟机本身的方式来读取或修改存储在它内部的数据的。

所以,从计算机的物理磁盘上不通过虚拟机,想直接找到虚拟机中的手机内存上的SQLite数据库文件,是不现实的。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6707054.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-27
下一篇 2023-03-27

发表评论

登录后才能评论

评论列表(0条)

保存