sqliteAndroid笔记——Android中多少的蕴藏格局(三)

  Android系统融为壹体了3个轻量级的数据库:SQLite,所以Android对数据库的支持很好,各样应用都足以方便的施用它。SQLite作为2个嵌入式的数据库引擎,专门适用于财富有限的设备上非凡数据存取,未来的主流移动设备像Android、金立等都应用SQLite作为复杂数据的囤积引擎,并且它是以手提式有线电电话机内部存款和储蓄器为储存的。

  那么,实际付出项目中有恢宏数码须求读写,并且须求面临多量用户的现身储存的图景呢。就不应有把数量存放在手提式有线电话机等运动装备的SQLite数据库里,移动设备的存储能力和计量能力都不足以让它充当服务器的剧中人物。纵然SQLite援助当先二分之一SQL-玖2语法,也能够应用SQL语句,和别的的基本点
SQL
数据库没什么不一样。但SQLite并不像Oracle、MySQL数据库那样须求设置、运营服务器进程,SQLite数据库只是三个文书。

  综上所述,大家得以总计出SQLite数据库的特点:

    面向能源有限的装备;

    未有服务器进度;

    全体数据存放在平等文件中,可随便复制;

    跨平台;

    操作便利,使用规范的CRUDE语句,ContentResolver.query(),
update(), delete() insert()。

  还有任何的风味:效用一级,那是无可不可以认的;
十一分契合储存结构化数据
;方便在分化的Activity,甚至差异的利用之间传递数据。

 

1.3  例子

  4.  SQLite数据库:

    3.1 案例:创建SQLite数据库

    

  • 创办数据库须求利用的api:SQLiteOpenHelper

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

      //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对象
                                            //获取1个虚构上下文
          MyOpenHelper oh = new MyOpenHelper(getContext(),
“people.db”, null, 2);

      sqlite 5     

 

 

 

 

 

 

 

 

 

参考资料

Android应用开发基础之数据存款和储蓄和界面显示(三)

Android达成数据存款和储蓄技术

Android中SQLite应用详解

Android数据存款和储蓄多样艺术计算

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

 

网站地图xml地图