SQLite案例1:利用SQLiteDatabase操作数据库与表

2023-12-28 17:08

本文主要是介绍SQLite案例1:利用SQLiteDatabase操作数据库与表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SQLite案例1:利用SQLiteDatabase操作数据库与表

一、运行效果

这里写图片描述

二、实现步骤
1、创建安卓应用SQLiteDatabaseDemo

这里写图片描述

2、准备背景图片background.jpg,拷贝到res下的mipmap目录里

这里写图片描述

3、主布局资源文件activity_main.xml

这里写图片描述

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    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"android:background="@mipmap/background"android:orientation="vertical"android:gravity="center"android:padding="10px"tools:context="net.lm.ied.sqlitedatabase.MainActivity"><Button
        android:id="@+id/btn_create_or_open_db"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doCreateOrOpenDB"android:text="@string/create_or_open_db"/><Button
        android:id="@+id/btn_create_tale"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doCreateTable"android:text="@string/create_table"/><Button
        android:id="@+id/btn_add_record"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doAddRecord"android:text="@string/add_record"/><Button
        android:id="@+id/btn_update_record"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doUpdateRecord"android:text="@string/update_record" /><Button
        android:id="@+id/btn_display_all_records"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doDisplayAllRecords"android:text="@string/display_all_records" /><Button
        android:id="@+id/btn_delete_all_records"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doDeleteAllRecords"android:text="@string/delete_all_records" /><Button
        android:id="@+id/btn_delete_table"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doDeleteTable"android:text="@string/delete_table" /><Button
        android:id="@+id/btn_delete_db"android:layout_width="200dp"android:layout_height="wrap_content"android:onClick="doDeleteDB"android:text="@string/delete_db" /></LinearLayout>

4、字符串资源文件strings.xml
这里写图片描述

<resources><string name="app_name">SQLiteDatabase用法示例</string><string name="create_or_open_db">创建或打开数据库</string><string name="create_table">创建表</string><string name="add_record">添加表记录</string><string name="update_record">更新表记录</string><string name="display_all_records">显示全部表记录</string><string name="delete_all_records">删除全部表记录</string><string name="delete_table">删除表</string><string name="delete_db">删除数据库</string><string name="action_settings">设置</string>
</resources>

5、主界面类MainActivity

这里写图片描述

1)定义常量和变量
import android.app.Activity;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;public class MainActivity extends Activity {/***数据库名*/private final String DB_NAME = "student.db";/*** 表名*/private final String TABLE_NAME = "student";/*** 文件访问模式 私有模式*/private final int MODE = Context.MODE_PRIVATE;/*** SQLite数据库*/private SQLiteDatabase db;/*** 学号*/private int id;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//利用资源布局文件设置用户界面setContentView(R.layout.activity_main);}
}

(2)创建或打开数据库按钮单击事件处理代码

/*** 创建或打开数据库** @param view*/
public void doCreateOrOpenDB(View view) {// 判断是否有数据库if (databaseList().length == 0) {// 创建数据库db = openOrCreateDatabase(DB_NAME, MODE, null);// 提示用户创建数据库成功Toast.makeText(this, "恭喜,数据库【" + DB_NAME + "】创建成功!", Toast.LENGTH_SHORT).show();} else {// 打开数据库db = openOrCreateDatabase(DB_NAME, MODE, null);// 提示用户打开数据库成功Toast.makeText(this, "恭喜,数据库【" + DB_NAME + "】打开成功!", Toast.LENGTH_SHORT).show();}
}

运行程序,结果如下:

这里写图片描述

第一次单击【创建或打开数据库】按钮:

这里写图片描述

第二次单击【创建或打开数据库】按钮:

这里写图片描述

(3)创建判断表是否存在的方法isTableExisted(String tableName)

这里写图片描述

/*** 判断表是否存在** @param tableName* @return*/
private boolean isTableExisted(String tableName) {// 定义SQL字符串String strSQL = "SELECT * FROM sqlite_master WHERE type = ? AND name = ?";// 执行SQL查询,返回游标Cursor cursor = db.rawQuery(strSQL, new String[] {"table", tableName});// 判断游标里是否有记录return cursor.getCount() > 0;
}

(4)创建表按钮单击事件处理代码

/*** 创建表** @param view*/
public void doCreateTable(View view) {// 判断数据库对象是否为空if (db == null) {// 判断数据库是否存在if (databaseList().length == 0) {Toast.makeText(this, "请创建数据库【" + DB_NAME + "】。", Toast.LENGTH_SHORT).show();} else {Toast.makeText(this, "请打开数据库【" + DB_NAME + "】。", Toast.LENGTH_SHORT).show();}} else {// 判断表是否存在if (isTableExisted(TABLE_NAME)) {// 弹出吐司提示用户表已存在Toast.makeText(this, "表【" + TABLE_NAME + "】已经存在!", Toast.LENGTH_LONG).show();} else {try {// 定义SQL字符串String strSQL = "CREATE TABLE " + TABLE_NAME + "(id integer, name text, gender text)";// 执行SQL语句db.execSQL(strSQL);// 提示用户创建表成功Toast.makeText(this, "创建表成功!", Toast.LENGTH_LONG).show();} catch (SQLException e) {// 提示用户创建表失败Toast.makeText(this, "创建表失败!", Toast.LENGTH_LONG).show();}}}
}

运行程序,结果如下:

这里写图片描述

不单击【创建或打开数据库】按钮,直接单击【创建表】按钮:

这里写图片描述

单击【创建或打开数据库】按钮之后,再单击【创建表】按钮:

这里写图片描述

此时,再单击【创建表】按钮:

这里写图片描述

github项目代码:(https://github.com/Liumce/SQLiteDatabase.git)


这篇关于SQLite案例1:利用SQLiteDatabase操作数据库与表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/546643

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边