Android下最好的数据储存方式:关系型数据库sqlite。

 

数据库的创建:使用SqliteOpenHelper类

结合SqliteOpenHelper类和SQLiteDatabase类的帮助,我们可以方便地对数据库进行CURD操作。

 

数据库的创建:

我们主要通过在SqliteOpenHelper类的onCreate方法中创建数据库表。

那么,onCreate方法又是在什么时候执行的呢?

我们先写一下代码:

package com.whathecode.db;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper; public class DatabaseHelper extends SQLiteOpenHelper
{ public static final String CREATE_TABLE = "create table student("
+ "id integer primary key," + "age integer," + "name char(20))"; public DatabaseHelper(Context context)
{
super(context, "dbsample.db", null, 1);
} @Override
public void onCreate(SQLiteDatabase db)
{
db.execSQL(CREATE_TABLE);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
{ } }

 

通过上面的代码,我们可以创建一个dbsample.db的数据库。

实际上,当我们通过new关键字创建这个类的实例的时候,数据库文件并没有被创建出来。

事实上是,数据库是我们第一次连接的时候创建的。

亦即是通过SqliteOpenHelper的getReadableDatabase()方法或者getWritableDatabase方法的时候创建

SqliteOpenHelper的onCreate方法也是在这个时候执行。

因此,我们可以在onCreate方法中创建需要的表。

 

下面是MainActivity的代码:

package com.whathecode.sqlitedemo;

import android.app.Activity;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle; import com.whathecode.db.DatabaseHelper; public class MainActivity extends Activity
{ @Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); //执行到这行的时候数据库没有被创建
DatabaseHelper dbh = new DatabaseHelper(this); //当执行到这行的时候数据被被创建出来
SQLiteDatabase readableDatabase = dbh.getReadableDatabase();
}
}

 

创建好数据库后,我们就可以对数据库进行CURD操作。

 

向数据库中插入数据:

使用SQLiteDatabase类中execSQL的方法,我们可以方便地操作数据库:

注意getReadableDatabase返回的数据库对象是只读的。

现在我们需要写入数据库,就需要调用getWritableDatabase方法

 

更新后的MainActivity代码:

package com.whathecode.sqlitedemo;

import android.app.Activity;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast; import com.whathecode.db.DatabaseHelper; public class MainActivity extends Activity
{
SQLiteDatabase readableDatabase = null;
DatabaseHelper dbh = null;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); //执行到这行的时候数据库没有被创建
dbh = new DatabaseHelper(this); //当执行到这行的时候数据被被创建出来
readableDatabase = dbh.getReadableDatabase();
} public void insertData(View view)
{
SQLiteDatabase writableDatabase = dbh.getWritableDatabase();
if (writableDatabase.isOpen())
{ for (int i = 0; i < 20; i++)
{
//执行数据插入操作
writableDatabase.execSQL("insert into student values(?,?,?);",
new Object[] { i + 2, 10 + i, "android " + i });
}
writableDatabase.close();
Toast.makeText(this, "数据插入成功", Toast.LENGTH_SHORT).show();
}
}
}

看一下运行结果:

 

现在,我们使用sqlite3工具看看数据是否真的被插入了

 

看到了吧,数据一条不少被插入了.

 

SqliteDatabase类除了execSQL方法外还有其他的方法可以操作数据库:

  • create(SQLiteDatabase.CursorFactory factory)
  • delete(String table, String whereClause, String[] whereArgs)
  • query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy)
  • rawQuery(String sql, String[] selectionArgs)

 

当使用execSQL执行任何的查詢语句都是没有返回结果的。

如果想返回结果,就要使用rawQuery方法。

 

当然,上面这些只是部分方法,其他的大家可以到官网查看API

其他的数据库查找,更新,删除操作都只是依瓢画葫芦。大家可以自行研究一下。

Android下的数据储存方式(三)的更多相关文章

  1. Android下的数据储存方式

      安卓系统默认提供了一下几种数据储存的方式: Shared Preferences 内部储存 外部储存 SQLite数据库 保存到网络服务器   使用Shared Preferences       ...

  2. Android下的数据储存方式( 二)

    在上一篇文章中我们介绍了SharedPreferences的使用方法. 今天我们继续介绍另一种储存数据的方式:使用内部储存和外部储存 每一个Android设备都拥有两个数据储存区域:外部储存和外部储存 ...

  3. 关系型数据库与HBase的数据储存方式差别

    现在Bigtable型(列族)数据库应用越来越广,功能也非常强大. 可是非常多人还是把它当做关系型数据库在使用,用原来关系型数据库的思维建表.存储.查询. 本文以hbase举例讲述数据模式的变化. 传 ...

  4. Android下的数据存储与訪问 --- 以文件的形式

    Android下的数据存储与訪问 --- 以文件的形式 1.1 储存文件存放在手机内存中: // *** 储存数据到 /data/data/包名/files/jxn.txt文件里 String dat ...

  5. Android MVP模式简单易懂的介绍方式 (三)

    Android MVP模式简单易懂的介绍方式 (一) Android MVP模式简单易懂的介绍方式 (二) Android MVP模式简单易懂的介绍方式 (三) 讲完M和P,接下来就要讲V了.View ...

  6. Android笔记:数据储存

    1.文件存储 文件存储是Android 中最基本的一种数据存储方式,它不对存储的内容进行任何的格式化处理,所有数据都是原封不动地保存到文件当中的,因而它比较适合用于存储一些简单的文本数据或二进制数据. ...

  7. Android中的数据储存

    数据的储存是一个十分重要的功能,它涉及到各种类型的数据,各种的储存方式,今天就接触了Android中数据储存的简单应用,有一种方式是可以将存入的数据原封不动的存储起来,这里要用到openfileout ...

  8. Android 里的数据储存

    数据持久化 关于数据储存,这个话题已经被反复讨论过很多次了,我是不建议把网络存储这种方式纳入到数据储存的范围的,因为这个和Android没多少关系,因此就有如下的分类: 本地储存(也称之为数据持久化, ...

  9. android下的数据存储

    android下数据存储的几种方式:(简单讨论) 1.文件 举例:登陆时“记住密码” 因为是基于Linux系统,直接建文件,文件会出现在项目工程:而手机登陆时,应该把文件放在手机里,通常数据放在dat ...

随机推荐

  1. uva 12745 Wishmaster(2-sat)

    12745 Wishmaster view code#include <iostream> #include <cstdio> #include <algorithm&g ...

  2. Linux软件安装-RPM安装

    RPM是RPM Package Manager(RPM软件包管理器)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux.         S ...

  3. Windows Azure Storage图形界面管理工具

    上一篇我们介绍了用PowerShell将Windows Azure的存储服务当网盘来使用.如果感觉还不够简单,那么这次我们来看看还有哪些使用起来更方便的图形界面管理工具吧.当然,这些工具必要支持中国版 ...

  4. [转]simple sample to create and use widget for nopcommerce

    本文转自:http://badpaybad.info/simple-sample-to-create-and-use-widget-for-nopcommerce Here is very simpl ...

  5. openfire+asmack搭建的安卓即时通讯(七) 15.5.27

    本地化之章! 往期传送门: 1.http://www.cnblogs.com/lfk-dsk/p/4398943.html 2.http://www.cnblogs.com/lfk-dsk/p/441 ...

  6. 记一次惨痛的线上bug

    讲述背景,刚入职新公司2个月的时候,接手一个红包系统.资历尚浅,对业务也不是很熟悉.公司开发新的平台,需要使用红包功能来进行推广,按照产品的需求,进行开发...然而,问题就出在这里,红包接口比较陈旧, ...

  7. 【HTML5】标记文字

    1.用基本的文字元素标记内容 先看显示效果: 对应HTML代码: <!DOCTYPE html> <html lang="en"> <head> ...

  8. Codeforces Round #285 (Div.1 B & Div.2 D) Misha and Permutations Summation --二分+树状数组

    题意:给出两个排列,求出每个排列在全排列的排行,相加,模上n!(全排列个数)得出一个数k,求出排行为k的排列. 解法:首先要得出定位方法,即知道某个排列是第几个排列.比如 (0, 1, 2), (0, ...

  9. NOIP2007矩阵取数[DP|高精度]

    题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...

  10. 虚拟机软件VMware Workstation Pro的安装与使用

    聚焦行业最佳实践,BDTC 2016完整议程公布      Java 编程入门(系列)      程序员11月书讯,评论得书啦      免费的知识库,你的知识库 虚拟机软件VMware Workst ...