通過項目實踐,來熟悉利用開源庫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"); //刪除數據庫