通过项目实践,来熟悉利用开源库LitePal来操作SQLite数据库的基本使用方法。
dependencies {
compile 'org.litepal.android:core:1.6.1'
}
编辑完成后,点击页面上方的Sync now来同步。其中,1.6.1是版本号,最新版本号信息可以到LitePal项目主页去查看。
其中,dbname是数据库名,我们沿用上一篇 关于SQLiteDatabase操作SQLite数据所使用的案例,version是数据库的版本号,list标签指定映射模型。
...
当然,如果你使用了自己的Application,如下所示:
public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
LitePal.initialize(this);
}
...
}
在配置AndroidManifest.xml文件时,则需要按如下所示配置:
...
经过以上三步配置之后,就可以开始使用LitePal了。
(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
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(); //打开或创建数据库
}
});
}
}
运行程序,点击创建按钮:
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类添加到映射模型中,
更新数据库一定要记得将版本号加一。
...
...
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类中继承来的。作用就是添加刚刚保存好的数据。
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表中的数据。
//更新数据的点击事件
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 字段均有效。
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表中的数据:
public class MainActivity extends AppCompatActivity {
...
//查询数据的点击事件
queryData.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//查询Book表的所有数据,返回List列表
List 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 books = DataSupport.select("name","author").find(Book.class);
List books = DataSupport.where("pages > ?","400").find(Book.class);
List books = DataSupport.order("price desc").find(Book.class);
List books = DataSupport.limit(3).find(Book.class);
List books = DataSupport.limit(3).offset(1).find(Book.class);
List 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");
DataSupport.findAllAsync(Book.class).listen(new FindMultiCallback() {
@Override
public void onFinish(List t) {
List books = (List) 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()方法中被回调。
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"); //删除数据库