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,甚至不同的施用中传递数据。

 

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”/>

sqlite 1sqlite 2

<?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>

View Code

      数据库存储于 data/< 项目文件夹 >/databases/
下。我们得据此SQLite Professional打开。

      sqlite 3

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

      sqlite 4

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

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

      sqlite 5     

 

 

 

 

 

 

 

 

 

参考资料

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

Android实现数据存储技术

Android中SQLite应用详解

Android数据存储五sqlite种办法总结

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

 

网站地图xml地图