`
dss16694
  • 浏览: 144620 次
社区版块
存档分类
最新评论

发布Sqlite数据库

 
阅读更多

前言

  如何将Sqlite数据库与apk一同发布?刚开始用时有朋友告诉我直接用adb命令手工发布,或者写sql语句动态创建,感觉不太理想。得益于银河使者实现基于Android的英文电子词典这篇文章,再经过文章2的补充以及实践得以完成,感谢大家的分享!

 

文章

  1.  实现基于Android的英文电子词典

  2.  Using your own SQLite database in Android applications

  3.  Android Asset,res/raw限制文件大小UNCOMPRESS为1MB

 

声明

  欢迎转载,但请保留文章原始出处:)

    博客园:http://www.cnblogs.com

农民伯伯: http://www.cnblogs.com/over140/   

 

正文

  一、准备

    1.1  准备目录

      在Android项目工程res下新建raw文件夹,在这个文件夹里面的文件不会被编译压缩。

    1.2  准备数据库

      新建或拷贝一个数据库,然后打开,依次执行以下两条SQL语句:

CREATE TABLE "android_metadata" ("locale" TEXT DEFAULT 'zh_CN')
INSERT INTO "android_metadata" VALUES ('zh_CN')

      这个表用途不太清楚,但是如果用Android sqlite API创建一个数据库的话,会默认带上这个表,而且少了还不行,会报错。

 

  二、实现代码

    /**
     * 是否完成初始化
     
*/
    
private static boolean isInit = false;

    
    
/**
     * 初始化数据库
     * 
@param context
     
*/
    
synchronized public static void init(Context context)
    {
        
if(isInit)
            
return;
        
// 输出路径
        String outFileName = DATABASE_PATH + DATABASE_NAME;

        
//检测是否已经创建
        File dir = new File(outFileName);
        
if(dir.exists())
            
return;

        
// 检测/创建数据库的文件夹
        dir = new File(DATABASE_PATH);

        
if (!dir.exists())
            dir.mkdir();

        InputStream input 
= null;
        OutputStream output 
= null;
        
// 从资源中读取数据库流
        input = context.getResources().openRawResource(R.raw.db);

        
try {
            output 
= new FileOutputStream(outFileName);

            
// 拷贝到输出流
            byte[] buffer = new byte[2048];
            
int length;
            
while ((length = input.read(buffer)) > 0) {
                output.write(buffer, 
0, length);
            }
        } 
catch (FileNotFoundException e) {
            e.printStackTrace();
        } 
catch (IOException e) {
            e.printStackTrace();
        } 
finally {
            
// 关闭输出流
            try {
                output.flush();
                output.close();
            } 
catch (IOException e) {
            }
            
// 关闭输入流
            try {
                input.close();
            } 
catch (IOException e) {
            }
        }
        isInit 
= true;
    }

    代码说明:

      a).  在主窗口(Activity)中调用一次即可,随后直接用SQLiteDatabase.openDatabase操作使用即可。

 

结束 

   注意文章3,但没有测试过,不知道后续的版本会不会改进这个数据库发布的问题。

 

分享到:
评论

相关推荐

    SQLite数据库与apk文件一起发布,raw目录下

    将SQLite数据库(XXX.db文件)与apk文件一起发布,在raw目录下。完整代码。

    SQLite数据库复制工具rqlite.zip

    rqlite 是一个用 Go 语言开发的分布式系统,提供 SQLite 数据库的复制功能。rqlite 使用 Raft来确保所有 SQLite ... rqlite 提供了数据库的容错以及复制,而且安装、发布和运维都非常简单。 标签:rqlite

    sqlite数据库查看软件

    SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源... 至今已经有10个年头,SQLite也迎来了一个版本 SQLite 3已经发布。

    sqlite3数据库操作示例

    SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个... 至2015年已经有15个年头,SQLite也迎来了一个版本 SQLite 3已经发布。 这个sqlite3数据库操作示例,里面有详细教程和sqlite打开工具。

    DB.Browser.for.SQLite-arm64-3.12.2 for macOS 苹果 M1/M2 专用版本

    该工具主要用于浏览和编辑 SQLite 数据库,它兼容标准的 SQLite 2.x 和 3.x 数据库。SQLite Browser 的功能强大,用户界面友好,使得数据库的管理变得简单易行。此外,SQLite Browser 项目在 GitHub 上开源,欢迎...

    csvs-to-sqlite:将CSV文件转换为SQLite数据库

    使用浏览和发布该 SQLite 数据库。 基本用法: csvs-to-sqlite myfile.csv mydatabase.db 这将创建一个名为mydatabase.db的新 SQLite 数据库,其中包含一个包含 CSV 内容的表myfile 。 您可以提供多个 CSV 文件...

    Android中SQLite数据库知识点总结

    它的设计目标是嵌入式的,而且占用资源非常低,在内存中只需要占用几百kB的存储空间,这也是Android移动设备采用SQLite数据库的重要原因之一。 SQLite 是遵守ACID的关系型数据库管理系统。这里的ACID是指数据库事务...

    SQLite数据库

    SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。... 至2015年已经有15个年头,SQLite也迎来了一个版本 SQLite 3已经发布。

    SQLite 一款轻型的数据库

    SQLite也迎来了一个版本 SQLite 3已经发布.  SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式...

    Android案例:商品展示系统。利用SQLite+ListView,实现商品增删查改

    使用Eclipse+SDK+ADT开发工具,利用SQLite数据库 + ListView开发技术,实现了一个简易的商品展示系统,其功能模块包括商品信息的增加、删除、修改、查询等。

    sqlite3.h数据库头文件

    这个头文件定义SQLite库呈现给客户端程序的接口。如果c函数、结构、数据类型或常量定义没有出现在这个文件中,那么它不是SQLite发布的API,可以在不通知的情况下进行更改,并且不应该被使用SQLite的程序引用。

    linux下sqlite服务器

    在LINUX下运行此服务器程序,即可从WINDOWS操作系统对LINUX下的SQLITE数据库进行远程操作,管理工具可使用我前面发布的sqlite远程管理工具,使用起来极其方便,解决了LINUX下对SQLITE数据进行管理的烦恼,我对这个...

    DB.Browser.for.SQLite-3.12.2 for macOS

    该工具主要用于浏览和编辑 SQLite 数据库,它兼容标准的 SQLite 2.x 和 3.x 数据库。SQLite Browser 的功能强大,用户界面友好,使得数据库的管理变得简单易行。此外,SQLite Browser 项目在 GitHub 上开源,欢迎...

    DB Browser for SQLite 版本 3.12 - PortableApp

    生成的程序被重命名为 SQLite 数据库浏览器,并由 Mauricio 发布到公共领域。图标由同样来自 Tabuleiro的Raquel Ravanini贡献。Jens Miltner ( @jmiltner ) 贡献了代码来支持 1.2 版本的 SQLite 3.x 数据库。

    importlite:将CSV文件导入SQLite数据库

    ImportLite:将CSV文件导入SQLite数据库 ImportLite是用于将CSV文件导入SQLite的命令行实用程序。 它既可以从头开始创建表,也可以将数据加载到现有表中。 它还提供高级功能,包括值预处理和数据规范化。 ##目录 ...

    DB.Browser.for.SQLite-3.12.2-win64 .zip

    该工具主要用于浏览和编辑 SQLite 数据库,它兼容标准的 SQLite 2.x 和 3.x 数据库。SQLite Browser 的功能强大,用户界面友好,使得数据库的管理变得简单易行。此外,SQLite Browser 项目在 GitHub 上开源,欢迎...

    全国省份城市数据库文件(精确到区县),Sqlite3版本,s3db格式

    根据SQLServer版本导出的Sqlite版本,因为自己项目需要,所以做了这个版本的数据库,发上来共享。...打开方式:使用Sqlite数据库的管理工具打开即可。管理工具及破解见我发布的SqliteDev及相关资源

    SQLiteCodeFirst:使用实体框架CodeFirst基于EdmModel创建SQLite数据库

    SQLite CodeFirst ... 它们根据您的模型/代码创建新SQLite数据库。 支持以下功能: 类中的表(支持的注释: Table ) 属性中的列(支持的注释: Column , Key , MaxLength , Required , NotMapped

    SQLiteForExcel:轻量级包装,可从VBA访问SQLite3库

    是一个小型,易于使用的开源SQL数据库引擎。 SQLite for Excel这个项目是一个轻量级包装,可以从VBA访问SQLite3库。 它提供了SQLite3 API函数的高性能路径,保留了SQLite3库调用的语义,并允许在不重新编译的情况下...

    JSP-JTBC-CMS(SQLITE).rar

    JSP_JTBC_CMS(SQLITE).rar是一个计算机专业的JSP源码资料包,它包含了一个基于JSP技术和SQLite数据库的内容管理系统(CMS)。这个系统采用了Java Server Pages(JSP)作为后端开发语言,结合了Java Servlet和...

Global site tag (gtag.js) - Google Analytics