安卓实战开发之SQLite从简单使用crud

2024-09-03 02:18

本文主要是介绍安卓实战开发之SQLite从简单使用crud,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

最近项目忙,然后呢很久没有更新博客了,react-native也是没有时间学习,然后项目里面用到了数据持久化(数据存储),Android系统中主要提供了三种数据持久化方式:文件存储、SharedPreference存储、数据库存储。说实在的毕竟app这种轻量级的使用数据库还是不多,然后呢要使用数据库也是在特定场合,这也导致了很多的移动端开发(对数据库操作不多)对数据库使用不太熟练。

应用场景

一般我们都不使用数据库的,基本上使用SharedPreference就能处理大部分问题,然后在特定场合比如做商城类资讯类及三级缓存图片地址时候就可能需要使用数据库,真到用的时候就要google和baidu了,对于数据简单并且不需要频繁操作数据的我们就参考下别人demo好了,然后数据存储量大比如新闻、缓存的离线天气、商品列表等我们就不得不去考虑性能了,然后开发就要考虑时间和性能你可能会使用greenDao、LitePal、realm。

效果如下:

这里写图片描述

简单使用SQLite用例

1.创建SQLite数据库:
public MyDatabaseHelper(Context context, String name, CursorFactory factory, int version) {super(context, name, factory, version);}public void onCreate(SQLiteDatabase db) {db.execSQL(CREATE_BOOK);}public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
2.升级SQLite数据库
 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {db.execSQL("drop table if exists ***");db.execSQL("drop table if exists ***");onCreate(db);}
3.在活动中创建SQLiteOpenHelper实现类的实例,调用其getWritableDatabase()方法;
MyDatabaseHelper dbHelper = new MyDatabaseHelper(this, "**.db", null, 1);
dbHelper.getWritableDatabase();
4.CRUD操作

CRUD我们可以通过像java使用hibernate样既可以执行原生的sql语句(db.execSQL(**))也可以执行自带的封装语句ad.insert。

  • insert()
    添加(Create):先将数据添加至ContentValues对象,然后调用insert()方法。
ContentValues values = new ContentValues();values.put("key1", value1);values.put("key2", value2);values.put("key3", value3);db.insert("table", null, values);values.clear();
  • query()
    查询(Retrieve):query()方法用于对数据进行查询,但即使是其最短的重载方法也有7个参数,其定义为:
Cursor query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy)
  • update()
    更新(Update):update()方法用于对数据进行更新,接收4个参数:
public int update (String table, ContentValues values, String whereClause, String[] whereArgs)
  • delete()
    删除(Delete):delete()方法用于删除数据,接收3个参数:
public int delete (String table, String whereClause, String[] whereArgs)

Sqlite项目简单使用详解

创建数据库:

package com.losileeya.dbsimple.db;import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;public class MyHelper extends SQLiteOpenHelper {private static String DB_NAME = "mydata.db";  //数据库名称public static String TABLE_NAME = "employee"; //表名/**super(参数1,参数2,参数3,参数4),其中参数4是代表数据库的版本,* 是一个大于等于1的整数,如果要修改(添加字段)表中的字段,则设置* 一个比当前的 参数4大的整数 ,把更新的语句写在onUpgrade(),下一次* 调用*/public MyHelper(Context context) {super(context, DB_NAME, null, 2);}@Overridepublic void onCreate(SQLiteDatabase db) {//Create tableString sql = "CREATE TABLE "+TABLE_NAME + "("+ "_id INTEGER PRIMARY KEY,"+ "name TEXT," + "sex TEXT);";Log.e("table oncreate", "create table");db.execSQL(sql);        //创建表}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {// TODO Auto-generated method stubLog.e("update", "update");
//      db.execSQL("ALTER TABLE "+ MyHelper.TABLE_NAME+" ADD sex TEXT"); //修改字段String sql = "DROP TABLE IF EXISTS " + TABLE_NAME;db.execSQL(sql);this.onCreate(db);}}

实际数据操作,进行crud

package com.losileeya.dbsimple.db;import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;import com.losileeya.dbsimple.bean.Person;import java.util.ArrayList;
import java.util.List;public class DatabaseUtil {private MyHelper helper;private SQLiteDatabase db;public DatabaseUtil(Context context) {super();helper = new MyHelper(context);db = helper.getWritableDatabase();}/*** 插入数据* * param String* */public boolean Insert(Person person) {// String sql = "insert into " + MyHelper.TABLE_NAME// + "(name,sex) values (" + "'" + person.getName() + "' ," + "'"// + person.getSex() + "'" + ")";//// try {// db.execSQL(sql);// return true;// } catch (SQLException e) {// Log.e("err", "insert failed");// return false;// } finally {// db.close();// }ContentValues values = new ContentValues();values.put("name", person.getName());values.put("sex", person.getSex());try {db.insert("employee", null, values);return true;} catch (SQLException e) {Log.e("err", "insert failed");return false;}}/*** 更新数据* * param Person*            person , int id* */public void Update(Person person, int id) {ContentValues values = new ContentValues();values.put("name", person.getName());values.put("sex", person.getSex());int rows = db.update(MyHelper.TABLE_NAME, values, "_id=?",new String[] { id + "" });}/*** 删除数据* * param int id* */public void Delete(int id) {int raw = db.delete(MyHelper.TABLE_NAME, "_id=?", new String[] { id+ "" });}/*** 查询所有数据* * */public List<Person> queryAll() {List<Person> list = new ArrayList<Person>();Cursor cursor = db.query(MyHelper.TABLE_NAME, null, null, null, null,null, null);while (cursor.moveToNext()) {Person person = new Person();person.setId(cursor.getInt(cursor.getColumnIndex("_id")));person.setName(cursor.getString(cursor.getColumnIndex("name")));person.setSex(cursor.getString(cursor.getColumnIndex("sex")));list.add(person);}return list;}/*** 按姓名进行查找并排序* * */public List<Person> queryByname(String name) {List<Person> list = new ArrayList<Person>();Cursor cursor = db.query(MyHelper.TABLE_NAME, new String[] { "_id","name", "sex" }, "name like ? ", new String[] { "%" + name+ "%" }, null, null, "name asc");while (cursor.moveToNext()) {Person person = new Person();person.setId(cursor.getInt(cursor.getColumnIndex("_id")));person.setName(cursor.getString(cursor.getColumnIndex("name")));person.setSex(cursor.getString(cursor.getColumnIndex("sex")));list.add(person);}return list;}/*** 按id查询* * */public Person queryByid(int id) {Person person = new Person();Cursor cursor = db.query(MyHelper.TABLE_NAME, new String[] { "name","sex" }, "_id=?", new String[] { id + "" }, null, null, null);while (cursor.moveToNext()) {person.setId(id);person.setName(cursor.getString(cursor.getColumnIndex("name")));person.setSex(cursor.getString(cursor.getColumnIndex("sex")));}return person;}public void close() {if (db != null) {db.close();}}
}

然后使用数据库千万记得要加权限:

  <!-- 添加SD卡读写权限 --><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/><uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>

注意:我们使用数据库的时候很容易因为手动关闭数据库,然后再次操作时出现错误,所以呢我们应该在数据库操作帮助类添加关闭方法,然后在activity销毁时候调用 。

当然如果你项目中可能使用到把数据库导出为excel表格的功能:

package com.losileeya.dbsimple.tools;
import android.os.Environment;
import com.losileeya.dbsimple.bean.Person;
import java.io.File;
import java.util.List;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
public class JxlUtil {/*** 导出生成excel文件,存放于SD卡中* @author smart **/private List<Person> list;public JxlUtil(List<Person> list){this.list = list;}public boolean toExcel() {// 准备设置excel工作表的标题String[] title = { "编号", "姓名", "性别" };try {// 获得开始时间long start = System.currentTimeMillis();//判断SD卡是否存在if(!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){return false;}String SDdir =  Environment.getExternalStorageDirectory().toString();  //获取SD卡的根目录// 创建Excel工作薄WritableWorkbook wwb;// 在SD卡中,新建立一个名为person的jxl文件wwb = Workbook.createWorkbook(new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/person.xls"));// 添加第一个工作表并设置第一个Sheet的名字WritableSheet sheet = wwb.createSheet("员工清单", 0);Label label;for (int i = 0; i < title.length; i++) {label = new Label(i, 0, title[i]);// 将定义好的单元格添加到工作表中sheet.addCell(label);}/** 保存数字到单元格,需要使用jxl.write.Number 必须使用其完整路径,否则会出现错误*/for(int i = 0 ; i < list.size(); i++){Person person = list.get(i);//添加编号jxl.write.Number number = new jxl.write.Number(0, i+1, person.getId());sheet.addCell(number);//添加姓名label = new Label(1,i+1,person.getName());sheet.addCell(label);//添加性别label = new Label(2,i+1,person.getSex());sheet.addCell(label);}wwb.write(); //写入数据wwb.close(); //关闭文件} catch (Exception e) {e.printStackTrace();}return true;}
}

实现这样一个功能你需要准备一个jxl.jar,过多的解释不多说。

可能大多数的情况下我们的数据一般from网络,下一篇我们就来对数据库进行封装提高一下数据库的使用效率。

demo 传送门:DbMaster

这篇关于安卓实战开发之SQLite从简单使用crud的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1131738

相关文章

Golang interface{}的具体使用

《Golanginterface{}的具体使用》interface{}是Go中可以表示任意类型的空接口,本文主要介绍了Golanginterface{}的具体使用,具有一定的参考价值,感兴趣的可以了... 目录一、什么是 interface{}?定义形China编程式:二、interface{} 有什么特别的?✅

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

PyTorch中cdist和sum函数使用示例详解

《PyTorch中cdist和sum函数使用示例详解》torch.cdist是PyTorch中用于计算**两个张量之间的成对距离(pairwisedistance)**的函数,常用于点云处理、图神经网... 目录基本语法输出示例1. 简单的 2D 欧几里得距离2. 批量形式(3D Tensor)3. 使用不

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案

《使用@Cacheable注解Redis时Redis宕机或其他原因连不上继续调用原方法的解决方案》在SpringBoot应用中,我们经常使用​​@Cacheable​​注解来缓存数据,以提高应用的性能... 目录@Cacheable注解Redis时,Redis宕机或其他原因连不上,继续调用原方法的解决方案1

java中XML的使用全过程

《java中XML的使用全过程》:本文主要介绍java中XML的使用全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录什么是XML特点XML作用XML的编写语法基本语法特殊字符编写约束XML的书写格式DTD文档schema文档解析XML的方法​​DOM解析XM

使用Java实现Navicat密码的加密与解密的代码解析

《使用Java实现Navicat密码的加密与解密的代码解析》:本文主要介绍使用Java实现Navicat密码的加密与解密,通过本文,我们了解了如何利用Java语言实现对Navicat保存的数据库密... 目录一、背景介绍二、环境准备三、代码解析四、核心代码展示五、总结在日常开发过程中,我们有时需要处理各种软