安卓:LitePal操作数据库

news/2024/10/30 15:21:11/

目录

一、LitePal介绍

常用方法:

1、插入数据:

2、更新数据:

3、删除数据:

4、查询数据:

二、LitePal的基本用法: 

1、集成LitePal:

 2、创建LitePal配置文件:

3、创建模型类:

 4、增删改查操作:

三、使用例子 

 MainActivity:

activity_main:

litepal.xml: 

运行结果: 

四、异常修复

一、LitePal介绍

        LitePal是一个开源的Android数据库框架,它提供了简单易用的API来帮助开发者进行数据库操作。LitePal允许开发者使用面向对象的方式来操作数据库,而无需编写复杂的SQL语句。

常用方法:

1、插入数据:

  • save():将当前模型对象保存到数据库中。
  • saveAll(Collection models):将指定的模型对象集合保存到数据库中。2

2、更新数据:

  • update():更新当前模型对象在数据库中的数据。
  • updateAll(String... conditions):根据条件更新符合条件的数据。

3、删除数据:

  • delete():删除当前模型对象在数据库中的数据。
  • deleteAll(Class<?> modelClass, String... conditions):根据条件删除符合条件的数据。
  • deleteAll(Class<?> modelClass):删除指定模型类的所有数据。

4、查询数据:

  • find(Class<?> modelClass, long id):根据id查询指定模型类的数据。
  • findFirst(Class<?> modelClass):查询指定模型类的第一条数据。
  • findLast(Class<?> modelClass):查询指定模型类的最后一条数据。
  • findAll(Class<?> modelClass):查询指定模型类的所有数据。
  • where(String... conditions):设置查询条件。
  • order(String... columns):设置查询结果的排序方式。
  • limit(int limit):设置查询结果的数量限制。
  • offset(int offset):设置查询结果的偏移量。
  • average(Class<?> modelClass, String column):计算指定列的平均值。
  • sum(Class<?> modelClass, String column):计算指定列的总和。
  • max(Class<?> modelClass, String column):计算指定列的最大值。
  • min(Class<?> modelClass, String column):计算指定列的最小值。

二、LitePal的基本用法: 

1、集成LitePal:

        首先,在项目的build.gradle文件中添加LitePal的依赖:

dependencies {implementation 'org.litepal.guolindev:core:版本号'
}

 2、创建LitePal配置文件:

        在项目的assets目录下创建litepal.xml文件,并配置数据库名称、版本号等信息。

<?xml version="1.0" encoding="utf-8"?>
<litepal><dbname value="数据库名称" /><version value="数据库版本号" /><list><mapping class="com.example.litepaltest.Book"></mapping><!-- 可以继续添加其他映射配置 -->
</list>
</litepal>

        在AndroidManifest.xml中的代码中,添加android:name = "org.litepal.LitePalApplication"

3、创建模型类:

        创建与数据库表对应的模型类,并继承自LitePalSupport。

import org.litepal.crud.LitePalSupport;public class Book extends LitePalSupport {private int id;private String name;private String author;// 省略getter和setter方法
}

 4、增删改查操作:

  • 插入数据:
Book book = new Book();
book.setName("Android入门");
book.setAuthor("张三");
book.save(); // 将数据保存到数据库中
  • 更新数据:
Book book = new Book();
book.setName("Android进阶");
book.updateAll("name = ?", "Android入门"); // 将名称为"Android入门"的数据更新为"Android进阶"
  • 删除数据:
LitePal.delete(Book.class, id); // 根据id删除指定的数据
LitePal.deleteAll(Book.class, "name = ?", "Android入门"); // 根据条件删除数据
  • 查询数据:
List<Book> bookList = LitePal.findAll(Book.class); // 查询所有数据
Book book = LitePal.findFirst(Book.class); // 查询第一条数据
List<Book> bookList = LitePal.where("author = ?", "张三").find(Book.class); // 根据条件查询数据

三、使用例子 

 MainActivity:

package com.example.litepaldemo;import androidx.appcompat.app.AppCompatActivity;import android.os.Bundle;
import android.util.Log;
import android.view.View;import org.litepal.FluentQuery;
import org.litepal.LitePal;import java.util.List;public class MainActivity extends AppCompatActivity {
String TAG = "MainActivity" ;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void CreateDatabase(View view) {// 创建数据库LitePal.getDatabase();}public void addData(View view) {Book book = new Book();book.setId(1);book.setAuthor("柏拉图");book.setName("理想国");book.setPages(259);book.setPrice(9.9);book.save();Book book1 = new Book();book1.setId(2);book1.setAuthor("夸美纽斯");book1.setName("大教学论");book1.setPages(259);book1.setPrice(99.9);book1.save();}public void deleteData(View view) {
//        LitePal.delete(Book.class, 1); // 根据id删除指定的数据LitePal.deleteAll(Book.class, "name = ?", "Android进阶"); // 根据条件删除数据}public void queryData(View view) {List<Book> bookList = LitePal.findAll(Book.class); // 查询所有数据for (Book book : bookList) {Log.d(TAG, "书名: " + book.getName());Log.d(TAG, "作者: " + book.getAuthor());Log.d(TAG, "页数: " + book.getPages());Log.d(TAG, "价格: " + book.getPrice());}}public void modifiedData(View view) {Book book = new Book();book.setName("Android进阶");book.updateAll("name = ?", "大教学论");}
}

activity_main:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity"><Buttonandroid:id="@+id/create_database"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="创建数据库"android:onClick="CreateDatabase"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintHorizontal_bias="0.498"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:layout_constraintVertical_bias="0.13" /><Buttonandroid:id="@+id/add_data"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="增加数据"android:onClick="addData"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintHorizontal_bias="0.498"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:layout_constraintVertical_bias="0.278" /><Buttonandroid:id="@+id/del_data"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="删除数据"android:onClick="deleteData"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintHorizontal_bias="0.498"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:layout_constraintVertical_bias="0.395" /><Buttonandroid:id="@+id/query_data"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="查询数据"android:onClick="queryData"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintHorizontal_bias="0.498"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:layout_constraintVertical_bias="0.512" /><Buttonandroid:id="@+id/motified_data"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="修改数据"android:onClick="modifiedData"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintHorizontal_bias="0.498"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:layout_constraintVertical_bias="0.651" /></androidx.constraintlayout.widget.ConstraintLayout>

litepal.xml: 

<?xml version="1.0" encoding="utf-8"?>
<litepal><dbname value="BookStore" ></dbname><version value="1" ></version><list><mapping class="com.example.litepaldemo.Book"></mapping></list>
</litepal>

运行结果: 

 四、异常修复

使用LItePal:报错element ‘litepal‘ must be declared和Class referenced in the manifest, `org.litepal.LitePa_敬往事一杯酒哈的博客-CSDN博客


http://www.ppmy.cn/news/1026952.html

相关文章

NeMo中文/英文ASR模型微调训练实践

1.安装nemo pip install -U nemo_toolkit[all] ASR-metrics 2.下载ASR预训练模型到本地(建议使用huggleface,比nvidia官网快很多) 3.从本地创建ASR模型 asr_model = nemo_asr.models.EncDecCTCModel.restore_from("stt_zh_quartznet15x5.nemo") 3.定义train_m…

SpringBoot案例-部门管理-修改

目录 前言 查看页面原型&#xff0c;明确需求 页面原型 需求 阅读接口文件 思路分析 功能接口开发 控制层&#xff08;Controller类&#xff09; 业务层&#xff08;Service类&#xff09; 业务类 业务实现类 持久层&#xff08;Mapper类&#xff09; 接口测试 前…

编译redis-5.0.9报错zmalloc.h:50:31: 致命错误:jemalloc/jemalloc.h:没有那个文件或目录问题解决

上图 解决&#xff1a; make && make install MALLOClibc原因: 原因是jemalloc重载了Linux下的ANSI C的malloc和free函数。

【C++】内存管理与模板

目录 一、内存管理 1.new与delete基本用法 (1) 内置类型 (2) 自定义类型 2.new, delete与malloc, free对比 (1) 内置类型 (2) 自定义类型 (3)综合特点 3.new与delete的底层实现 4. 定位new表达式 二、模板 1.引入机制 2. 基本使用 (1) 函数模板 ①概念&#xff1a…

【C++学习】STL容器——stack和queue

目录 一、stack的介绍和使用 1.1 stack的介绍 1.2 stack的使用 1.3 stack的模拟实现 二、queue的介绍和使用 2.1 queue的介绍 2.2 queue的使用 2.3 queue的模拟实现 三、priority_queue的介绍和使用 3.1 priority_queue的介绍和使用 3.2 priority_queue的使用 3.4 p…

CentOS7连接网络

1.下载centos7镜像文件 2.安装centos7 3.修改网卡,ens33. 注意: 这里使用的是dhcp,设置IPADDR192.168.31.64一方面是为了后面使用crt或者MobaXterm连接,另一方面它和windows电脑的网卡要一致.这样才可以连接到网络.win r,输入cmd,打开命令窗口输入ipconfig.可以看到IPv4: 102…

在多页面应用和单页面应用中(例如vue)怎么提高seo搜索引擎优化

那么 我们要先知道 搜索引擎是怎么工作的&#xff1f; 搜索引擎是通过一系列步骤来工作的&#xff0c;以下是其基本原理&#xff1a; 1、网络爬虫&#xff1a;搜索引擎使用网络爬虫&#xff08;也称为蜘蛛、机器人&#xff09;来从互联网上抓取网页。网络爬虫按照预定义的规则…

wifi列表消失 后总结

故障现象&#xff1a; 管理源身份打开cmd &#xff0c;然后重启网络服务 Fn 加信号塔 开启二者为自动&#xff1a; 刷新网络&#xff1a; Fn 加信号塔 重启的时间可以放长一些 半个小时左右