Android學習筆記:SQLite數據庫開源庫LitePal的基本使用方法
標簽: SQL SQLite LitePal 數據庫 Android
通過項目實踐,來熟悉利用開源庫LitePal來操作SQLite數據庫的基本使用方法。
一、LitePal開源庫
1、簡介
2、配置
dependencies {
compile 'org.litepal.android:core:1.6.1'
}
編輯完成后,點擊頁面上方的Sync now來同步。其中,1.6.1是版本號,最新版本號信息可以到LitePal項目主頁去查看。<?xml version="1.0" encoding="utf-8"?>
<litepal>
<dbname value="BookStore" />
<version value="1" />
<list>
</list>
</litepal>
其中,dbname是數據庫名,我們沿用上一篇關于SQLiteDatabase操作SQLite數據所使用的案例,version是數據庫的版本號,list標簽指定映射模型。<manifest>
<application
android:name="org.litepal.LitePalApplication"
...
>
...
</application>
</manifest>
當然,如果你使用了自己的Application,如下所示:public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
LitePal.initialize(this);
}
...
}
在配置AndroidManifest.xml文件時,則需要按如下所示配置:<manifest>
<application
android:name="com.example.MyApplication"
...
>
...
</application>
</manifest>
經過以上三步配置之后,就可以開始使用LitePal了。3、創建數據庫
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<Button
android:id="@+id/create_database"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="創建"
/>
<Button
android:id="@+id/add_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="添加"
/>
<Button
android:id="@+id/update_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="更新"
/>
<Button
android:id="@+id/delete_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="刪除"
/>
<Button
android:id="@+id/query_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="查詢"
/>
</LinearLayout>
(1)、定義Book類。package com.my.litepaltest;
public class Book {
private int id; //主鍵,可定義可不定義,會自動生成。
private String author; //作者
private double price; //價格
private int pages; //頁數
private String name; //書名
//自動生成的getter和setter方法,Alt + Insert
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getAuthor() {
return author;
}
public void setAuthor(String author) {
this.author = author;
}
public double getPrice() {
return price;
}
public void setPrice(double price) {
this.price = price;
}
public int getPages() {
return pages;
}
public void setPages(int pages) {
this.pages = pages;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
快速生成getter和setter方法快捷鍵:Alt + Insert(2)、將Book類添加到映射模型中。
<list>
<mapping class = "com.my.litepaltest.Book" />
</list>
mapping標簽就是用來聲明我們配置的映射類型,要使用完整的類名。package com.my.litepaltest;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import org.litepal.LitePal;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button createDatabase = (Button)findViewById(R.id.create_database);
Button addData = (Button)findViewById(R.id.add_data);
Button updateData = (Button)findViewById(R.id.update_data);
Button deleteData = (Button)findViewById(R.id.delete_data);
Button queryData = (Button)findViewById(R.id.query_data);
//更新按鈕點擊事件
createDatabase.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
LitePal.getDatabase(); //打開或創建數據庫
}
});
}
}
運行程序,點擊創建按鈕:可以看到數據庫已存在,Book也已經建立,還可以查看建表語句:
4、升級數據庫
public class Book {
...
private String press; //出版社
...
public String getPress() {
return press;
}
public void setPress(String press) {
this.press = press;
}
}
(2)、新建Category類package com.my.litepaltest;
public class Category {
private int id;
private String categoryName; //分類名
private int categoryCode; //分類代碼
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getCategoryName() {
return categoryName;
}
public void setCategoryName(String categoryName) {
this.categoryName = categoryName;
}
public int getCategoryCode() {
return categoryCode;
}
public void setCategoryCode(int categoryCode) {
this.categoryCode = categoryCode;
}
}
(3)、將Category類添加到映射模型中,更新數據庫一定要記得將版本號加一。<litepal>
...
<version value="2" />
<list>
...
<mapping class = "com.my.litepaltest.Category" />
</list>
</litepal>
數據表已成功創建。
5、添加數據
public class Book extends DataSupport{
...
}
(2)、修改MainActivity中的代碼,在createDatabase的點擊事件下新增一個addData的點擊事件。 //添加按鈕點擊事件
addData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Book book = new Book();
book.setName("The Da Vinci Code");
book.setAuthor("Dan Brown");
book.setPages(454);
book.setPrice(16.96);
book.setPress("Unknown");
book.save();
}
});
save()方法在Book類中并不存在,之所以能使用是因為他是從DataSupport類中繼承來的。作用就是添加剛剛保存好的數據。運行程序,點擊添加按鈕,然后查看Book表中的數據。
6、更新數據
public class MainActivity extends AppCompatActivity {
...
//更新數據的點擊事件
updateData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Book book = new Book();
book.setName("The Lost Symbol");
book.setAuthor("Dan Brown");
book.setPages(510);
book.setPrice(19.95);
book.setPress("Unknown");
book.save();
book.setPrice(10.99); //對剛才更新的數據重新設值
book.save(); //調用save()方法更新數據
}
});
}
}
運行程序,然后點擊更新按鈕,查看Book表中的數據。可以看到,原本添加的數據是19.95,更新后變成了10.99.
//更新數據的點擊事件
updateData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// Book book = new Book();
// book.setName("The Lost Symbol");
// book.setAuthor("Dan Brown");
// book.setPages(510);
// book.setPrice(19.95);
// book.setPress("Unknown");
// book.save();
// book.setPrice(10.99); //對剛才更新的數據重新設值
// book.save(); //調用save()方法更新數據
Book book = new Book();
book.setPrice(14.95); //設置新的價格
book.setPress("Anchor"); //設置新的出版社
//利用約束語句,將書名為The Lost Symbol和作者為Dan Brown的圖書價格、出版社更新
book.updateAll("name = ? and author = ?","The Lost Symbol","Dan Brown");
}
});
運行程序,點擊更新按鈕,查看Book表中的數據:數據庫中的數據已經按照程序預期進行了更新。
Book book = new Book();
book.setToDefault("pages");
book.updateAll();
上述代碼就是對 pages 字段的值進行恢復默認值。若不添加約束條件,則對Book表的所有 pages 字段均有效。7、刪除數據
public class MainActivity extends AppCompatActivity {
...
//刪除數據的點擊事件
deleteData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//刪除Book表中價格大于 15 的書籍
DataSupport.deleteAll(Book.class,"price > ?","15");
}
});
}
}
運行程序,點擊刪除按鈕,查看Book表中的數據:對比上一次的查詢結果,價格大于15的書籍已經被刪除。
8、查詢數據
public class MainActivity extends AppCompatActivity {
...
//查詢數據的點擊事件
queryData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//查詢Book表的所有數據,返回List列表
List<Book> books = DataSupport.findAll(Book.class);
for(Book book : books){
Log.d("MainActivity", "book name is " + book.getName());
Log.d("MainActivity", "book author is " + book.getAuthor());
Log.d("MainActivity", "book pages is " + book.getPages());
Log.d("MainActivity", "book prices is " + book.getPrice());
Log.d("MainActivity", "book press is " + book.getPress());
}
}
});
}
}
運行程序,點擊查詢按鈕,查看Logcat輸出:Book firstBook = DataSupport.findFirst(Book.class);
Book lastBook = DataSupport.findLast(Book.class);
List<Book> books = DataSupport.select("name","author").find(Book.class);
List<Book> books = DataSupport.where("pages > ?","400").find(Book.class);
List<Book> books = DataSupport.order("price desc").find(Book.class);
List<Book> books = DataSupport.limit(3).find(Book.class);
List<Book> books = DataSupport.limit(3).offset(1).find(Book.class);
List<Book> books = DataSupport.select("name","author","pages")
.where("pages > ?","400")
.order("pages")
.limit(10)
.offset(10)
.find(Book.class);
這段代碼的含義是:查詢10~20行中滿足頁數大于400這個條件的name、author和pages這三列數據,并將查詢結果按頁數的升序排列。Cursor cursor = DataSupport.findBtSQL("select * from Book where pages > ? and price < ?","400","200");
9、異步操作
DataSupport.findAllAsync(Book.class).listen(new FindMultiCallback() {
@Override
public <T> void onFinish(List<T> t) {
List<Book> books = (List<Book>) t;
}
});
如果使用findAllAsync()而不是findAll(),需要添加一個listen()方法,一旦操作完成,查詢結果將在onFinish()方法中被回調。book.setName("The Da Vinci Code");
book.setAuthor("Dan Brown");
book.setPages(454);
book.setPrice(16.96);
book.setPress("Unknown");
book.saveAsync().listen(new saveCallback(){
@Override
public void onFinish(boolean success) {
...
}
});
如果使用saveAsync()而不是save()方法,將會在后臺向數據庫中添加數據,保存結果將在onFinish()方法中被回調。10、多個數據庫
LitePalDB litePalDB = new LitePalDB("Person", 1);
litePalDB.addClassName(Name.class.getName());
litePalDB.addClassName(Age.class.getName());
litePalDB.addClassName(Sex.class.getName());
LitePal.use(litePalDB); //創建數據庫
如果想新建一個數據庫,但是這個數據庫的配置和litepal.xml一樣,可以使用以下代碼:LitePalDB litePalDB = LitePalDB.fromDefault("BookStore");
LitePal.use(litePalDB); //使用litepal.xml創建一個新數據庫
也可以隨時返回默認的數據庫:LitePal.useDefault(); //返回默認數據庫
也可以通過指定數據庫的名字來刪除它:LitePal.deleteDatabase("BookStore"); //刪除數據庫
智能推薦
數據庫-SQLite-python使用方法
1.數據庫使用概述 1、數據庫(Database,DB)是可以長期儲存在計算機內、有組織的、可共享的數據集合 。 2、數據庫管理系統(Database Management System,DBMS)是對數據庫進行統一管理和共享數據操作的軟件,其主要功能包括了建立、使用、維護數據庫。 根據存儲數據結構和是否采用分布式技術特征 可以分為關系型數據庫和非關系型數據庫。 2.關系型數據庫 2.1 sqli...
LitePal數據庫的使用
今天來一波LitePal數據庫的使用操作 LitePal數據庫的githup地址: https://github.com/LitePalFramework/LitePal 直接開始步驟了 1、添加依賴 2、在assets創建litepal.xml文件管理數據庫 如圖 為了方便,貼個代碼粘貼 3、初始化數據庫 4、以上就基本完成了配置操作,切記一定要用應用程序的上下文初始化...
Android學習(24)SQLite_數據庫的使用
Android學習(24)SQLite_數據庫的使用 SQLite數據庫介紹: 輕量級:SQLite是進程內的數據庫引擎,因此不存在數據庫的客戶端和服務器。使用SQLite一般只需要帶上它的一個動態庫,就可以享受它的全部功能。而且動態庫的尺寸也相當小。 獨立性:SQLite數據庫的核心引擎本身不依賴第三方軟件,使用它也不需要“安裝”,所以在使用的時候能夠省去不少麻煩 隔離性...
Android開發學習---SQLite 數據庫的使用
一.創建數據庫 1.創建MyDatabaseHelper 類繼承SQLiteOpenHelper幫助類,借助這個類就可以對數據庫進行創建和升級。 2.SQLiteOpenHelper 是一個抽象類,必須繼承才能使用。 3.SQLiteOpenHelper 中有兩個抽象方法,分別是onCreate()和 onUpgrade(),我們必須在自己的幫助類里面重寫這兩個方法,然后分別在這兩個方法中去實現創...
Github最火開源項目-LitePal數據庫使用
歡迎關注微信公眾號、長期為您推薦優秀博文、開源項目、視頻 微信公眾號名稱:Android干貨程序員 PS:如果覺得文章太長,你也可觀看該課程的視頻,親,里面還有高清,無碼的福利喔 開源項目總貼地址:https://github.com/open-android/Android 數據庫LitePal地址:https://github.com/open-android/LitePal 省市縣三級聯動地...
猜你喜歡
開源數據庫 LitePal 學習,強大好使的 CRUD
LitePal 簡介 LitePal 是一款開源的 Android 數據庫框架,它采用了對象關系映射(ORM)的模式,將我們平時使用的一些數據庫(比如 Sqlite)功能進行了封裝。 配置 第一步 和我們平時使用開源庫一樣,在項目的 build.gradle 文件下的 dependencies 閉包中添加依賴: 1 1 第二步 需要配置 litepal.xml 文件,在 app...
Android學習筆記(十三)——數據存儲(LitePal操作數據庫)
【第一部分】歷史文章: Android學習筆記(一)——創建第一個Android項目 Android學習筆記(二)android studio基本控件及布局(實現圖片查看器) Android學習筆記(三)android studio中CheckBox自定義樣式(更換復選框左側的勾選圖像) Android學習筆記(四)Android 中Activity頁面的跳轉及傳值 And...
android studio 3.2如何使用LitePal數據庫
android studio 3.2如何使用LitePal數據庫 LitePal簡介 LitePal是一款開源的Android數據庫框架,它采用了對象關系映射(ORM)的模式,并將我們平時開發最常用的一些數據庫功能進行了封裝,是的不用編寫一行SQL語句就可以完成各種建表和增刪改查的操作,我們現大開始進行示范 1.編輯app/build.gradle文件,在dependencies閉包中添加如下內容...
Android中數據庫開發之LitePal的基本用法(總結)
LitePal是一款開源的Android數據庫框架,采用對象關系映射(ORM)模式,將常用的數據庫功能進行封裝,可以不用寫一行SQL語句就可以完成創建表、增刪改查的操作。并且很輕量級,jar包不到100k,幾乎零配置。 使用步驟: 1、添加遠程依賴: 2、在app目錄下創建assets文件夾,并創建litepal.xml文件。 其中litepal.xml的內容為:(這個文件主要是用來配置數據庫以及...