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

相关文章

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Springboot3 ResponseEntity 完全使用案例

《Springboot3ResponseEntity完全使用案例》ResponseEntity是SpringBoot中控制HTTP响应的核心工具——它能让你精准定义响应状态码、响应头、响应体,相比... 目录Spring Boot 3 ResponseEntity 完全使用教程前置准备1. 项目基础依赖(M

MySQL MHA集群详解(数据库高可用)

《MySQLMHA集群详解(数据库高可用)》MHA(MasterHighAvailability)是开源MySQL高可用管理工具,用于自动故障检测与转移,支持异步或半同步复制的MySQL主从架构,本... 目录mysql 高可用方案:MHA 详解与实战1. MHA 简介2. MHA 的组件组成(1)MHA

C++11中的包装器实战案例

《C++11中的包装器实战案例》本文给大家介绍C++11中的包装器实战案例,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录引言1.std::function1.1.什么是std::function1.2.核心用法1.2.1.包装普通函数1.2.

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

Redis 命令详解与实战案例

《Redis命令详解与实战案例》本文详细介绍了Redis的基础知识、核心数据结构与命令、高级功能与命令、最佳实践与性能优化,以及实战应用场景,通过实战案例,展示了如何使用Redis构建高性能应用系统... 目录Redis 命令详解与实战案例一、Redis 基础介绍二、Redis 核心数据结构与命令1. 字符

使用Python在PDF中绘制多种图形的操作示例

《使用Python在PDF中绘制多种图形的操作示例》在进行PDF自动化处理时,人们往往首先想到的是文本生成、图片嵌入或表格绘制等常规需求,然而在许多实际业务场景中,能够在PDF中灵活绘制图形同样至关重... 目录1. 环境准备2. 创建 PDF 文档与页面3. 在 PDF 中绘制不同类型的图形python