你的位置:首页 > 软件开发 > 操作系统 > Android笔记——Android中数据的存储方式(三)

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

发布时间:2016-01-17 01:00:05
Android系统集成了一个轻量级的数据库:SQLite,所以Android对数据库的支持很好,每个应用都可以方便的使用它。SQLite作为一个嵌入式的数据库引擎,专门适用于资源有限的设备上适量数据存取,现在的主流移动设备像Android、iPhone等都使用SQLite作为复杂 ...

  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("数据库被创建了");

原标题:Android笔记——Android中数据的存储方式(三)

关键词:Android

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录