欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android使用Sqlite存儲(chǔ)數(shù)據(jù)用法示例

 更新時(shí)間:2016年11月01日 11:44:31   作者:老碼農(nóng)豆豆  
這篇文章主要介紹了Android使用Sqlite存儲(chǔ)數(shù)據(jù)的方法,結(jié)合實(shí)例形式分析了Android操作SQLite數(shù)據(jù)庫(kù)的相關(guān)步驟與操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Android使用Sqlite存儲(chǔ)數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:

一般在開(kāi)發(fā)程序中,經(jīng)常使用數(shù)據(jù)的存儲(chǔ)功能,如在使用Delphi開(kāi)發(fā)程序時(shí),存儲(chǔ)程序的簡(jiǎn)單設(shè)置的INI文件,在C#開(kāi)發(fā)中有時(shí)也需要存儲(chǔ)簡(jiǎn)單的設(shè)置,個(gè)人一般存儲(chǔ)在XML中,也在INI中存儲(chǔ)過(guò),但是不如XML使用方便,那么這些都是簡(jiǎn)單的數(shù)據(jù)存儲(chǔ)功能,在Android中也支持這樣的文件存儲(chǔ),但是現(xiàn)在這里主要說(shuō)的還是使用SQLite存儲(chǔ)數(shù)據(jù),SQLite是一種跨平臺(tái)的數(shù)據(jù)庫(kù),是單文件式的,如咱們平常見(jiàn)的最多的Access數(shù)據(jù)庫(kù),但是他有比Access更好的平臺(tái)支持,并且支持分頁(yè),現(xiàn)在主要是用于嵌入式的開(kāi)發(fā)。

在開(kāi)發(fā)過(guò)程中其實(shí)可以直接聲明數(shù)據(jù)庫(kù)對(duì)象來(lái)進(jìn)行存儲(chǔ)管理的,代碼如下:

SQLiteDatabase sqlitedb; //數(shù)據(jù)庫(kù)對(duì)象
sqlitedb = this.openOrCreateDatabase(datebaseName, MODE_PRIVATE, null);
//執(zhí)行代碼:
SqlString = " create table " + tableName + " (_id integer primary key,num integer,data text) ";
sqlitedb.execSQL(SqlString);

這種方式需要我們處理的內(nèi)容更多一些,個(gè)人感覺(jué)不是太方便,就像我們開(kāi)發(fā)C#的程序使用SqlHelper一樣,在Android平臺(tái)中也提供了一個(gè)類似的類:

SQLiteOpenHelper 這樣的類

我們可以通過(guò)實(shí)現(xiàn)這個(gè)類來(lái)完成我們的操作,這樣更簡(jiǎn)單和高效:

代碼如下:

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);
  }
}

在這里只做了一個(gè)簡(jiǎn)單的寫(xiě)作,沒(méi)有寫(xiě)太多方法這個(gè)只是一個(gè)引導(dǎo),可以對(duì)這個(gè)類進(jìn)行擴(kuò)展,這樣使用起來(lái)更方便一些。

下面是一個(gè)簡(jiǎn)單的調(diào)用:

//聲明
SQLiteDatabase db = null;
DBHelper dbhelper = null;
//實(shí)例化
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();
}

在此只是提供一下簡(jiǎn)單的參考!歡迎批評(píng)指正!

更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android操作SQLite數(shù)據(jù)庫(kù)技巧總結(jié)》、《Android數(shù)據(jù)庫(kù)操作技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android文件操作技巧匯總》、《Android編程開(kāi)發(fā)之SD卡操作方法匯總》、《Android開(kāi)發(fā)入門(mén)與進(jìn)階教程》、《Android資源操作技巧匯總》、《Android視圖View技巧總結(jié)》及《Android控件用法總結(jié)

希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論