Android使用Sqlite存储数据用法示例

 更新时间:2016年11月01日 11:44:31   作者:老码农豆豆  
这篇文章主要介绍了Android使用Sqlite存储数据的方法,结合实例形式分析了Android操作SQLite数据库的相关步骤与操作技巧,需要的朋友可以参考下

本文实例讲述了Android使用Sqlite存储数据的方法。分享给大家供大家参考,具体如下:

一般在开发程序中,经常使用数据的存储功能,如在使用Delphi开发程序时,存储程序的简单设置的INI文件,在C#开发中有时也需要存储简单的设置,个人一般存储在XML中,也在INI中存储过,但是不如XML使用方便,那么这些都是简单的数据存储功能,在Android中也支持这样的文件存储,但是现在这里主要说的还是使用SQLite存储数据,SQLite是一种跨平台的数据库,是单文件式的,如咱们平常见的最多的Access数据库,但是他有比Access更好的平台支持,并且支持分页,现在主要是用于嵌入式的开发。

在开发过程中其实可以直接声明数据库对象来进行存储管理的,代码如下:

SQLiteDatabase sqlitedb; //数据库对象
sqlitedb = this.openOrCreateDatabase(datebaseName, MODE_PRIVATE, null);
//执行代码:
SqlString = " create table " + tableName + " (_id integer primary key,num integer,data text) ";
sqlitedb.execSQL(SqlString);

这种方式需要我们处理的内容更多一些,个人感觉不是太方便,就像我们开发C#的程序使用SqlHelper一样,在Android平台中也提供了一个类似的类:

SQLiteOpenHelper 这样的类

我们可以通过实现这个类来完成我们的操作,这样更简单和高效:

代码如下:

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
public class DBHelper extends SQLiteOpenHelper {
  private static final int DB_VERSION = 1;
  public DBHelper(Context context, String name, CursorFactory factory, int version) {
    super(context, name, factory, version);
    // TODO Auto-generated constructor stub
  }
  public DBHelper(Context context, String dBName) {
    super(context, dBName, null, DB_VERSION);
  }
  @Override
  public void onCreate(SQLiteDatabase db) {
    // TODO Auto-generated method stub
  }
  public void onCreate(SQLiteDatabase db, String createDBSql) {
    // TODO Auto-generated method stub
    db.execSQL(createDBSql);
  }
  @Override
  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    // TODO Auto-generated method stub
  }
  @Override
  public void onOpen(SQLiteDatabase db) {
    // TODO Auto-generated method stub
    super.onOpen(db);
  }
  public void InsertintoDB(SQLiteDatabase db,String sql)
  {
    db.execSQL(sql);
  }
  public Cursor opendb(SQLiteDatabase db,String sql) {
    return db.rawQuery(sql, null);
  }
}

在这里只做了一个简单的写作,没有写太多方法这个只是一个引导,可以对这个类进行扩展,这样使用起来更方便一些。

下面是一个简单的调用:

//声明
SQLiteDatabase db = null;
DBHelper dbhelper = null;
//实例化
dbhelper = new DBHelper(this, "DBName");
//方法
void CreateTable() {
    String sql = "Create Table if not exists " + TABLE_NAME + " ( " + ID + " text not null , " + NAME + " text not null );";
    dbhelper.onCreate(db, sql);
  }
  void InsertDB(String id, String name) {
    db = dbhelper.getWritableDatabase();
    String sql = "insert into " + TABLE_NAME + " (" + ID + "," + NAME + ") values('" + id + "','" + name + "')";
    dbhelper.InsertintoDB(db, sql);
  }
  void getDB() {
    db = dbhelper.getReadableDatabase();
    String sql = "select * from " + TABLE_NAME;
    Cursor cursor = dbhelper.opendb(db, sql);
    String text = "";
    while (cursor.moveToNext()) {
      for (int i = 0; i < cursor.getColumnCount(); i++) {
        text += cursor.getString(i);
      }
      text += "\n";
    }
    Toast.makeText(this, cursor.getCount() + "\n" + text,Toast.LENGTH_LONG).show();
}

在此只是提供一下简单的参考!欢迎批评指正!

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作SQLite数据库技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结

希望本文所述对大家Android程序设计有所帮助。

相关文章

  • Android使用Intent获取联系人信息

    Android使用Intent获取联系人信息

    这篇文章主要为大家详细介绍了Android Intent的使用方法,Android如何获取联系人信息,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Android系统更改状态栏字体颜色

    Android系统更改状态栏字体颜色

    这篇文章主要介绍了Android系统更改状态栏字体颜色的方法,需要的朋友可以参考下
    2016-01-01
  • Android实现将View转化为图片并保存到本地

    Android实现将View转化为图片并保存到本地

    这篇文章主要为大家详细介绍了Android实现将View转化为图片并保存到本地,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • 浅谈Android Studio导出javadoc文档操作及问题的解决

    浅谈Android Studio导出javadoc文档操作及问题的解决

    这篇文章主要介绍了浅谈Android Studio导出javadoc文档操作及问题的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • Android控件ViewPager实现带有动画的引导页

    Android控件ViewPager实现带有动画的引导页

    这篇文章主要为大家详细介绍了Android控件ViewPager实现带有动画的引导页,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • Android开发之自定义加载动画详解

    Android开发之自定义加载动画详解

    这篇文章主要介绍了Android开发的自定义加载动画,效果为一个连续的动画,就是这个大圆不停地吞下小圆,文中示例代码讲解详细,感兴趣的可以了解一下
    2022-03-03
  • Android 无预览拍照功能

    Android 无预览拍照功能

    最近小编接到一个项目,遇到这样的需求,要求在后台拍照并保存功能,也就是无预览拍照功能,下面小编给大家带来了实例代码,需要的朋友参考下
    2018-02-02
  • Android 更新RecyclerView的好方法

    Android 更新RecyclerView的好方法

    在使用RecyclerView的时候不免要修改RecyclerView的数据,使用notifyDataSetChanged()来刷新界面,但是当数据多,而只是修改了一点的数据,或者刷新比较频繁,这样就会导致界面卡顿,用户交互特别不好,这时可以使用RecyclerView方法解决,具体实现代码大家参考下本文吧
    2017-06-06
  • Android App跳转微信小程序踩坑实战

    Android App跳转微信小程序踩坑实战

    现在市面上很多的应用都可以实现相互跳转,下面这篇文章主要给大家介绍了关于Android App跳转微信小程序踩坑的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • Android权限操作之uses-permission详解

    Android权限操作之uses-permission详解

    这篇文章主要介绍了Android权限操作之uses-permission,较为详细的分析了uses-permission常见权限操作类型与功能,需要的朋友可以参考下
    2016-10-10

最新评论