详解Android轻量型数据库SQLite

数据库是Android存储方案的核心,在Andorid中SQLite非常轻量,而且执行sql语句甚至比MySQL还要快。
SQLiteDatabase 是 Android 中操作数据库的核心类之一,使用SQLiteDatabase可以打开数据库,也可以对数据库进行操作,然而,为了数据库升级以及使用更加方便,我们常用SQLiteOpenHelper的子类来完成创建,打开数据库的操作。
SQLiteOpenHelper是一个抽象类,在该类中有下面两个必须实现的方法:

public void onCreate(SQLiteDatabase db);// 该函数在数据库第一次被建立时调用
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion);// 数据库更新升级操作

我们新建一个类DBHelper extends SQLiteOpenHelper

import java.util.Random;

import android.R.bool;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DBHelper extends SQLiteOpenHelper {

 // 设置数据库默认版本
 private static final int VERSON = 1;
 // 自定义数据库名,可以随便取名字
 private static final String DBNAME = "mydb";

 // 继承SQLiteOpenHelper类的类必须有自己的构造函数
 // 该构造函数4个参数,直接调用父类的构造函数。其中第一个参数为该类本身;第二个参数为数据库的名字;
 public DBHelper(Context context, String name, CursorFactory factory,
   int version) {
  super(context, name, factory, version);
 }

 // 该构造函数有3个参数,因为它把上面函数的第3个参数固定为null了
 public DBHelper(Context context, String name, int verson) {
  this(context, name, null, verson);
 }

 // 该构造函数只有2个参数,在上面函数 的基础上将版本号固定了
 public DBHelper(Context context, String name) {
  this(context, name, VERSON);
 }

 // 该构造函数只有1个参数,固定默认数据库,在这里我们实现增删改查为了方便,就用它了
 public DBHelper(Context context) {
  this(context, DBNAME, null, VERSON);
 }

 // 该函数在数据库第一次被建立时调用
 public void onCreate(SQLiteDatabase db) {
  System.out.println("create a sqlite database");
  //建表语句(注意:因为在绑定数据时,Cursor对象返回的记录集中必须包含一个"_id"字段,否则无法完成数据绑定
  String sql = "CREATE TABLE [test]("+
      "[_id] AUTOINC,"+
      "[name] varchar(20),"+
      "[age] varchar(20),"+
      "PRIMARY KEY ([_id]))";
  db.execSQL(sql);

  //向test表中插入10条数据
  for (int i = 1; i <= 10; i++) {
   String name = "Jepson";
   name+=i;
   String age = "age";
   age+=i;
   db.execSQL("insert into test(name,age) values(?,?)",new Object[]{name,age});
  }
 }

 // 数据库更新操作
 public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
  System.out.println("update a sqlite database");
 }

 //自定义query方法,用以执行查询语句,返回Cursor对象
 public Cursor query(String sql,String[] args){
  //调用 getReadableDatabase方法时,如果数据库文件不存在,会调用 onCreate方法
  SQLiteDatabase db = this.getReadableDatabase();
  Cursor cursor = db.rawQuery(sql, args);
  return cursor;
 }
}

这样,我们的DBHelper 类写好了,我们来实现一个查询操作。

第一步,activity_main.xml添加 listview 展示控件

activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:background="#FFFFFF"
 android:orientation="vertical"
 tools:context=".MainActivity" >

 <ListView
  android:id="@android:id/list"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:layout_weight="1"
  android:divider="#6b6f74"
  android:dividerHeight="1px" >
 </ListView>

</LinearLayout>

第二步,新建一个xml布局文件,用来作为列表项使用的布局资源

user_list_cell.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 android:background="#FFFFFF">
 <!-- 大字体TextView,用以展示 name姓名 -->
 <TextView
  android:id="@+id/tvName"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="Large"
  android:textColor="#000000"
  android:textSize="20dp" />

 <!-- 小字体TextView,用以展示 age年龄 -->
 <TextView
  android:id="@+id/tvAge"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="Small"
  android:textColor="#000000"
  android:textSize="14dp" />

</LinearLayout>

第三步,主Activity

import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends ListActivity {

 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }

 public void initView(){
  //调用只有1个参数的构造函数,实例化dbHelper
  DBHelper dbHelper = new DBHelper(this);
  //新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
  Cursor cursor = dbHelper.query("select * from test", null);
  //创建SimpleCursorAdapter对象,5个参数,
  //第一个是context,就写当前this就行
  //第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
  //第三个就是Cursor对象
  //第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
  //第五个就是对应列表项布局中的控件ID了
  SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
    R.layout.user_list_cell, cursor,
    new String[] { "name", "age" }, new int[] { R.id.tvName,
      R.id.tvAge });
  setListAdapter(simpleCursorAdapter);
  Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
 }
}

执行一下看看,我们是不是查询成功了?

操作SQLite数据库应了解,对数据库的增删改查都有两种方法,一种是前面的使用 rawQuery方法直接执行SQL语句,另一种就是使用SQLiteDatabase类的相应方法来操作,下面举一个第二种的例子,比如我们要插入数据 name=11 age=22

import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends ListActivity {

 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }

 public void initView(){
  //执行添加操作
  DBHelper dbHelper = new DBHelper(this);
  //获得写入权限getWritableDatabase
  SQLiteDatabase db = dbHelper.getWritableDatabase();
  //新建contentvalues保存insert数据
  ContentValues cv = new ContentValues();
  cv.put("name", "11");
  cv.put("age", "22");
  db.insert("test", null, cv);
  Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();

  ////查询操作
  ////调用只有1个参数的构造函数,实例化dbHelper
  //DBHelper dbHelper = new DBHelper(this);
  ////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
  //Cursor cursor = dbHelper.query("select * from test", null);
  ////创建SimpleCursorAdapter对象,5个参数,
  ////第一个是context,就写当前this就行
  ////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
  ////第三个就是Cursor对象
  ////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
  ////第五个就是对应列表项布局中的控件ID了
  //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
  //  R.layout.user_list_cell, cursor,
  //  new String[] { "name", "age" }, new int[] { R.id.tvName,
  //    R.id.tvAge });
  //setListAdapter(simpleCursorAdapter);
  //Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
 }
}

执行插入成功以后,再将插入语句注释,将查询语句去掉注释,重新启动,会发现最后一多了一个item,添加成功。

另外查询记录获得的Cursor对象,需要使用movetoFirst,moveToNext,movToPosition(position)等方法将指针移动相应的位置,来进行查询结果的读取。

import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends ListActivity {

 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initView();
 }

 public void initView(){
  //解析Cursor对象的查询操作
  DBHelper dbHelper = new DBHelper(this);
  SQLiteDatabase db = dbHelper.getWritableDatabase();
  Cursor cursor = db.query("test", null, null, null, null, null, null,
    null);
  //定义结果字符串
  String result = "";
  // 判断cursor不为空 这个很重要
  if (cursor != null) {
   while (cursor.moveToNext()) {
    String name = cursor.getString(cursor.getColumnIndex("name"));// 获取name列的值
    String age = cursor.getString(cursor.getColumnIndex("age"));// 获取age列的值
    result += "姓名:" + name + ",年龄:" + age + "\n";
   }
  }
  cursor.close();
  db.close();
  System.out.println(result);
  Toast.makeText(this, result, Toast.LENGTH_SHORT).show();

  // //执行添加操作
  // DBHelper dbHelper = new DBHelper(this);
  // //获得写入权限getWritableDatabase
  // SQLiteDatabase db = dbHelper.getWritableDatabase();
  // //新建contentvalues保存insert数据
  // ContentValues cv = new ContentValues();
  // cv.put("name", "11");
  // cv.put("age", "22");
  // db.insert("test", null, cv);
  // Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();

  ////查询操作
  ////调用只有1个参数的构造函数,实例化dbHelper
  //DBHelper dbHelper = new DBHelper(this);
  ////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
  //Cursor cursor = dbHelper.query("select * from test", null);
  ////创建SimpleCursorAdapter对象,5个参数,
  ////第一个是context,就写当前this就行
  ////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
  ////第三个就是Cursor对象
  ////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
  ////第五个就是对应列表项布局中的控件ID了
  //SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
  //  R.layout.user_list_cell, cursor,
  //  new String[] { "name", "age" }, new int[] { R.id.tvName,
  //    R.id.tvAge });
  //setListAdapter(simpleCursorAdapter);
  //Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
 }
}

执行以后,可以发现,name和age全都获取到了,并显示在了Toast和system.out中。是不是很有意思呢?

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android SQLite数据库增删改查操作的使用详解

    一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NULL.INTEGER.REAL(浮点数字). TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n). char(n).decimal(p,s) 等数据类型,只不过在运算或保存时会转成对应的五种数据类型. SQLite最大的特点是你可以把各种类型的数据保存到任何字段中,而不用关心字段

  • android中sqlite的按条件查找的小例子

    name      hobby Tom        football Peter       basketball 我们如果要查找爱好是football的一行数据怎么办呢?在网上找了很多方法,感觉都说不到点子上,所以浪费了很多时间,好在终于解决了,解决方法如下 [java] 复制代码 代码如下: Cursor mcursor=mSQLiteDatabase.query(tableName, new String[]{"id as _id","name","

  • Android开发之SQLite的使用方法

    前言 SQLite是一种轻量级的小型数据库,虽然比较小,但是功能相对比较完善,一些常见的数据库基本功能也具有,在现在的嵌入式系统中使用该数据库的比较多,因为它占用系统资源很少.Android系统中也不例外,也是采用SQLite,本节中就学习下在andorid中怎样使用该数据库来存放数据,并且对SQLite完成简单的新建,更新,查询,删除等操作. 实验说明: Android中使用SQLite数据库时,需要用adb来辅助调试,如果想在windows下的cmd命令行中使用adb,必须先配置环境变量,我

  • Android--SQLite(增,删,改,查)操作实例代码

    需要5个类: 1.实体类:Person.java 2.抽象类:SQLOperate.java(封装了对数据库的操作) 3.助手类:DBOpenHelper.java(继承SQLiteOpenHelper) 4.实现类:SQLOperateImpl.java(实现抽象类SQLOperate.java) 5.测试类:Test.java(继承AndroidTestCase) 1.Person.java 复制代码 代码如下: package com.mrzhu.sqltite; public class

  • android创建数据库(SQLite)保存图片示例

    复制代码 代码如下: //1.创建数据库public class DBService extends SQLiteOpenHelper { private final static int VERSION = 1;private final static String DATABASE_NAME = "uniteqlauncher.db"; public DBService(Context context) {    this(context, DATABASE_NAME, null,

  • 深入Android SQLite 事务处理详解

    应用程序初始化时需要批量的向sqlite中插入大量数据,单独的使用for+Insert方法导致应用响应缓慢,因为 sqlite插入数据的时候默认一条语句就是一个事务,有多少条数据就有多少次磁盘操作.我的应用初始5000条记录也就是要5000次读写磁盘操作. 而且不能保证所有数据都能同时插入.(有可能部分插入成功,另外一部分失败,后续还得删除.太麻烦) 解决方法: 添加事务处理,把5000条插入作为一个事务 我们使用SQLite的事务进行控制: 复制代码 代码如下: db.beginTransac

  • Android中的SQL查询语句LIKE绑定参数问题解决办法(sqlite数据库)

    由于考虑到数据库的安全性,不被轻易SQL注入,执行查询语句时,一般不使用直接拼接的语句,而是使用参数传递的方法.然后在使用参数传递的方法中时,发现当使用like方式查询数据时,很容易出现一个问题. 错误案例: 复制代码 代码如下: String myname = "abc";String sql = "select * from mytable where name like '?%'";Cursor cursor = db.rawQuery(sql, new St

  • Android 用SQLite实现事务的方法

    复制代码 代码如下: public void payment() {  SQLiteDatabase db = dbOpenHelper.getReadableDatabase();  db.beginTransaction();//开始事务  try {   db.execSQL("update person set amount=amount-10 where personid=2");   db.execSQL("update person set amount=amo

  • android开发教程之listview显示sqlite数据

    复制代码 代码如下: package com.it.db; import java.util.List;import com.it.dao.PersonDao;import com.it.domain.Person;import android.os.Bundle;import android.app.Activity;import android.content.Intent;import android.view.View;import android.view.ViewGroup;impo

  • Android使用SQLite数据库的简单实例

    先画个图,了解下Android下数据库操作的简单流程: 1.首先,写一个自己的数据库操作帮助类,这个类继承自Android自带的SQLiteOpenHelper. 2.在自己的DAO层借助自己的Helper写数据库操作的一些方法 3.Activity调用DAO层的数据库操作方法进行操作 下面例子是: 1.Helper 复制代码 代码如下: package cn.learn.db.util; import android.content.Context;import android.databas

随机推荐