Android笔记——Android中数据的存储方式(三)

  Android系统集成了一个轻量级的数据库:SQLite,所以Android对数据库的支持很好,每个应用都可以方便的使用它。SQLite作为一个嵌入式的数据库引擎,专门适用于资源有限的设备上适量数据存取,现在的主流移动设备像Android、iPhone等都使用SQLite作为复杂数据的存储引擎,并且它是以手机内存为储存的。

  那么,实际开发项目中有大量数据需要读写,并且需要面临大量用户的并发储存的情况呢。就不应该把数据存放在手机等移动设备的SQLite数据库里,移动设备的储存能力和计算能力都不足以让它充当服务器的角色。虽然SQLite支持大部分SQL-92语法,也可以使用SQL语句,和其他的主要 SQL 数据库没什么区别。但SQLite并不像Oracle、MySQL数据库那样需要安装、启动服务器进程,SQLite数据库只是一个文件。

  综上所述,我们可以总结出SQLite数据库的特点:

    面向资源有限的设备;

    没有服务器进程;

    所有数据存放在同一文件中,可自由复制;

    跨平台;

    操作方便,使用标准的CRUDE语句,ContentResolver.query(), update(), delete() insert()。

  还有其他的特点:效率出众,这是无可否认的; 十分适合存储结构化数据 ;方便在不同的Activity,甚至不同的应用之间传递数据。

在我们为移动设备开发应用程序时,也许就要使用到SQLite来存储我们大量的数据,所以我们就需要掌握移动设备上的SQLite开发技巧

可以充当服务器

且只利用很少的内存就有很好的性能

1.3  例子

  4.  SQLite数据库

    3.1 案例:创建SQLite数据库

    

  • 创建数据库需要使用的api:SQLiteOpenHelper

    • 必须定义一个构造方法:

      //arg2:数据库文件的名字
      //arg3:游标工厂
      //arg4:数据库版本
      public MyOpenHelper(Context context, String name, CursorFactory factory, int version){}
      
    • 数据库被创建时会调用:onCreate方法
    • 数据库升级时会调用:onUpgrade方法
  • 创建数据库步骤:
    //创建OpenHelper对象
    MyOpenHelper oh = new MyOpenHelper(getContext(), "person.db", null, 1);
    //获得数据库对象,如果数据库不存在,先创建数据库,后获得,如果存在,则直接获得
    SQLiteDatabase db = oh.getWritableDatabase();
  • getWritableDatabase():打开可读写的数据库
  • getReadableDatabase():在磁盘空间不足时打开只读数据库,否则打开可读写数据库
  • 在创建数据库时创建表
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        db.execSQL("create table person (_id integer primary key autoincrement, name char(10), phone char(20), money integer(20))");
    }
    
  • 代码:
    • 创建MyOpenHelper类继承 SQLiteOpenHelper
package com.bokeyuan.createsqlite;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class MyOpenHelper extends SQLiteOpenHelper {

    public MyOpenHelper(Context context, String name, CursorFactory factory,
            int version) {
        //name:数据库文件的名字
        //factory:游标工厂
        //version:数据库的版本号
        super(context, name, factory, version);
        // TODO Auto-generated constructor stub
    }

    //数据库创建时,此方法调用
    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        System.out.println("数据库被创建了");     //创建表        db.execSQL("create table person(_id integer primary key autoincrement, name char(10), phone char(20), money integer(10))");
    }

    //数据库升级时,此方法调用
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub
        System.out.println("数据库升级了");
    }

}
    • 这里不再用前台视图布局,直接用单元测试框架。

      在com.bokeyuan.createsqlite.domian包中创建Test.java 并继承 AndroidTestCase类。

      

package com.bokeyuan.createsqlite.domian;

import com.bokeyuan.createsqlite.MyOpenHelper;

import android.database.sqlite.SQLiteDatabase;
import android.test.AndroidTestCase;

public class Test extends AndroidTestCase {

    public void Test() {
        // 创建数据库
        //1.创建OpenHelper对象
                                            //获取一个虚拟上下文
        MyOpenHelper oh = new MyOpenHelper(getContext(), "people.db", null, 2);
        //2.创建数据库
        //如果数据库不存在,那么先创建,再打开,如果数据库已经存在,侧直接打开
        SQLiteDatabase db = oh.getWritableDatabase();
        //如果磁盘不足,数据库只读
//        SQLiteDatabase db = oh.getReadableDatabase();
    }
}
    • 在清单文件AndroidManifest.xml设置指令集和库:

      <instrumentation
              android:name="android.test.InstrumentationTestRunner"
              android:targetPackage="com.bokeyuan.createsqlite"></instrumentation>

      <uses-library android:name="android.test.runner"/>

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.bokeyuan.createsqlite"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="19"
        android:targetSdkVersion="19" />

    <instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:targetPackage="com.bokeyuan.createsqlite"></instrumentation>
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <uses-library android:name="android.test.runner" />
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

      数据库存储在 data/< 项目文件夹 >/databases/ 下。我们可以用SQLite Professional打开。

      

      数据库创建时,此方法调用  说明onCreate()方法被调用了,数据库被创建了

      

      
         把version改成2,Run As →Android JUint Test后, 调用onUpgrade()方法,数据库升级了

        //1.创建OpenHelper对象
                                            //获取一个虚拟上下文
          MyOpenHelper oh = new MyOpenHelper(getContext(), "people.db", null, 2);

           

参考资料

Android应用开发基础之数据存储和界面展现(三)

Android实现数据存储技术

Android中SQLite应用详解

Android数据存储五种方式总结

Android开发笔记之: 数据存储方式详解

时间: 2024-10-12 13:12:02

Android笔记——Android中数据的存储方式(三)的相关文章

Android笔记——Android中数据的存储方式(二)

我们在实际开发中,有的时候需要储存或者备份比较复杂的数据.这些数据的特点是,内容多.结构大,比如短信备份等.我们知道SharedPreferences和Files(文本文件)储存这种数据会非常的没有效率.如果学过JavaWeb的朋友,首先可能想到的是数据库.当然了数据库是一个方案,那么是否还有其他的解决方案呢?今天我们在讲下Android笔记——Android中数据的存储方式(一) 提到的除了SharedPreferences和Files(文本文件)以外的其他几种数据储存方式:xml文件.SQL

opengl中的Floatbuffer和IntBuffer与java中数据的存储方式不同的解决方法

android OpenGL ES的书中使用了下面代码: 1)创建三个顶点 private IntBuffer triggerBuffer = IntBuffer.wrap(new int[]{ 0,one,0,      -one,-one,0, one,-one,0, }); 2)然后使用triggerBuffer 画顶点 例如:gl.glVertexPointer(3, GL10.GL_FIXED, 0,triggerBuffer ); 经常会出现:Must use a native or

iOS开发中数据的存储方式

1.plist属性列表 >1.适用对象:仅仅是Foundation框架中自带的一些类,比如:NSString/NSArray/NSDicionary/NSSet/NSNumber/NSData >2.调用对象的writeToFileXXX方法就可以写入文件 >3.调用对象的XXXWithcontensOfFile方法就可以从文件中读取对象内容 2.偏好设置 >1.本质还是plist属性列表的方法进行存储 >2.存取非常简单  (不用关心文件夹和文件名) >3.只能存储一

iOS中数据持久存储方式及区别

1 NSUserdefaults 主要用来存储一些短小的信息,例如应用程序设置和属性及用户数据. 2 属性列表 以列表的形式把数据存储到磁盘上.属性列表类包括NSArray, NSDictionary, NSString, NSNumber, NSDate, NSdata. 这些类型的数据可用直接调用writeToFile和相应的加载函数来存储到磁盘和从磁盘读出. 相应的加载函数有: arrayWithContentsOfFile: dictionaryWithContentsOfFile: s

Android的4中数据存储方式

Android的4中数据存储方式:1.SharedPreference2.SQLite3.ContentProvider4.File 1.SharedPreference 1)轻量级数据存储方式A 2)本质是基于XML文件存储key-value键值对数据 3)用于保存应用程序的 参数/属性的配置信息 SharedPreference对象本身只能获取数据而不支持存储和修改,修改是通过Editor来实现 实现SharedPreference存储的步骤: (1)获得SharedPreference对象

Android的数据的存储方式

数据的存储方式,总的来说分为三种: ① 文件存储: * SharedPreferences存储 * SD卡存储 ---- Environment * 数据库存储 ---- SQLite .MySQL.sqlserver.Oracle * File  存储 * ContentPrivider存储 ② 内存存储 * 集合 * 变量 ③ 网络存储 * 数据在服务器

转载:android笔记--android中的多线程--Handler, Looper, MessageQueue, Message类

什么时候使用多线程: 1. 耗时操作使用多线程, 耗时操作放在UI线程中会导致用户的操作无法得到响应. 2. 阻塞操作使用多线程, 理由同上. 3. 多核CUP的设备使用多线程, 可以有效提高CPU的利用率. 4. 并行操作使用多线程. android中的多线程模型主要涉及的类有:Looper, Handler, MessageQueue, Message等. 一:Looper类: 1 static final ThreadLocal<Looper> sThreadLocal = new Th

Tair存储引擎之一Leveldb中数据的存储思想

1. Tair ldb简单介绍 1.1 tair非持久化/持久化存储引擎 tair 是淘宝自己开发的一个分布式 key/value 存储引擎. tair 分为持久化和非持久化两种使用方式. 非持久化的 tair 可以看成是一个分布式缓存. 持久化的 tair 将数据存放于磁盘中. 在最新版本的tair trunk中目前实现了以下4种存储引擎. 非持久化:mdb 持久化:fdb.kdb和 ldb 分别基于四种开源的key/value数据库:Memcached.Firebird.Kyoto Cabi

从计算机中数据类型的存储方式,思考理解原码,反码,补码

从计算机中数据类型的存储方式,思考理解原码,反码,补码 1. 数据类型 首先,我们知道,在C中,设计了两个类型的数据: 有符号数据类型 无符号数据类型 ==== signed & unsigned 打印方式: signed: %d, unsigned: %u 数据范围: signed: [-128, 127] unsigned: [0, 255] 2. 无符号数据类型 - 原码,反码,补码 在学习计算机的过程中,很快出现了:原码,反码,补码的概念.这里你肯定不会理解为什么要设计这个玩意儿的! 因