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

相关文章

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

Python使用DrissionPage中ChromiumPage进行自动化网页操作

《Python使用DrissionPage中ChromiumPage进行自动化网页操作》DrissionPage作为一款轻量级且功能强大的浏览器自动化库,为开发者提供了丰富的功能支持,本文将使用Dri... 目录前言一、ChromiumPage基础操作1.初始化Drission 和 ChromiumPage

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件