iOS:第三方数据库文件FMDB的使用

简介:

第三方数据库FMDB

•FMDB的使用:在sqlite的基础上,将sqlite中的函数进行封装产生的一个数据库文件。
–FMDB的好处是对基本C库的封装,方便使用。同时还提供了多线程操作数据库带来的读脏数据等问题的方法。
–框架地址:https://github.com/ccgus/fmdb
–FMDB有三个主要的类

FMDatabase:对象就代表一个单独的SQLite数据库用来执行SQL语句

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

FMDatabaseQueue:用于在多线程中执行多个查询或更新,它是线程安全的
 
 
对数据库所有的操作只需下面的方法即可:
查询语句:- (FMResultSet *)executeQuery:(NSString*)sql, ...    

                    - (BOOL)next;

                    -{type}ForColumnIndex:(int)columnIdx

创建、插入、修改等等语句:- (BOOL)executeUpdate:(NSString*)sql, ...
 

执行SQL语句:

<1>使用:(需要FMDatabase *db成员变量)
     创建或打开:FMDataBase类

self.db = [FMDatabase databaseWithPath:fileName];  //创建数据库

[self.db open];//打开数据库

[self.db close]; //关闭数据库

//对数据库进行插入、修改的操作

[self.db executeUpdate:@“CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, name TEXT,age INTEGER)”]; 

[self.db executeUpdate:@"INSERT INTO t_student(name , age) VALUES(?, ?);", @"xuneng", @(10)];

[self.db executeUptate:@"update t_student set name = 'lisi' where age = @(10)"]; 

<2>查询:FMResultSet类(数据取出完全后,不需要再去关闭结果集,当新的结果集产生,或者其数据库关闭时,会自动关闭。)

        // 1.查询

        FMResultSet *set = [self.db  executeQuery:@"SELECT * FROM t_student;"];  //返回结果集

       // 2.取出数据

       while ([set next])

       {      

   // 取出姓名 

        NSString *name = [set stringForColumnIndex:1];

  // 取出年龄    

        int age = [set intForColumnIndex:2];

         NSString *name = [set stringForColumn:@"name"];

         int age = [set intForColumn:@"age"];

         NSLog(@"name = %@, age = %d", name, age);

}

创建数据库并进行增删改查的操作举例如下:

1、首先导入sqlite本地数据库和第三方数据库FMDB

     

 

     

 

2、在UIViewController类中对数据库表进行增删该查操作如下:

《1》数据库路径

    NSArray *dics = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);

    NSString *dbPath = [[dics lastObject] stringByAppendingPathComponent:@"user.db"];

 

《2》 创建数据库

    self.db = [FMDatabase databaseWithPath:dbPath];

 

《3》打开数据库

    if(![self.db open])

    {

           return; //打开数据库失败

    }

 

 《4》创建数据库表

    if(![self.db executeUpdate:@"create table if not exists user (ID integer primary key autoincrement,name text,password text)"])

    {

        return; //创建数据库表失败

    }

 

《5》插入数据

    if(![self.db executeUpdate:@"insert into user (name,password) values('admin','123456')"])

    {

        return; //插入数据失败

    }

 

《6》修改数据

    if(![self.db executeUpdate:@"update user set name = 'zhangsan' where ID = 2"])

    {

        return; //修改数据失败

    }

  

《7》获取结果集

    FMResultSet *resultSet = [self.db executeQuery:@"select * from user"];

 

《8》遍历结果集,取出数据

    while ([resultSet next])

    {

        int ID = [resultSet intForColumnIndex:0];

        NSString *name = [resultSet stringForColumnIndex:1];

        NSString *password = [resultSet stringForColumnIndex:2];

        NSLog(@"ID:%d,name:%@,password:%@",ID,name,password);

    }

 

《8》//关闭数据库

    [self.db close];

 

演示结果如下:

2015-09-21 21:44:38.640 第三方数据库FMDB[4207:296060] ID:1,name:admin,password:123456
2015-09-21 21:44:38.641 第三方数据库FMDB[4207:296060] ID:2,name:zhangsan,password:123456
2015-09-21 21:44:38.641 第三方数据库FMDB[4207:296060] ID:3,name:admin,password:123456
2015-09-21 21:44:38.641 第三方数据库FMDB[4207:296060] ID:4,name:admin,password:123456
2015-09-21 21:44:38.641 第三方数据库FMDB[4207:296060] ID:5,name:admin,password:123456

 

程序猿神奇的手,每时每刻,这双手都在改变着世界的交互方式!


本文转自当天真遇到现实博客园博客,原文链接:http://www.cnblogs.com/XYQ-208910/p/4827381.html,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
安全 数据安全/隐私保护 Android开发
【05】2025年1月首发完整版-篇幅较长-苹果app如何上架到app store完整流程·不借助第三方上架工具的情况下无需花钱但需仔细学习-优雅草央千澈详解关于APP签名以及分发-们最关心的一篇来了-IOS上架app
【05】2025年1月首发完整版-篇幅较长-苹果app如何上架到app store完整流程·不借助第三方上架工具的情况下无需花钱但需仔细学习-优雅草央千澈详解关于APP签名以及分发-们最关心的一篇来了-IOS上架app
420 75
|
1月前
|
存储 NoSQL MongoDB
数据库数据恢复—MongoDB数据库迁移过程中丢失文件的数据恢复案例
某单位一台MongoDB数据库由于业务需求进行了数据迁移,数据库迁移后提示:“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
5月前
|
SQL 关系型数据库 MySQL
数据库导入SQL文件:全面解析与操作指南
在数据库管理中,将SQL文件导入数据库是一个常见且重要的操作。无论是迁移数据、恢复备份,还是测试和开发环境搭建,掌握如何正确导入SQL文件都至关重要。本文将详细介绍数据库导入SQL文件的全过程,包括准备工作、操作步骤以及常见问题解决方案,旨在为数据库管理员和开发者提供全面的操作指南。一、准备工作在导
951 0
|
3月前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
3月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
4月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
5月前
|
SQL 关系型数据库 MySQL
|
6月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
5月前
|
存储 关系型数据库 MySQL
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
131 2
|
5月前
|
SQL 存储 关系型数据库
SQL文件导入MySQL数据库的详细指南
数据库中的数据转移是一项常规任务,无论是在数据迁移过程中,还是在数据备份、还原场景中,导入导出SQL文件显得尤为重要。特别是在使用MySQL数据库时,如何将SQL文件导入数据库是一项基本技能。本文将详细介绍如何将SQL文件导入MySQL数据库,并提供一个清晰、完整的步骤指南。这篇文章的内容字数大约在
674 1