Android Sqlite 資料的儲存

來源:互聯網
上載者:User

一般在開發程式中,經常使用資料的儲存功能,如在使用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();
}

 

在此只是提供一下簡單的參考!歡迎批評指正!

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.