iOS SQLite3数据库操作

简介: iOS中数据持久化分为四种:属性列表、对象归档、SQLite3和Core Data,SQLite3数据库操作是一个必不或缺的技术。SQLite3简介SQLite3数据库是移动端(iOS、Android、嵌入式)上认定的关系型数据库,与MySQL、Oracle等数据库相比,具有轻量级的优势,这就造成了体积小、迅速、简单功能依旧强大等优势。

iOS中数据持久化分为四种:属性列表、对象归档、SQLite3和Core Data,SQLite3数据库操作是一个必不或缺的技术。

SQLite3简介

SQLite3数据库是移动端(iOS、Android、嵌入式)上认定的关系型数据库,与MySQL、Oracle等数据库相比,具有轻量级的优势,这就造成了体积小、迅速、简单功能依旧强大等优势。

SQLite3语句特点

  • 不区分大小写

  • 每一句以;结尾

SQLite字段类型

  • integer:整型

  • real:浮点值

  • text:文本字符串

  • blob:二进制类型

    注意:严格意义上说,SQLite字符类型是没有类型,即integer类型的也能存储其他类型的。但为了编程规范,建议严格遵守各个类型

SQLite3语句的种类

DDL语句(create、drop)

创表

create 表名(字段名1 字段类型,字段名2 字段类型,字段名3 字段类型,....);
create table t_Student(id integer name text,age integer,addr text);

拓展:

主键约束

为了方便准确记录数据便于区分每组数据,保证每组数据中有唯一区别的地方就需要添加一个主键约束用来标识记录的唯一性

create table t_Student(id integer primary key autoincrement name text,age integer,addr text);
autoincrement 自动增长

简单约束

  • not null :规定字段的值不能为null

  • unique:规定字段的值必须唯一

  • default:指定字段的默认值

删表

drop table 表名;
drop table t_Student;

DML语句(insert update delete)

insert into 表名(字段1,字段2,字段3,...)values(字段1的值,字段2的值,字段3的值,...);
insert into t_Student(name,age,addree)values('唐伯虎',788,'宋朝');
update 表名 set 字段1= 字段1的值 where 条件;
update t_Student set age = 1000 where name='唐伯虎';
delete from 表名 where 条件;
delete from t_Student where age < 100;

DQL语句(select)

select 字段1,字段2,...from表名;
select *from 表名;
select * from t_Student;
select name,age,addree from t_Student;
select name from t_Student where age<100;
select count(字段)from 表名;
select count(*)from t_Student;
select count(age)from t_Student;

其他边角知识点

  • 创建表时加 if not exists 是为了防止重复创建表,当表存在就不会创建表,若不存在就会创建,类似变量的懒加载

  • 条件句中where 字段可以用>、<、=、is、!=、is not、or、and、它们表达的意思跟上学时代的英语数学课堂意思一样,再这里不再赘述。

  • as可以给表起别名,利用点语法可以访问表内的字段

让我们创建一个信息系统吧

技术准备

sqlite3          *db, 数据库句柄,跟文件句柄FILE很类似

sqlite3_stmt      *stmt, 这个相当于ODBC的Command对象,用于保存编译好的SQL语句

sqlite3_open(),   打开数据库,没有数据库时创建。

sqlite3_exec(),   执行非查询的sql语句

sqlite3_bind_text(),设置占位符的内容

sqlite3_prepare_v2(),检测查询语句合法性

Sqlite3_step(), 在调用sqlite3_prepare后,使用这个函数在记录集中移动。

Sqlite3_close(), 关闭数据库文件

sqlite3_column_text(), 取text类型的数据。

sqlite3_column_blob(),取blob类型的数据

sqlite3_column_int(), 取int类型的数据
  1. 创建工程、添加sqlite3类库包
    这里写图片描述

  2. 在storyboard中添加几个控件
    这里写图片描述
  3. 3.
//在沙盒中创建数据库
    NSString *filename = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"student.sqlite"];
    int result =sqlite3_open(filename.UTF8String,&db);
    if (result==SQLITE_OK) {
        NSLog(@"成功创建数据库并打开");
     //创建一个张表
        const char *sql="create table if not exists t_Student(id integer primary key autoincrement,name text,age integer,addr text);";
        char *errorMesg=NULL;
        int result=sqlite3_exec(db,sql,NULL,NULL,&errorMesg);
        if (result==SQLITE_OK) {
            NSLog(@"成功创建表");
        }
        else
        {
            NSLog(@"创建表失败%s",errorMesg);
        }

        }
    else
    {
        NSLog(@"打开数据库失败");
    }
  1. 增加数据
 NSString *sql=[NSString stringWithFormat:@"insert into t_Student(name,age,addr)values(%@,%@,'%@');",_nameTF.text,_ageTF.text,_addreeTF.text];
    char *errorMesg=NULL;
    int result=sqlite3_exec(db,sql.UTF8String,NULL,NULL,&errorMesg);
    if (result==SQLITE_OK) {
        NSLog(@"添加成功");
    }
    else
    {
        NSLog(@"添加失败%s",errorMesg);
    }
  1. 查询数据
const char *sql = "select * from t_Student;";
    // 2.定义一个stmt存放结果集
    sqlite3_stmt *stmt = NULL;
    // 3.检测SQL语句的合法性
    int result = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
    if (result == SQLITE_OK) {
        NSLog(@"查询语句是合法的");
        sqlite3_bind_text(stmt,1,"student",-1,NULL);
        while (sqlite3_step(stmt)==SQLITE_ROW) {
            int sid=sqlite3_column_int(stmt,0);
            const unsigned char *sname=sqlite3_column_text(stmt,1);
            int sage=sqlite3_column_int(stmt,2);
            NSLog(@"%d,%s,%d",sid,sname,sage);
        }
    }
    else
    {
        NSLog(@"查询语句不合法");
    }

Demo地址为:点击进入下载

SQLite3可视化工具

  • Navicat Premium

Navicat Premium 内部集成了SQLite3可以很友好的进行数据的创建,增添、修改、删除等操作。
下面介绍一下 Navicat Premium的用法(由于CSDN上传附件不能超过60M需要Navicat Premium软件的可以在下面给我留言,私下发给你)
1. 打开Navicat Premium 软件
2. 点击左上角这里写图片描述选择SQLite选项 ,在对话框上填写数据库名字选择数据类型、数据库存放地址,如下图:
这里写图片描述
点击OK。
3.点击main下的Tables,右击选择New Table创建一个表文件
这里写图片描述
注意:

  1. id 设置为Key(唯一标示),并勾选了Auto increment自增长按钮

  2. age设置了默认值为20,如果不输入数字就初始化为默认值

4.点击这里写图片描述按钮后设置表的名字为t_Student
5.双击t_Student后点击 +号 添加几组数据
这里写图片描述
可以观察到我们不为id和age赋值的时候会有默认值
另外我们还可以用数据库语句创建表和添加数据以及查询数据
这里写图片描述

INSERT into t_Student(name,age,addree)VALUES('乔布斯',64,'苹果公司')

这里写图片描述

相关文章
|
2月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
385 15
|
3月前
|
存储 SQL 数据库
数据库知识:了解SQLite或其他移动端数据库的使用
【10月更文挑战第22天】本文介绍了SQLite在移动应用开发中的应用,包括其优势、如何在Android中集成SQLite、基本的数据库操作(增删改查)、并发访问和事务处理等。通过示例代码,帮助开发者更好地理解和使用SQLite。此外,还提到了其他移动端数据库的选择。
73 8
|
4月前
|
存储 缓存 关系型数据库
sqlite 数据库 介绍
sqlite 数据库 介绍
88 0
|
4月前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
73 4
|
4月前
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
102 3
|
4月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
5月前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
313 1
|
5月前
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
125 2
|
5月前
|
JSON NoSQL 数据库
和SQLite数据库对应的NoSQL数据库:TinyDB的详细使用(python3经典编程案例)
该文章详细介绍了TinyDB这一轻量级NoSQL数据库的使用方法,包括如何在Python3环境中安装、创建数据库、插入数据、查询、更新以及删除记录等操作,并提供了多个编程案例。
244 0
|
6月前
|
SQL 存储 小程序
【教程】navicat配合HTTP通道远程连接SQLite数据库
本文介绍了如何通过 Navicat Premium 工具配合 n_tunnel_sqlite.php 和 HTTP 通道远程连接服务器上的 SQLite 数据库。SQLite 是一种自给自足的、无服务器的 SQL 数据库引擎,由于其端口未对外开放,直接使用 Navicat 进行远程连接不可行。文章详细记录了使用 HTTP 通道实现远程连接的过程,包括定位本地 `ntunnel_sqlite.php` 文件,将其上传至服务器,并通过 Navicat 配置 HTTP 通道连接 SQLite 数据库的具体步骤。
299 0
【教程】navicat配合HTTP通道远程连接SQLite数据库

热门文章

最新文章

  • 1
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
    14
  • 2
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    28
  • 3
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    34
  • 4
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    29
  • 5
    【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
    23
  • 6
    uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
    143
  • 7
    【05】2025年1月首发完整版-篇幅较长-苹果app如何上架到app store完整流程·不借助第三方上架工具的情况下无需花钱但需仔细学习-优雅草央千澈详解关于APP签名以及分发-们最关心的一篇来了-IOS上架app
    235
  • 8
    app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
    90
  • 9
    深入探索iOS开发中的SwiftUI框架
    145
  • 10
    ios样式开关按钮jQuery插件
    60