安卓——第三方插件LitePal

为什么使用第三方插件

使用第三方插件可以方便查看数据库里面的数据,可以更加快速的看出增删改查的操作。

第三方插件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)里面。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值