《第一行代码:Android》第三版7.4SQLite数据库存储

布局文件略过,就是五个按钮,点击按钮执行对应的功能。

Android 专门提供了一个SQLiteOpenHelper帮助类来对数据库进行创建和升级。

自己创建一个类继承自SQLiteOpenHelper,重新写onCreate()方法和onUpgrade()方法,分别对应创建数据库和升级数据库。

还有两个非常重要的方法:getReadableDatabase()和getWritableDatabase(),它们都可以创建或者打开一个现有的数据库。

insert()方法用于添加数据。

update()方法用于对数据进行更新。

delete()方法用来删除数据。

query()方法用来查询数据,返回的是一个Cursor对象。

主代码文件内容如下:

package com.example.databasetestimport android.annotation.SuppressLint
import android.content.ContentValues
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.util.Log
import android.widget.Buttonclass MainActivity : AppCompatActivity() {@SuppressLint("SuspiciousIndentation")override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)//下面的是数据库相关的代码//创建数据库val dbHelper=MyDatabaseHelper(this,"BookStore.db",1)val createDatabase: Button =findViewById(R.id.createDatabase)createDatabase.setOnClickListener{dbHelper.writableDatabase}//增加一条记录val addData:Button=findViewById(R.id.addData)addData.setOnClickListener{val db=dbHelper.writableDatabaseval values1=ContentValues().apply{//开始组装第一条数据put("name","The Da Vinci Code")put("author","Dan Brown")put("pages",454)put("price",16.96)}//插入第一条数据db.insert("Book",null,values1)//第二条数据val values2=ContentValues().apply{//开始组装第一条数据put("name","The Lost Symbol")put("author","Dan Brown")put("pages",510)put("price",19.95)}//插入第二条数据db.insert("Book",null,values2)}//更新一条记录,把书的价钱更改为10.99val updateData:Button=findViewById(R.id.updateData)updateData.setOnClickListener{val db=dbHelper.writableDatabaseval values=ContentValues()values.put("price",10.99)db.update("Book",values,"name= ?", arrayOf("The Da Vanci Code"))}//删除一条记录val deleteData:Button=findViewById(R.id.deleteData)deleteData.setOnClickListener{val db=dbHelper.writableDatabasedb.delete("Book","pages > ?",arrayOf("500"))}//查询数据,也是最复杂的一种,需要更多的精力来学习val queryData:Button=findViewById(R.id.queryData)queryData.setOnClickListener{val db=dbHelper.writableDatabase//查询表中所有的数据val cursor=db.query("Book",null,null,null,null,null,null)if(cursor.moveToFirst()){do{//遍历cursor对象,取出数据并打印val name=cursor.getString(cursor.getColumnIndex("name"))val author=cursor.getString(cursor.getColumnIndex("author"))val pages=cursor.getString(cursor.getColumnIndex("pages"))val price=cursor.getString(cursor.getColumnIndex("price"))Log.d("MainActivity","book name is $name")Log.d("MainActivity","book author is $author")Log.d("MainActivity","book pages is $pages")Log.d("MainActivity","book price is $price")}while(cursor.moveToNext())            }}}
}

直接用下面这种方法,可以直接操作数据库,感觉这种比较简单,但是容易出错。

db.execSQL("insert into Book (name, author, pages, price) values(?, ?, ?, ?)",arrayOf("The Da Vinci Code", "Dan Brown", "454", "16.96")
)
db.execSQL("insert into Book (name, author, pages, price) values(?, ?, ?, ?)",arrayOf("The Lost Symbol", "Dan Brown", "510", "19.95")
)//更新
db.execSQL("update Book set price = ? where name = ?", arrayOf("10.99", "The Da Vinci Code"))
//删除
db.execSQL("delete from Book where pages > ?", arrayOf("500"))
//查询
val cursor = db.rawQuery("select * from Book", null)

 实际情况会比例子复杂多了,很多内容都需要深入研究的,本文只是能起到入门的作用。

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

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

相关文章

扔掉xshell,基于 QT 实现一个串口命令行工具(带源码)

背景 xshell 带有支持串口的命令行能力, 可以方便的和下位机用命令进行交互,如下图所示: msh > msh > msh >version\ | / - RT - Thread Operating System/ | \ 3.1.3 build Nov 7 20232006 - 2019 Copyright by rt-thre…

this.$emit(‘update:isVisible‘, false)作用

这个写是不是很新颖&#xff0c;传父组件传值&#xff01;这是什么鬼。。。 假设你有以下逻辑业务。在A页面弹出一个组件B&#xff0c;A组件里面使用B组件&#xff0c;是否展示B组件你使用的是baselineShow变量控制&#xff01; <BaselineData :isVisible.sync"basel…

如何在Word中简洁地插入代码

如何在Word中简洁地插入代码 背景&#xff1a; ​ 最近在一写一些论文或者报告的时候&#xff0c;需要将源代码放在论文的最后&#xff0c;有一个很头疼的问题&#xff0c;如果直接把代码从编辑器复制到word中&#xff0c;就变成了下面这个样子&#xff1a; 这有点丑陋啊&…

Qt简介、C++工程文件分离、创建Qt工程、Qt的帮助文档

QT 简介 core&#xff1a;核心模块&#xff0c;非图形的接口类&#xff0c;为其它模块提供支持 gui&#xff1a;图形用户接口&#xff0c;qt5之前 widgets&#xff1a;图形界面相关的类模块 qt5之后的 database&#xff1a;数据库模块 network&#xff1a;网络模块 QT 特性 开…

Linux系统的各项命令

文章目录 Linux系统的目录结构Linux路径的描述方式Linux命令入门**什么是命令、命令行**Linux命令基础格式 ls命令入门HOME目录和工作目录ls命令的参数和选项ls命令的 -a选项ls命令的 -l选项ls命令选项的组合使用ls选项和参数的组合使用ls命令的 -h选项 目录切换相关命令&#…

多线程案例-阻塞队列

阻塞队列是什么 阻塞队列是一种特殊的队列.也遵循"先进先出"的原则 阻塞队列能是一种线程安全的数据结构,并且具有以下特性: 当队列满的时候,继续入队列就会阻塞,直到有其他线程从队列中取走元素. 当队列空的时候,继续出队列也会阻塞,直到有其他线程往队列中插入元素…

这七款网工在线画拓扑工具,绝了!

你们好&#xff0c;我的网工朋友。 画拓扑图&#xff0c;绝对是网络工程师的基操。 上次给你来了篇手把手教你绘制拓扑图的好文&#xff0c;还没看过的先去看啊&#xff1a;《网络拓扑图怎么画最好&#xff1f;》。 关于画拓扑的工具&#xff0c;那就多了&#xff0c;直接用…

数据结构与算法-D8D9队列实现及应用

队列&#xff1a;限制在两端进行插入和删除的线性表 允许进行存入操作的一端为“队尾” 允许进行删除操作的一端为“队头” 顺序队列 注意&#xff1a;front指向队头元素的位置 rear指向队尾元素的下一个位置 实现循环队列&#xff1a;(rear1)%N取余&#xff0c;为了区分空…

Connection refused: no further information

解决目录 一、报错信息二、解决方法 一、报错信息 二、解决方法 1、报错原因是开启了代理&#xff0c;像AS是绝对不能开代理的。 2、设置为No proxy&#xff0c;然后Apply再选择OK&#xff0c;重新同步。 要远离消耗你的人和事&#xff0c;不要花费任何情绪或者精力在他们身…

unity Pc获取本机Mac地址

1.此方法只能获取众多Mac中的一个 private static string GetMacAddress(){string physicalAddress "";NetworkInterface[] nice NetworkInterface.GetAllNetworkInterfaces();foreach (NetworkInterface adaper in nice){Debug.Log(adaper.Description);if (adape…

Linux网络——高级IO

目录 一.五种IO模型 1.阻塞式IO 2.非阻塞式IO 3.信号驱动IO 4.多路转接IO&#xff1a; 5.异步IO 二.同步通信 vs 异步通信 三.设置非阻塞IO 1.阻塞 vs 非阻塞 2.非阻塞IO 3.实现函数SetNoBlock 四.I/O多路转接之select 1.初识select 2.select函数原型 3.socket就绪…

UEFI下Windows10和Ubuntu22.04双系统安装图解

目录 简介制作U盘启动盘并从U盘启动电脑安装系统安装Windows系统安装Ubuntu 附录双系统时间不一致 简介 传统 Legacy BIOS主板下的操作系统安装可参考本人博客 U盘系统盘制作与系统安装&#xff08;详细图解&#xff09; &#xff0c;本文介绍UEFI主板下的双系统安装&#xff…

手把手教你在GPU T4卡上安装硬解环境+编译硬解的ffmpeg

系列文章目录 文章目录 系列文章目录前言一、NVDIA环境软件安装二、FFMPEG编译过程总结前言 通常开发流媒体服务,经常需要ffmpeg支持硬解解码功能,即常见的GPU解码,如cuda解码等。下面主要讲解在全新的环境中怎么安装nvidia的环境与编译ffmpeg的过程。 运行环境Centos7.5 G…

解决 Element-ui中 表格(Table)使用 v-if 条件切换后,表格的列的筛选不显示了

解决方法 在每个需要使用 v-if 或 v-else 的 el-table-column 上增加 key 作为唯一标识&#xff0c;这样渲染的时候就不会因为复用原则导致列数据混乱了。关于key值&#xff0c;一般习惯使用字段名&#xff0c;也可随机生成一个值&#xff0c;只要具有唯一性就可以。

如何快速上手不熟悉的库

首先需要一个编辑器vscode或者pycharm 然后&#xff0c;不要傻乎乎的自己急着去看代码。 先看有没有文档和使用手册&#xff0c;一般都有一个quick_start.md文件或者其他的.md文件。 然后&#xff0c;还是不急着看代码&#xff0c;先看代码的注释。 比如我现在要从这里找到…

Java王者荣耀火柴人

主要功能 键盘W,A,S,D键&#xff1a;控制玩家上下左右移动。按钮一&#xff1a;控制英雄发射一个矩形攻击红方小兵。按钮控制英雄发射魅惑技能&#xff0c;伤害小兵并让小兵停止移动。技能三&#xff1a;攻击多个敌人并让小兵停止移动。普攻&#xff1a;对小兵造成基础伤害。小…

LVGL——按钮部件

目录 一、组成部分 二、按钮部件操作 1、创建 2、设置样式 3、添加事件 4、代码例程 三、按钮部件案例 一、组成部分 主体&#xff08;LV_PART_MAIN&#xff09; 二、按钮部件操作 1、创建 lv_obj_t *btn lv_btn_create( parent );2、设置样式 lv_obj_set_siz…

nginx配置自动压缩-gzip压缩

1.nginx配置文件 server里添加gzip配置信息。 重启nginx服务 对比效果&#xff1a;上图是没有开启gzip自动压缩&#xff0c;总共资源是1.3M&#xff0c;传输1.3MB&#xff0c;下图是开启gzip压缩&#xff0c;总共资源是1.3M&#xff0c;传输了973KB。

Axure简单安装与入门

目录 一.Axure简介 二.应用场景 三.安装与汉化 3.1.安装 3.2.汉化 四. 入门 4.1.复制、剪切及粘贴区域 4.2.选择模式 4.3. 插入形状 4.4.预览、共享 感谢大家观看&#xff01;希望能帮到你哦&#xff01;&#xff01;&#xff01; 一.Axure简介 Axure RP是一款专业的原型…