热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

数据库SQLite以及FMDB的使用

SQLite函数总结1.打开数据库intsqlite3_open(constchar*filename, 数据库的文件路径sqlite3**ppDb     数据库实例);2.执行

SQLite函数总结

1.打开数据库

int sqlite3_open(

const char *filename,  // 数据库的文件路径

sqlite3 **ppDb          // 数据库实例

);

2.执行任何SQL语句

int sqlite3_exec(

sqlite3*,                                  // 一个打开的数据库实例

const char *sql,                          // 需要执行的SQL语句

int (*callback)(void*,int,char**,char**),  // SQL语句执行完毕后的回调

void *,                                    // 回调函数的第1个参数

char **errmsg                              // 错误信息

);

3.检查SQL语句的合法性(查询前的准备)

int sqlite3_prepare_v2(

sqlite3 *db,            // 数据库实例

const char *zSql,      // 需要检查的SQL语句

int nByte,              // SQL语句的最大字节长度

sqlite3_stmt **ppStmt,  // sqlite3_stmt实例,用来获得数据库数据

const char **pzTail

);

4.查询一行数据

int sqlite3_step(sqlite3_stmt*); // 如果查询到一行数据,就会返回SQLITE_ROW

5.利用stmt获得某一字段的值(字段的下标从0开始)

double sqlite3_column_double(sqlite3_stmt*, int iCol);  // 浮点数据

int sqlite3_column_int(sqlite3_stmt*, int iCol); // 整型数据

sqlite3_int64 sqlite3_column_int64(sqlite3_stmt*, int iCol); // 长整型数据

const void *sqlite3_column_blob(sqlite3_stmt*, int iCol); // 二进制文本数据

const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol);  // 字符串数据

SQLite最全的常用语句

/*简单约束*/

CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER);

CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, age INTEGER NOT NULL);

CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT UNIQUE, age INTEGER);

CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER DEFAULT 1);

/*分页*/

SELECT * FROM t_student ORDER BY id ASC LIMIT 30, 10;

/*排序*/

SELECT * FROM t_student WHERE score > 50 ORDER BY age DESC;

SELECT * FROM t_student WHERE score <50 ORDER BY age ASC , score DESC;

/*计量*/

SELECT COUNT(*) FROM t_student WHERE age > 50;

/*别名*/

SELECT name as myName, age as myAge, score as myScore FROM t_student;

SELECT name myName, age myAge, score myScore FROM t_student;

SELECT s.name myName, s.age myAge, s.score myScore FROM t_student s WHERE s.age > 50;

/*查询*/

SELECT name, age, score FROM t_student;

SELECT * FROM t_student;

/*修改指定数据*/

UPDATE t_student SET name = &#8216;MM&#8217; WHERE age = 10;

UPDATE t_student SET name = &#8216;WW&#8217; WHERE age is 7;

UPDATE t_student SET name = &#8216;XXOO&#8217; WHERE age <20;

UPDATE t_student SET name = &#8216;NNMM&#8217; WHERE age <50 and score > 10;

/*删除数据*/

DELETE FROM t_student;

/*更新数据*/

UPDATE t_student SET name = &#8216;LNJ&#8217;;

/*插入数据*/

INSERT INTO t_student(age, score, name) VALUES (&#8217;28&#8217;, 100, &#8216;jonathan&#8217;);

INSERT INTO t_student(name, age) VALUES (&#8216;lee&#8217;, &#8217;28&#8217;);

INSERT INTO t_student(score) VALUES (100);

/*插入数据*/

INSERT INTO t_student(name, age, score) VALUES (&#8216;lee&#8217;, &#8217;28&#8217;, 100);

/*添加主键*/

CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, score REAL);

CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY, name TEXT, age INTEGER, score REAL);

CREATE TABLE IF NOT EXISTS t_student (id INTEGER, name TEXT, age INTEGER, score REAL, PRIMARY KEY(id));

/*删除表*/

DROP TABLE t_student;

DROP TABLE IF EXISTS t_student;

/*创建表*/

CREATE TABLE t_student(id INTEGER , name TEXT, age , score REAL);

CREATE TABLE IF NOT EXISTS t_student(id INTEGER , name TEXT, age , score REAL);

FMDB

什么是FMDB

FMDB是iOS平台的SQLite数据库框架

FMDB以OC的方式封装了SQLite的C语言API

FMDB的优点

使用起来更加面向对象,省去了很多麻烦、冗余的C语言代码

对比苹果自带的CoreData框架,更加轻量级和灵活

提供了多线程安全的数据库操作方法,有效地防止数据混乱

FMDB的github地址

https://github.com/ccgus/fmdb

FMDB有三个主要的类

FMDatabase

一个FMDatabase对象就代表一个单独的SQLite数据库

用来执行SQL语句

pFMResultSet

使用FMDatabase执行查询后的结果集

FMDatabaseQueue

用于在多线程中执行多个查询或更新,它是线程安全的

通过指定SQLite数据库文件路径来创建FMDatabase对象

FMDatabase *db = [FMDatabase databaseWithPath:path];

if (![db open]) {

NSLog(@&#8221;数据库打开失败!&#8221;);

}

文件路径有三种情况

具体文件路径

如果不存在会自动创建

空字符串@&#8221;&#8221;

会在临时目录创建一个空的数据库

当FMDatabase连接关闭时,数据库文件也被删除

nil会创建一个内存中临时数据库,当FMDatabase连接关闭时,数据库会被销毁

执行更新

在FMDB中,除查询以外的所有操作,都称为“更新”

create、drop、insert、update、delete等

使用executeUpdate:方法执行更新

&#8211; (BOOL)executeUpdate:(NSString*)sql, &#8230;

&#8211; (BOOL)executeUpdateWithFormat:(NSString*)format,

&#8230;

&#8211; (BOOL)executeUpdate:(NSString*)sqlwithArgumentsInArray:(NSArray*)arguments

示例

[db executeUpdate:@&#8221;UPDATE

t_student

SET age = ? WHERE name = ?;&#8221;, @20, @&#8221;Jack&#8221;]

执行查询

查询方法

&#8211; (FMResultSet*)executeQuery:(NSString*)sql, &#8230;

&#8211; (FMResultSet*)executeQueryWithFormat:(NSString*)format,

&#8230;

&#8211; (FMResultSet*)executeQuery:(NSString*)sqlwithArgumentsInArray:(NSArray*)arguments

示例

// 查询数据

FMResultSet *rs = [db executeQuery:@&#8221;SELECT

* FROM t_student&#8221;];

// 遍历结果集

while ([rs next]) {

NSString*name = [rsstringForColumn:@&#8221;name&#8221;];

intage

= [rsintForColumn:@&#8221;age&#8221;];

doublescore = [rsdoubleForColumn:@&#8221;score&#8221;];

}

FMDatabase这个类是线程不安全的,如果在多个线程中同时使用一个FMDatabase实例,会造成数据混乱等问题

为了保证线程安全,FMDB提供方便快捷的FMDatabaseQueue类

FMDatabaseQueue的创建

FMDatabaseQueue

*queue = [FMDatabaseQueue databaseQueueWithPath:path];

使用事务

[queue inTransaction:^(FMDatabase *db, BOOL

*rollback) {

[dbexecuteUpdate:@&#8221;INSERT

INTOt_student(name)

VALUES (?)&#8221;,@&#8221;Jack&#8221;];

[dbexecuteUpdate:@&#8221;INSERT

INTOt_student(name)

VALUES (?)&#8221;,@&#8221;Rose&#8221;];

[dbexecuteUpdate:@&#8221;INSERT

INTOt_student(name)

VALUES (?)&#8221;,@&#8221;Jim&#8221;];

FMResultSet*rs= [dbexecuteQuery:@&#8221;select

* fromt_student&#8221;];

while([rsnext]) {

// …

}

}];

事务回滚

*rollback = YES;


推荐阅读
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 初探PLC 的ST 语言转换成C++ 的方法
    自动控制软件绕不开ST(StructureText)语言。它是IEC61131-3标准中唯一的一个高级语言。目前,大多数PLC产品支持ST ... [详细]
  • MySQL 数据库基础学习 一、SQL的作用及分类 二、数据类型 三、存储引擎  (建库建表、数据插入等))
    MySQL 数据库基础学习 一、SQL的作用及分类 二、数据类型 三、存储引擎 (建库建表、数据插入等)) ... [详细]
  • MySQL千万级数据的大表优化解决方案【mysql特性】
    mysql数据库中的表数据量几千万后,查询速度会很慢,日常各种卡慢,严重影响使用体验。在考虑升级数据库或者换用大数据解决方案前,必须优化现有mysql数据库 ... [详细]
  • mysql innodb myisam,mysql从MyISAM迁移到InnoDB引擎过程及优化
    由于开发需要使用InnoDB引擎的事务功能,需要将原有的MyISAM引擎更换为InnoDB,InnoDB行级锁也可以避免MyISAM的锁表, ... [详细]
  • qt学习(六)数据库注册用户的实现方法
    本文介绍了在qt学习中实现数据库注册用户的方法,包括登录按钮按下后出现注册页面、账号可用性判断、密码格式判断、邮箱格式判断等步骤。具体实现过程包括UI设计、数据库的创建和各个模块调用数据内容。 ... [详细]
  • 全面介绍Windows内存管理机制及C++内存分配实例(四):内存映射文件
    本文旨在全面介绍Windows内存管理机制及C++内存分配实例中的内存映射文件。通过对内存映射文件的使用场合和与虚拟内存的区别进行解析,帮助读者更好地理解操作系统的内存管理机制。同时,本文还提供了相关章节的链接,方便读者深入学习Windows内存管理及C++内存分配实例的其他内容。 ... [详细]
  • 本文介绍了GTK+中的GObject对象系统,该系统是基于GLib和C语言完成的面向对象的框架,提供了灵活、可扩展且易于映射到其他语言的特性。其中最重要的是GType,它是GLib运行时类型认证和管理系统的基础,通过注册和管理基本数据类型、用户定义对象和界面类型来实现对象的继承。文章详细解释了GObject系统中对象的三个部分:唯一的ID标识、类结构和实例结构。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 前端Angular的Post导出Excel,内容全部乱码(不是文件名),而Get方式导出没问题 ... [详细]
  • 点此学习更多SQL相关函数与字符串处理函数mysql函数一、简明总结ASCII(char)        返回字符的ASCII码值BIT_LENGTH(str)      返回字 ... [详细]
  • 分析OpenSurf(2)
    ①积分图像的实现首先在Integral.cpp里面找到Integral(),如下:IplImage*Integral(IplImage*source) ... [详细]
  • Tencent APIJSON自动化接口和文档 ORM 库开源啦
    APIJSON是一种专为API而生的JSON网络传输协议以及基于这套协议实现的ORM库。为简单的增删改查、复杂的查询、简单的事务操作提供了完全自动化的API。能大幅降低开发和沟通成 ... [详细]
author-avatar
手机用户2502914387
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有