安卓学习笔记6.2——SQLite数据库

目录

零、学习目标

一、SQLite数据库概述

1、SQLite构成

2、SQLite数据类型

3、SQLite数据库特点

二、使用SQLiteDatabase类操作数据库

(一)实现步骤

1、创建安卓应用【CreateDeleteDB】

2、将背景图片拷贝到drawable目录 

 3、字符串资源文件strings.xml

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

 5、主界面类 - MainActivity

 6、启动应用,查看效果


零、学习目标

  • 学会利用sqlite3来创建以及操作数据库
  • 能利用SQLiteDatabase操作数据库与表
  • 能利用SQLiteOpenHelper操作数据库与表


一、SQLite数据库概述

  • SQLite是D. Richard Hipp用C语言编写的开源嵌入式数据库引擎。它支持大多数的SQL92标准,并且可以在所有主要的操作系统上运行。

1、SQLite构成

  • SQLite由SQL编译器、内核、后端以及附件几个部分构成。SQLite通过利用虚拟机和虚拟数据库引擎(VDBE),使得调试、修改和扩展SQLite的内核变得更加方便,所有SQL语句都被编译成易读的、可以在SQLite虚拟机中执行的程序集。SQLite的整体结构图如下:

2、SQLite数据类型

  • 概括来讲,SQLite支持NULL、INTEGER、REAL、TEXT和BLOB数据类型,分别代表空值、整型值、浮点值、字符串文本、二进制对象。

3、SQLite数据库特点

  • 值得一提的是,袖珍型的SQLite竟然可以支持高达2TB大小的数据库,每个数据库都是以单个文件的形式存在,这些数据都是以B-Tree的数据结构形式存储在磁盘上。
  • 在事务处理方面,SQLite通过数据库级上的独占性和共享锁来实现独立事务处理。这意味着多个进程可以在同一时间从同一数据库读取数据,但只有一个可以写入数据。在某个进程或线程想数据库执行写操作之前,必须获得独占锁。在获得独占锁之后,其他的读或写操作将不会再发生。
  • SQLite采用动态数据类型,当某个值插入到数据库时,SQLite将会检查它的类型,如果该类型与关联的列不匹配,SQLite则会尝试将该值转换成该列的类型,如果不能转换,则该值将作为本身的类型存储,SQLite称这为“弱类型”。但有一个特例,如果是INTEGER PRIMARY KEY,则其他类型不会被转换,会报一个“datatype missmatch”的错误。
  • ACID,指数据库事务正确执行的四个基本要素的缩写。包含:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。一个支持事务(Transaction)的,必需要具有这四种特性,否则在事务过程(Transaction processing)当中无法保证数据的正确性,交易过程极可能达不到交易方的要求。

二、使用SQLiteDatabase类操作数据库

(一)实现步骤

1、创建安卓应用【CreateDeleteDB】

2、将背景图片拷贝到drawable目录 

 3、字符串资源文件strings.xml

<resources>
    <string name="app_name">创建和删除数据库</string>
    <string name="create_db">创建数据库</string>
    <string name="delete_db">删除数据库</string>
</resources>

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

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/background"
    android:gravity="center"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/btnCreateDB"
        android:layout_width="200dp"
        android:layout_height="wrap_content"
        android:onClick="doCreateDB"
        android:text="@string/create_db"
        android:textSize="20dp" />

    <Button
        android:id="@+id/btnDeleteDB"
        android:layout_width="200dp"
        android:layout_height="wrap_content"
        android:onClick="doDeleteDB"
        android:text="@string/delete_db"
        android:textSize="20dp" />
</LinearLayout>

 5、主界面类 - MainActivity

 

  • 声明变量和常量 
  • 获取应用当前数据库个数 
  • 编写代码创建数据库 
  •  编写删除数据库代码

 6、启动应用,查看效果

6.2素材

猜你喜欢

转载自blog.csdn.net/justin02191004/article/details/128281907
今日推荐