Android SQLite 資料庫操作詳解

在開發Android應用過程中,本地數據的存儲和管理是非常常見的需求。而Android系統提供了SQLite資料庫,支持非常強大和靈活的數據存儲方式。本文就來詳細介紹如何在Android應用中進行SQLite資料庫操作。

一、創建SQLite資料庫

在Android應用中創建SQLite資料庫有兩個核心概念:SQLiteOpenHelper 和 SQLiteDatabase。

SQLiteOpenHelper 是Sqlite資料庫操作的幫助類,提供了創建、更新和打開 Sqlite 資料庫的功能。下面是一個創建 SQLiteOpenHelper 的示例代碼:

public class MySQLiteOpenHelper extends SQLiteOpenHelper {
    private static final String DB_NAME = "my_db.db"; // 資料庫名稱
    private static final int DB_VERSION = 1; // 資料庫版本

    public MySQLiteOpenHelper(Context context) {
        super(context, DB_NAME, null, DB_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // 創建表格等資料庫操作
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
       // 資料庫升級操作
    }
}

SQLiteDatabase 是一個表示 SQLite 資料庫的類,提供了對數據表的操作,包括 CRUD 操作(增刪改查)等。下面是一個使用 SQLiteDatabase 創建表格的示例代碼:

MySQLiteOpenHelper helper = new MySQLiteOpenHelper(context);
SQLiteDatabase db = helper.getWritableDatabase();
String sql = "create table user(_id integer primary key autoincrement,name varchar(20) not null,age integer not null)";
db.execSQL(sql);
db.close();

二、SQLite資料庫的增刪改查操作

1. SQLite 資料庫的插入操作

使用 SQLiteDatabase 的 insert() 方法可以將數據插入到資料庫中。一般情況下,我們使用 ContentValues 來輔助進行數據增加。下面是一個示例代碼:

MySQLiteOpenHelper helper = new MySQLiteOpenHelper(context);
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name","Tom");
values.put("age",25);
db.insert("user",null,values);
db.close();

2. SQLite 資料庫的查詢操作

使用 SQLiteDatabase 的 query() 方法可以進行資料庫的查詢操作,使用 Cursor 對象來獲取查詢結果。下面是一個查詢用戶列表並列印的示例代碼:

MySQLiteOpenHelper helper = new MySQLiteOpenHelper(context);
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.query("user",new String[]{"_id","name","age"},null,null,null,null,null);
while(cursor.moveToNext()){
    // 獲取每列的數據
    int id = cursor.getInt(cursor.getColumnIndex("_id"));
    String name = cursor.getString(cursor.getColumnIndex("name"));
    int age = cursor.getInt(cursor.getColumnIndex("age"));
    // 列印數據
    Log.d("TAG","id = "+id+", name = "+name+", age = "+age);
}
cursor.close();
db.close();

3. SQLite 資料庫的更新操作

使用 SQLiteDatabase 的 update() 方法可以進行資料庫的更新操作。下面是一個更新指定用戶的示例代碼:

MySQLiteOpenHelper helper = new MySQLiteOpenHelper(context);
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("age", 26);
int updateCount = db.update("user", values, "_id=?", new String[]{"2"});
db.close();

4. SQLite 資料庫的刪除操作

使用 SQLiteDatabase 的 delete() 方法可以進行資料庫的刪除操作。下面是一個刪除指定用戶的示例代碼:

MySQLiteOpenHelper helper = new MySQLiteOpenHelper(context);
SQLiteDatabase db = helper.getWritableDatabase();
int deleteCount = db.delete("user","_id=?",new String[]{"2"});
db.close();

三、SQLite資料庫事務操作

在進行 SQLite 資料庫操作時,如果需要對多個操作進行集合管理或者需要批量進行數據操作,可以使用事務操作。SQLite 支持事務的概念,這樣可以增加數據的安全性和數據處理速度。下面是一個資料庫事務管理的示例代碼:

MySQLiteOpenHelper helper = new MySQLiteOpenHelper(context);
SQLiteDatabase db = helper.getWritableDatabase();
try {
    db.beginTransaction();
    // 資料庫操作1
    // 資料庫操作2
    // 資料庫操作3
    db.setTransactionSuccessful();
} finally {
    db.endTransaction();
    db.close();
}

四、SQLite資料庫執行SQL語句操作

在某些情況下,我們需要執行自定義的 SQL 語句進行數據的操作,這時我們可以使用 SQLiteDatabase 的 execSQL() 方法來執行 SQL 語句。下面是一個執行自定義 SQL 語句的示例代碼:

MySQLiteOpenHelper helper = new MySQLiteOpenHelper(context);
SQLiteDatabase db = helper.getWritableDatabase();
db.execSQL("insert into user(name,age) values('Tom',25)");
db.close();

五、總結

本文詳細介紹了在 Android 應用中對 SQLite 資料庫進行相關操作的方法,包括創建資料庫、數據的增刪改查、事務操作,以及執行 SQL 語句等。使用 SQLite 資料庫可以為我們的應用提供強大和靈活的本地數據存儲和管理功能,希望本文能對開發人員有所幫助。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/255193.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 12:15
下一篇 2024-12-15 12:15

相關推薦

  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • Python 常用資料庫有哪些?

    在Python編程中,資料庫是不可或缺的一部分。隨著互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的資料庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝資料庫方案

    本文將介紹在openeuler操作系統中安裝資料庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟體源 sudo…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • Python代碼實現迴文數最少操作次數

    本文將介紹如何使用Python解決一道經典的迴文數問題:給定一個數n,按照一定規則對它進行若干次操作,使得n成為迴文數,求最少的操作次數。 一、問題分析 首先,我們需要了解迴文數的…

    編程 2025-04-29
  • Python磁碟操作全方位解析

    本篇文章將從多個方面對Python磁碟操作進行詳細闡述,包括文件讀寫、文件夾創建、刪除、文件搜索與遍歷、文件重命名、移動、複製、文件許可權修改等常用操作。 一、文件讀寫操作 文件讀寫…

    編程 2025-04-29
  • 資料庫第三範式會有刪除插入異常

    如果沒有正確設計資料庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係資料庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • Python元祖操作用法介紹

    本文將從多個方面對Python元祖的操作進行詳細闡述。包括:元祖定義及初始化、元祖遍歷、元祖切片、元祖合併及比較、元祖解包等內容。 一、元祖定義及初始化 元祖在Python中屬於序…

    編程 2025-04-29
  • 如何用Python對數據進行離散化操作

    數據離散化是指將連續的數據轉化為離散的數據,一般是用於數據挖掘和數據分析中,可以幫助我們更好的理解數據,從而更好地進行決策和分析。Python作為一種高效的編程語言,在數據處理和分…

    編程 2025-04-29

發表回復

登錄後才能評論