[Android]发布Sqlite数据库

简介:

一、准备

    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操作使用即可。

本文转自博客园农民伯伯的博客,原文链接:[Android]发布Sqlite数据库,如需转载请自行联系原博主。

目录
相关文章
|
22天前
|
API 数据库 C语言
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
163 0
|
1月前
|
网络协议 关系型数据库 MySQL
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
|
2月前
|
存储 监控 安全
内网屏幕监控软件的数据存储与管理:使用SQLite数据库保存监控记录和配置信息
在当今数字化时代,安全和监控在企业和组织中变得至关重要。内网屏幕监控软件作为一种关键工具,帮助组织监视员工的活动并确保信息安全。这种软件不仅需要高效地记录和管理监控数据,还需要能够方便地进行配置和调整。本文将讨论如何使用SQLite数据库来保存监控记录和配置信息,并介绍如何通过自动化机制将监控到的数据提交到指定网站。
148 2
|
4天前
|
SQL 关系型数据库 数据库
Python中SQLite数据库操作详解:利用sqlite3模块
【4月更文挑战第13天】在Python编程中,SQLite数据库是一个轻量级的关系型数据库管理系统,它包含在一个单一的文件内,不需要一个单独的服务器进程或操作系统级别的配置。由于其简单易用和高效性,SQLite经常作为应用程序的本地数据库解决方案。Python的内置sqlite3模块提供了与SQLite数据库交互的接口,使得在Python中操作SQLite数据库变得非常容易。
|
1月前
|
关系型数据库 数据库 C++
嵌入式数据库sqlite3【基础篇】基本命令操作,小白一看就懂(C/C++)
嵌入式数据库sqlite3【基础篇】基本命令操作,小白一看就懂(C/C++)
|
1月前
|
存储 SQL 数据库
django如何连接sqlite数据库?
django如何连接sqlite数据库?
38 0
|
1月前
|
存储 SQL 数据库
【Android 从入门到出门】第六章:使用Room数据库并测试
【Android 从入门到出门】第六章:使用Room数据库并测试
29 4
|
1月前
|
网络协议 关系型数据库 MySQL
安卓手机termux上安装MariaDB数据库并实现公网环境下的远程连接
安卓手机termux上安装MariaDB数据库并实现公网环境下的远程连接
|
2月前
|
数据库 Android开发 数据库管理
【Android】使用android studio查看内置数据库信息
【Android】使用android studio查看内置数据库信息
60 0
|
2月前
|
SQL 数据库管理
sqlite语句order by两个字段同时排序处理
sqlite语句order by两个字段同时排序处理
19 0