为什么使用第三方插件
使用第三方插件可以方便查看数据库里面的数据,可以更加快速的看出增删改查的操作。
第三方插件litepal
我们需要先在github上面搜索一下litepal,然后点开那篇文章,我们需要先导一下这两个数据包。
compile 'org.litepal.android:core:1.6.1'
debugImplementation 'com.amitshekhar.android:debug-db:1.0.3'
接着在project下面的main下面建一个assets的包,在里面存储一个litepal.xml的文件。
<?xml version="1.0" encoding="utf-8"?>
<litepal>
<dbname value="demo" />
<version value="1" />
<list>
<mapping class="myapplication.com.example.zhihui.Song"/>
<mapping class="myapplication.com.example.zhihui.Album"/>
</list>
</litepal>
记得在manifest里面加上一句话。
android:name="org.litepal.LitePalApplication"
然后创建两个类,分别是song和album。实现他们的方法。
public class Song extends DataSupport {
@Column(nullable = false)
private String name;
private int duration;
@Column(ignore = true)
private String uselessField;
private Album album;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getDuration() {
return duration;
}
public void setDuration(int duration) {
this.duration = duration;
}
public String getUselessField() {
return uselessField;
}
public void setUselessField(String uselessField) {
this.uselessField = uselessField;
}
public Album getAlbum() {
return album;
}
public void setAlbum(Album album) {
this.album = album;
}
}
Album:
public class Album extends DataSupport {
@Column(unique = true, defaultValue = "unknown")
private String name;
private float price;
private List<Song> songs = new ArrayList<Song>();
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public float getPrice() {
return price;
}
public void setPrice(float price) {
this.price = price;
}
public List<Song> getSongs() {
return songs;
}
public void setSongs(List<Song> songs) {
this.songs = songs;
}
}
最后在XML布局文件中写edittext控件和四个button按钮。添加id和监听事件。修改和增加数据,需要在后面保存至数据库。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="myapplication.com.example.zhihui.MainActivity">
<EditText
android:layout_width="match_parent"
android:layout_height="50dp"
android:id="@+id/album_et"
/>
<Button
android:id="@+id/add_album_btn"
android:layout_width="match_parent"
android:layout_height="50dp"
android:text="添加专辑"/>
<Button
android:id="@+id/add_motify_btn"
android:layout_width="match_parent"
android:layout_height="50dp"
android:text="修改专辑"/>
<Button
android:id="@+id/add_delete_btn"
android:layout_width="match_parent"
android:layout_height="50dp"
android:text="删除专辑"/>
<Button
android:id="@+id/add_query_btn"
android:layout_width="match_parent"
android:layout_height="50dp"
android:text="查询专辑"/>
</LinearLayout>
因为我用的是手机调试,所以可以打印一下日志。logcat下面就会出现那个网址( 数据库在线查看地址:Open http://192.168.43.173:8080 in your browser)。
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private EditText albumEt;
private Button addAlbumBtn;
private Button motifyBtn;
private Button deleteBtn;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.e("MAIN", "数据库在线查看地址:" + DebugDB.getAddressLog());
// SQLiteDatabase db= LitePal.getDatabase();
bindID();
}
private void bindID() {
albumEt = findViewById(R.id.album_et);
addAlbumBtn = findViewById(R.id.add_album_btn);
motifyBtn = findViewById(R.id.add_motify_btn);
deleteBtn = findViewById(R.id.add_delete_btn);
addAlbumBtn.setOnClickListener(this);
deleteBtn.setOnClickListener(this);
motifyBtn.setOnClickListener(this);
}
接着底下就是在switch语句里面进行增删改查的操作了。在查询里面需要用到一个foreach循环。
@Override
public void onClick(View view) {
switch (view.getId()) {
//添加数据
case R.id.add_album_btn:
String albumName = albumEt.getText().toString();
float price = 109.9f;
Album album = new Album();
album.setName(albumName);
album.setPrice(price);
album.save();//保存至数据库
break;
//修改数据
case R.id.add_motify_btn:
Album album1 = DataSupport.find(Album.class, 2);
album1.setName("Fantasy");
album1.save();//保存至数据库
break;
//删除数据
case R.id.add_delete_btn:
int row = DataSupport.deleteAll(Album.class, "id>?", "3");
Toast.makeText(this, "您删除了吗" + row + "行数据", Toast.LENGTH_SHORT).show();
break;
//查询数据
case R.id.add_query_btn:
List<Album> albumList = DataSupport.where("name like ?", "a%").order("name").find(Album.class);
for (Album a :
albumList
) {
Log.e("MAIN", a.getName() + "***********");
}
break;
}
}
详细见解在这个文章网址(https://github.com/LitePalFramework/LitePal)里面。