开发者社区> walb呀> 正文

[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数据库,如需转载请自行联系原博主。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【 uniapp 】打包Android的apk(原生APP-云打包),及发布测试
【 uniapp 】打包Android的apk(原生APP-云打包),及发布测试
215 0
Android Studio获取开发版SHA1值和发布版SHA1值的史上最详细方法
今天我想把百度地图的定位集成到项目中来,想写个小小的案例,实现一下,但在集成百度地图时首先要申请秘钥,申请秘钥要用到SHA1值,所以今天就来总结一下怎样去获取这个值吧,希望对大家有帮助。
351 0
Android 发布开源库到 JitPack (详细步骤)
Android 发布开源库到 JitPack (详细步骤)
205 0
Android Bintray、JCenter 替代方案MavenCentral(发布jar,aar到Maven中央仓库)
Android Bintray、JCenter 替代方案MavenCentral(发布jar,aar到Maven中央仓库)
276 0
Android如何通过Gradle发布Android依赖库(aar)到 jitpack 公共仓库
Android如何通过Gradle发布Android依赖库(aar)到 jitpack 公共仓库
193 0
Android如何通过Gradle发布java依赖库(jar)到 jitpack 公共仓库(—)
Android如何通过Gradle发布java依赖库(jar)到 jitpack 公共仓库(—)
116 0
如何把自己的Android Library发布到GitHubd依赖使用
如何把自己的Android Library发布到GitHubd依赖使用
49 0
使用Jenkins发布Android项目
使用Jenkins发布Android项目
285 0
微软正式发布 Windows 11,支持 Android 应用,面向开发者友好
微软正式发布 Windows 11,支持 Android 应用,面向开发者友好
69 0
Android 12 将允许运行 5 个 Chrome 实例;Furion v3.0.0.rc 发布 | 思否周刊
Android 12 将允许运行 5 个 Chrome 实例;Furion v3.0.0.rc 发布 | 思否周刊
68 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Android组件化实现
立即下载
蚂蚁聚宝Android秒级编译—— Freeline
立即下载
Android开发之多进程架构
立即下载