Android数据存储之SQLite

SQLite:Android提供的一个标准的数据库,支持SQL语句。
用来处理数据量较大的数据。
△ SQLite特征:
1.轻量性
2.独立性
3.隔离性
4.跨平台性
5.多语言接口
6.安全性
△ SQLite数据库的一般操作包括:创建数据库、打开数据库、创建表、向表中添加数据、从表中删除数据、修改表中的数据、关闭数据库、删除指定表、删除数据库和查询表中的某条数据。
1.创建和打开数据库:使用openOrCreateDatabase方法来实现,因为它会自动去检测是否存在这个数据库,如果存在则打开,如果不存在则创建一个数据库。
创建成功后返回一个SQLiteDatabase对象。
/* 数据库对象 */
private SQLiteDatabase  mSQLiteDatabase = this.openOrCreateDatabase(DATABASE_NAME, MODE_PRIVATE, null);
2.创建表:要创建表可以通过execSQL方法来执行一条SQL语句。
/* 创建表的sql语句 */
private final static String CREATE_TABLE = "CREATE TABLE " + TABLE_NAME + " (" + TABLE_ID + " INTEGER PRIMARY KEY," + TABLE_NUM + " INTERGER,"+ TABLE_DATA + " TEXT)";
  // 获取数据库Phones的Cursor
  try
  {
   /* 在数据库mSQLiteDatabase中创建一个表 */
   mSQLiteDatabase.execSQL(CREATE_TABLE);
  }
3.向表中添加一条数据:
可以使用insert方法来添加数据,但是insert方法要求把数据都打包到ContentValues中,ContentValues其实就是一个Map,Key值是字段名称,Value值是字段值。通过ContentValues的put方法就可以把数据放到ContentValues对象中,然后插入到表中去。
/* 更新一条数据 */
public void UpData()
{
  ContentValues cv = new ContentValues();
  cv.put(TABLE_NUM, 1);
  cv.put(TABLE_DATA, "测试数据库数据" );
  mSQLiteDatabase.insert(TABLE_NAME, null, cv );
  /* 同样可以通过execSQL 方法来执行一条"插入"的SQL语句,代码如下 :
  String INSTERT_DATA = "INSERT INTO table1(_id,num,data) values(1,1,'通过SQL语句插入')";
  mSQLiteDatabase.execSQL(INSERT_DATA);*/
}
4.从表中删除数据
mSQLiteDatabase.delete( "Examples.db", "WHERE _id="+0, null );
/* 也可以通过执行 execSQL 方法来执行SQL语句删除数据:
string DELETE_DATA = "DELETE FROM table1 WHERE _id=1";
mSQLiteDatabase.execSQL(DELETE_DATA); */
5.修改表中的数据
ContentValues cv = new ContentValues();
cv.put("TABLE_NUM",3);
cv.put("TABLE_DATA","修改后的数据");
mSQLiteDatabase.update("table1",cv,"num"+"="+Integer.toString(0), null );
6.关闭数据库
关闭数据库很重要,也是大家经常容易忘记的。关闭的方法很简单,直接使用SQLiteDatabase的close方法。
mSQLiteDatabase.close();
7.删除指定表
mSQLiteDatabase.execSQL("DROP TABLE table1");
8.删除数据库
this.deleteDatabase("Examples.db");
9.查询表中的某条数据
Android中查询数据通过Cursor类来实现的。我们使用SQLiteDatabase.query()方法,会得到一个Cursor对象,Cursor指向的就是每一条数据。
代码如下:
/* 删除数据库 */
public void DeleteDataBase()
{
  this.deleteDatabase(DATABASE_NAME);
  this.finish();
}

/* 删除一个表 */
public void DeleteTable()
{
  mSQLiteDatabase.execSQL("DROP TABLE " + TABLE_NAME);
  this.finish();
}

/* 更新一条数据 */
public void UpData()
{
  ContentValues cv = new ContentValues();
  cv.put(TABLE_NUM, miCount);
  cv.put(TABLE_DATA, "修改后的数据" + miCount);
  /* 更新数据 */
  mSQLiteDatabase.update(TABLE_NAME, cv, TABLE_NUM + "=" + Integer.toString(miCount - 1), null);
  UpdataAdapter();
}

/* 向表中添加一条数据 */
public void AddData()
{
  ContentValues cv = new ContentValues();
  cv.put(TABLE_NUM, miCount);
  cv.put(TABLE_DATA, "测试数据库数据" + miCount);
  /* 插入数据 */
  mSQLiteDatabase.insert(TABLE_NAME, null, cv);
  miCount++;
  UpdataAdapter();
}

/* 从表中删除指定的一条数据 */
public void DeleteData()
{
  /* 删除数据 */
  mSQLiteDatabase.execSQL("DELETE FROM " + TABLE_NAME + " WHERE _id=" + Integer.toString(miCount));
  miCount--;
  if (miCount < 0)
  {
   miCount = 0;
  }
  UpdataAdapter();
}
☆ SQLiteOpenHelper应用:
在使用SQLiteOpenHelper时需要注意:SQLiteOpenHelper的构造方法中分别需要传入Content、数据库名称、CursorFactory(一般传入null,否则为默认数据库)、数据库版本号(不能为负数)。SQLiteOpenHelper构造函数中并没有真正创建数据库,而是在调用getWritableDatabase或者getReadableDatabase方法时才真正去创建数据库,并返回一个SQLiteDatabase对象。
代码如下:
// 打开数据库,返回数据库对象
public void open() throws SQLException
{
  mDatabaseHelper = new DatabaseHelper(mContext);
  mSQLiteDatabase = mDatabaseHelper.getWritableDatabase();
}

// 关闭数据库
public void close()
{
  mDatabaseHelper.close();
}
/* 插入一条数据 */
public long insertData(int num, String data)
{
  ContentValues initialValues = new ContentValues();
  initialValues.put(KEY_NUM, num);
  initialValues.put(KEY_DATA, data);
  return mSQLiteDatabase.insert(DB_TABLE, KEY_ID, initialValues);
}
/* 删除一条数据 */
public boolean deleteData(long rowId)
{
  return mSQLiteDatabase.delete(DB_TABLE, KEY_ID + "=" + rowId, null) > 0;
}
/* 通过Cursor查询所有数据 */
public Cursor fetchAllData()
{
  return mSQLiteDatabase.query(DB_TABLE, new String[] { KEY_ID, KEY_NUM, KEY_DATA }, null, null, null, null, null);
}
/* 查询指定数据 */
public Cursor fetchData(long rowId) throws SQLException
{
  Cursor mCursor =
  mSQLiteDatabase.query(true, DB_TABLE, new String[] { KEY_ID, KEY_NUM, KEY_DATA }, KEY_ID + "=" + rowId, null, null, null, null, null);
  if (mCursor != null)
  {
   mCursor.moveToFirst();
  }
  return mCursor;
}
/* 更新一条数据 */
public boolean updateData(long rowId, int num, String data)
{
  ContentValues args = new ContentValues();
  args.put(KEY_NUM, num);
  args.put(KEY_DATA, data);
  return mSQLiteDatabase.update(DB_TABLE, args, KEY_ID + "=" + rowId, null) > 0;
}

相关参考链接:http://www.apkbus.com/forum.php?mod=viewthread&tid=140454

http://www.apkbus.com/android-726-1-1.html

http://www.apkbus.com/forum.php?mod=viewthread&tid=15731

相关代码下载链接:http://www.apkbus.com/android-141976-1-1.html

Android数据存储:SQLite的更多相关文章

  1. Android数据存储——SQLite数据库(模板)

    本篇整合Android使用数据库,要保存一个实体类的样本. 首先看一下数据库语句: ORM:关系对象映射 添加数据: ContentValues values = new ContentValues( ...

  2. Android数据存储之SQLite数据库

    Android数据存储 之SQLite数据库简介 SQLite的相关知识,并结合Java实现对SQLite数据库的操作. SQLite是D.Richard Hipp用C语言编写的开源嵌入式数据库引擎. ...

  3. Android数据存储之SQLCipher数据库加密

    前言: 最近研究了Android Sqlite数据库(文章地址:Android数据存储之Sqlite的介绍及使用)以及ContentProvider程序间数据共享(Android探索之ContentP ...

  4. Android数据存储之GreenDao 3.0 详解

    前言: 今天一大早收到GreenDao 3.0 正式发布的消息,自从2014年接触GreenDao至今,项目中一直使用GreenDao框架处理数据库操作,本人使用数据库路线 Sqlite----> ...

  5. Android数据存储方式--SharedPreferences

    Android数据存储方式有如下四种:SharedPreferences.存储到文件.SQLite数据库.内容提供者(Content provider).存储到网络服务器. 本文主要介绍一下Share ...

  6. 10、Android数据存储

    课程目标: 掌握Android中数据存储的几种方式 熟练使用PreferenceActivity&PreferenceScreen做专业的Setting功能 熟练使用SQLite3来存储数据 ...

  7. Android数据存储五种方式

    1 使用SharedPreferences存储数据:常用于做本地缓存 2 文件存储数据:(1)data/data/<package name>/files目录内   (2)SDCard内 ...

  8. Android数据存储:Shared Preferences

    Android数据存储之SharedPreferences 在Android系统中提供了多种存储技术.通过这些存储技术可以将数据存储在各种存储介质上, Android 为数据存储提供了如下几种方式:1 ...

  9. 【Android开发日记】之入门篇(八)——Android数据存储(下)

    废话不多说了,紧接着来讲数据库的操作吧.Come On! 提到数据存储问题,数据库是不得不提的.数据库是用来存储关系型数据的不二利器.Android为开发者提供了强大的数据库支持,可以用来轻松地构造基 ...

随机推荐

  1. CF848E Days of Floral Colours——DP+多项式求逆/分治NTT

    官方题解:http://codeforces.com/blog/entry/54233 就是由简入繁 1.序列处理,只考虑一个半圆 2.环形处理(其实这个就是多了旋转同构) 然后基于分割线邻居的跨越与 ...

  2. JAVA SpringBoot 项目打成jar包供第三方引用自动配置(Spring发现)解决方案

    本项目测试环境 JDK: 1.8 SpringBoot: 2.1 需求描述 当我们想要利用SpringBoot封装一套组件并发布给第三方使用时,我们就不得不考虑我们的组件能否被使用者正确引入使用,此处 ...

  3. 文件操作(十二)——open,read,close,write,seek,truncate

    open函数 #!/usr/bin/env python #-*- coding:utf8 -*- f = open('xxx','r',encoding='utf-8') data = f.read ...

  4. poj 3678(SCC+2-SAT)

    传送门:Problem 3678 https://www.cnblogs.com/violet-acmer/p/9769406.html 难点: 题意理解+构图 题意: 有n个点 v[0,2..... ...

  5. my phone blackberry classic / passport / priv / keyone

    smy blackberry classic PIN: 2BF66A72 / 查看手机位置https://protect.blackberry.com/protect/mydevice#BlackBe ...

  6. java8的新特性详解-----------Lamda表达式

    java8最大的亮点就是引入了Lamda表达式  , 函数式编程的概念  具体啥意思我也不知道.只管用就行了,非常的强大,简洁,一个表达式相当于以前的十几行代码  因为之前要实现这种效果全靠if el ...

  7. 缓存穿透、雪崩、热点与Redis

    (拼多多问:Redis雪崩解决办法) 导读:互联网系统中不可避免要大量用到缓存,在缓存的使用过程中,架构师需要注意哪些问题?本文以 Redis 为例,详细探讨了最关键的 3 个问题. 一.缓存穿透预防 ...

  8. Java的参数传递是「按值传递」还是「按引用传递」?

    JAVA传递的只有值,.传递的都是栈里的的值,只是有些栈里面的是值.有的是内存地址.(原文传递的都是栈里的的值有误,局部变量在栈中,成员变量在堆中,类变量(静态变量和常量)在方法区中,可以看做本文的变 ...

  9. Spring 学习04

    一.上节内容回顾 1 基于aspectj的注解aop操作 2 spring的jdbcTemplate操作 (1)实现crud操作 - 添加.修改.删除update方法 - 查询 -- 查询某个值 qu ...

  10. JAVA NIO 中的 zerocopy 技术提高IO性能

    关于一篇更详细更好的介绍 ZeroCopy技术的文章,可参考:JAVA IO 以及 NIO 理解 这篇文章介绍了 zerocopy技术来提高Linux平台上的IO密集型的JAVA应用程序的性能. ze ...