SQLite数据库在Android中的使用

目录

一,SQLite简介

二,SQLIte在Android中的使用

1,打开或者创建数据库

2,创建表

3,插入数据

4,删除数据

5,修改数据

 6,查询数据

三,SQLiteOpenHelper类

四,SQLite中事务的处理


一,SQLite简介

        SQLite是一个无服务器的零配置的事务性的SQL数据库引擎。无服务器,意味着使用sqlite不需要联网;不需要配置,意味着不需要安装和管理;同时sqlite遵循ACID原则。SQLIte是一款轻型的数据库,占用资源非常低,在嵌入式设备中,可能只需几百k的内存。

二,SQLIte在Android中的使用

        Android中使用SQLiteDatabase代表数据库,并提供了一系列方法来操作数据库。对于常用的增删改查操作,既可以使用execSQL()方法直接执行sql语句,也可以使用Android提供的方法,由于execSQL()方法返回void,无法判断是否执行成功,所以除创建表之外的操作通常使用Android提供的一系列方法。

1,打开或者创建数据库

        使用openOrCreateDatabase()打开或者创建一个数据库,如果数据库存在则打开数据库,反之则创建一个数据库。创建成功则返回SQLiteDatabase对象,否则抛出异常。使用时需提供创建路径和一个游标工厂;

private void initDatabase() {String filePath = getFilesDir().getAbsolutePath() + "wordDB.db";DB = SQLiteDatabase.openOrCreateDatabase(filePath, null);Log.i("DB", "数据库初始化成功!");
}

2,创建表

表的创建可以通过SQLiteDatabase的exexSQL()方法直接执行sql语句来创建;

private void inittable() {String table = "create table tb_word(" +"id integer primary key autoincrement," +"word varchar(20) not null," +"translation varchar(20) not null);";DB.execSQL(table);
}

3,插入数据

  1. table:所要执行的表名;
  2. nullColumnHack:在此处指定一个列名,当数据为空时,会向该列插入一个null。一般设为null;
  3. values:要插入的内容;
private void insert() {//所要插入的数据ContentValues contentValues = new ContentValues();contentValues.put("word", word);contentValues.put("translation", translation);//执行插入long id = wordDB.insert("tb_word", null, contentValues);if(id > 0){Toast.makeText(this, "录入成功!", Toast.LENGTH_SHORT).show();}
}

4,删除数据

  1.  table:表名;

  2. whereClause:修改条件,也就是sql语句中where后的内容,可以使用占位符,如"id=?";

  3. whereArgs:修改条件参数,当whereClause使用占位符时,在此处填入条件参数,形式为字符串数组;

private void delete() {//删除条件String whereClause = "word = ?";//删除条件参数String[] whereArgs = {String.valueOf(words.getWord())};//执行删除int row = wordDB.delete("tb_word", whereClause, whereArgs);if(row > 0){Log.i("delete", "删除成功");}else {Log.i("delete", "删除失败");}
}

5,修改数据

  1. table:表名;
  2. values:修改的内容;
  3. whereClause:修改的条件,与delete的一致;
  4. whereArgs:修改条件参数; 
private void update(){//修改的内容ContentValues values = new ContentValues();values.put("translation", translation);//修改条件String whereClause = "word=?";//修改条件参数String[] whereArgs = {word};//执行修改int row = wordDB.update("tb_word", values, whereClause, whereArgs);if(row > 0){Log.i("update", "更新成功");}else {Log.i("update", "更新失败");}
}

 6,查询数据

        在Android中查询数据是通过Cursor类来实现的,当我们使用SQLiteDatabase.query()方法时,会得到一个Cursor对象,Cursor指向的就是每一条数据。

  1. table:表名;
  2. columns:列名称数组,指定从哪些列寻找;
  3. selection:查询的条件,相当于where后的内容;
  4. selectionArgs:查询条件的参数;
  5. groupBy:分组列;
  6. having:分组条件;
  7. orderBy:排序列;
  8. limit:分页查询限制;

Cursor游标类常用方法:

private void searchWord() {//查询条件String selection = "word=?";//查询条件参数String[] selectionArgs = { String.valueOf(word) };//执行查询,获取游标类Cursor cursor = wordDB.query("tb_word", null, selection, selectionArgs , null, null, null);StringBuffer result = new StringBuffer();while(cursor.moveToNext()){int idOfWord = cursor.getColumnIndex("word");String word1 = cursor.getString(idOfWord);int idOfTranslation = cursor.getColumnIndex("translation");String translation = cursor.getString(idOfTranslation);result.append(word1 + ": " + translation + "\n");}tv_words.setText(result.toString());
}

三,SQLiteOpenHelper类

        Android提供SQLiteOpenHelper类来管理数据库。主要负责数据库的创建版本更新,一般情况通过创建它的子类并扩展onCreate()onUpgrade()方法来实现。 

SQLiteOpenHelper类常用方法:

  1. abstract void onCreate():第一次创建数据库时回调;
  2. abstract void onUpgrade():数据库版本更新时回调;
  3. SQLiteDatabase  getWritableDatabase():获得可读/写的数据库;
  4. SQLiteDatabase  getReadableDatabase():获得可读的数据库;
  5. void close():关闭所有打开的SQLiteDatabase;

 (1)创建SQLiteOpenHelper的子类,并重写方法:

public class MySqliteHelper extends SQLiteOpenHelper {public MySqliteHelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {super(context, name, factory, version);}@Overridepublic void onCreate(SQLiteDatabase db) {String table = "create table tb_word(" +"id integer primary key autoincrement," +"word varchar(20) not null," +"translation varchar(20) not null);";db.execSQL(table);}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
}

(2)通过子类来创建数据库:

private void initDatabaseHelper() {mySqliteHelper = new MySqliteHelper(this,"wordDB.db",null,1);SQLiteHelperUtil.wordDB = mySqliteHelper.getWritableDatabase();Log.i("wordDB", "数据库初始化成功!");
}

四,SQLite中事务的处理

SQLite采用如下方法来处理事务:

  1. beginTransaction():开启事务;
  2. setTransactionSuccessful():标记事务成功;
  3. endTransaction():提交事务,当事务执行失败时,可调用此方法回滚事务;
db.beginTransaction();
try {// 执行事务中的sql语句db.setTransactionSuccessful();
} finally {db.endTransaction();}
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习008-02-01-05 Configure a One-to-Many Relationship(配置一对多关系)

Configure a One-to-Many Relationship(配置一对多关系) This lesson explains how to create a One-to-Many relationship between two entities and how XAF generates the UI for such a relationship. 本课介绍如何在两个实体之间创建一对多关系以及…

nginx高可用实例

什么是nginx高可用 为什么需要高可用 正常情况下使用nginx,浏览器访问网址到nginx服务器,nginx再发送到目标服务器,获取资源返回。 但是会有一个问题:当nginx进程发生宕机,此时目标服务器存在,但是浏览器访…

Vue入门之v-for、computed、生命周期和模板引用

天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。…

Linux系统下U-Boot基本操作——UBoot基础知识

个人名片: 🎓作者简介:嵌入式领域优质创作者🌐个人主页:妄北y 📞个人QQ:2061314755 💌个人邮箱:[mailto:2061314755qq.com] 📱个人微信:Vir2025WB…

React基础学习-Day08

React基础学习-Day08 React生命周期(旧)(新)(函数组件) (旧) 在 React 16 版本之前,React 使用了一套不同的生命周期方法。这些生命周期方法在 React 16 中仍然可以使用…

django报错(二):NotSupportedError:MySQL 8 or later is required (found 5.7.43)

执行python manage.py runserver命令时报版本不支持错误,显示“MySQL 8 or later is required (found 5.7.43)”。如图: 即要MySQL 8或更高版本。但是企业大所数用的还是mysql5.7相关版本。因为5.7之后的8.x版本是付费版本,贸然更新数据库肯定…

RK3562 NPU开发环境搭建

如何在Ubuntu系统(PC)上搭建RK3562 Buildroot Linux的NPU开发环境?即电脑端运行Ubuntu系统,而RK3562板卡运行Buildroot Linux系统的情况下,搭建RK3562 NPU开发环境。 下面是相应的步骤(对应的命令&#xf…

DICOM CT\MR片子免费在线查看工具;python pydicom包加载查看;mayavi 3d查看

DICOM CT\MR片子免费在线查看工具 参考: https://zhuanlan.zhihu.com/p/668804209 dicom格式: DICOM(Digital Imaging and Communications in Medicine)是医学数字成像和通信的标准。它定义了医学图像(如CT、MRI、X…

蓝桥 双周赛算法赛【小白场】

博客主页:誓则盟约系列专栏:IT竞赛 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ 蓝桥第14场小白入门赛T1/T2/T3 题目: T1照常还是送分题无需多…

ChatTTS超强的真人AI语音助手下载使用教程

简介 ChatTTS是专门为对话场景设计的文本转语音模型,支持多人同时对话,适用的场景非常丰富,比如LLM助手对话任务,视频配音、声音克隆等。同时支持英文和中文两种语言。最大的模型使用了10万小时以上的中英文数据进行训练&#xf…

AI 基于病理图像分析揭示了一种不同类型的子宫内膜癌| 文献速递-基于人工智能(AI base)的医学影像研究与疾病诊断

Title 题目 AI-based histopathology image analysisreveals a distinct subset of endometrialcancers AI 基于病理图像分析揭示了一种不同类型的子宫内膜癌。 01 文献速递介绍 子宫内膜癌(EC)有四种分子亚型,具有很强的预后价值和治疗…

如何安装Visual Studio Code

Visual Studio Code(简称 VS Code) Visual Studio Code 是一款由微软开发的免费、开源的现代化轻量级代码编辑器。 主要特点包括: 跨平台:支持 Windows、Mac 和 Linux 等主流操作系统,方便开发者在不同平台上保持一…

二叉树 初阶 总结

树的基础认知 结点的度:一个结点含有的子树的个数称为该结点的度; 如上图:A的为6 叶结点或终端结点:度为0的结点称为叶结点; 如上图:B、C、H、I...等结点为叶结点 非终端结点或分支结点:度不为0…

采用T网络反馈电路的运算放大器(运放)反相放大器

运算放大器(运放)反相放大器电路 设计目标 输入电压ViMin输入电压ViMax输出电压VoMin输出电压VoMaxBW fp电源电压Vcc电源电压Vee-2.5mV2.5mV–2.5V2.5V5kHz5V–5V 设计说明1 该设计将输入信号 Vin 反相并应用 1000V/V 或 60dB 的信号增益。具有 T 反馈网络的反相放大器可用…

【鸿蒙学习笔记】位置设置・position・绝对定位・子组件相对父组件

官方文档:位置设置 目录标题 position・绝对定位・子组件相对父组件Row Text position position・绝对定位・子组件相对父组件 正→ ↓ Row Text position Entry Component struct Loc_position {State message: string Hello World;build() {Column() {Co…

【Neural signal processing and analysis zero to hero】- 1

The basics of neural signal processing course from youtube: 传送地址 Possible preprocessing steps Signal artifacts (not) to worry about doing visual based artifact rejection so that means that before you start analyzing, you can identify those data epic…

Elasticsearch:如何选择向量数据库?

作者:来自 Elastic Elastic Platform Team 向量数据库领域是一个快速发展的领域,它正在改变我们管理和搜索数据的方式。与传统数据库不同,向量数据库以向量的形式存储和管理数据。这种独特的方法可以实现更精确、更相关的搜索,并允…

【HarmonyOS】关于鸿蒙消息推送的心得体会 (一)

【HarmonyOS】关于鸿蒙消息推送的心得体会(一) 前言 这几天调研了鸿蒙消息推送的实现方式,形成了开发设计方案,颇有体会,与各位分享。 虽然没做之前觉得很简单的小功能,貌似只需要和华为服务器通信&…

Unity XR Interaction Toolkit的安装(二)

提示:文章有错误的地方,还望诸位大神不吝指教! 文章目录 前言一、安装1.打开unity项目2.打开包管理器(PackageManage)3.导入Input System依赖包4.Interaction Layers unity设置总结 前言 安装前请注意:需要…

科技论文在线--适合练习期刊写作和快速发表科技成果论文投稿网站

中国科技论文在线这个平台可以作为练手的一个渠道,至少可以锻炼一下中文写作,或者写一些科研方向的简单综述性文章。当然,如果你的老师期末要求也是交一份科技论文在线的刊载证明的话,这篇文章可以给你提供一些经验。 中国科技论…