iOS FMDB(数据库框架)

简介: FMDB1. 导包// 点击项目->General->Linked Frameworks and Libraries->搜索libsqlite3.tbd,并add.

FMDB

1. 导包

// 点击项目->General->Linked Frameworks and Libraries->搜索libsqlite3.tbd,并add.
#import "FMDB.h"
#import <sqlite3.h>
@interface ViewController ()
// 数据库对象
@property (nonatomic, strong) FMDatabase *fmDatabase;
@end

2. 打开数据库

    // 创建数据库路径
    NSString *path = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"data.sqlite"];
    // 创建数据库对象
    FMDatabase *db = [FMDatabase databaseWithPath:path];
    self.fmDatabase = db;
    // 打开数据库,true,打开成功;false,打开失败
    BOOL isSuccess = [db open];
    // 判断是否打开成功
    if (isSuccess) {
        NSLog(@"打开数据库成功");
        NSLog(@"数据库路径:%@", path);
    } else {
        NSLog(@"打开数据库失败");
    }

3. 创建表

    // 创建表,执行sql语句,增删改相同,查询不一样
    NSString *sql = @"create table if not exists test(id integer primary key autoincrement, name text, age integer);";
    // 执行创建表命令,true, 创建成功;false,创建失败
    BOOL isSuccess = [self.fmDatabase executeUpdate:sql];
    if (isSuccess) {
        NSLog(@"创建表成功");
    } else {
        NSLog(@"创建表失败");
    }

4. 插入数据

    // 向表中添加100条数据
    for (int i = 0; i < 100; i++) {
        // 名称设置
        NSString *name = [NSString stringWithFormat:@"item-%d", i];
        // 随机生成20--25岁之间的年龄
        NSInteger age = arc4random_uniform(5) + 20;
        // sql语句拼接
        NSString *sql = [NSString stringWithFormat:@"insert into test(name,age) values('%@',%zd);", name, age];
        // 执行插入语句
        BOOL isSuccess = [self.fmDatabase executeUpdate:sql];
        // 判断是否添加成功
        if (isSuccess) {
            NSLog(@"添加成功");
        } else {
            NSLog(@"添加失败");
        }
    }

5. 查询数据

    // 查询语句
    NSString *sql = @"select name,age from test where age = 23;";
    // 执行查询语句
    FMResultSet *result = [self.fmDatabase executeQuery:sql];
    // 遍历查询结果
    while ([result next]) {
        // name
        NSString *name = [result stringForColumnIndex:0];
        // age
        NSInteger age = [result intForColumnIndex:1];
        NSLog(@"name = %@, age = %ld.", name, age);
    }

6. 更新数据

    // 修改语句
    NSString *sql = @"update test set age = 30 where age < 22;";
    // 执行sql语句
    BOOL isSuccess = [self.fmDatabase executeUpdate:sql];
    if (isSuccess) {
        NSLog(@"修改数据成功");
    } else {
        NSLog(@"修改数据失败");
    }

7. 删除数据

    // 删除语句
    NSString *sql = @"delete from test where age > 25;";
    // 执行语句
    BOOL isSuccess = [self.fmDatabase executeUpdate:sql];
    if (isSuccess) {
        NSLog(@"删除成功");
    } else {
        NSLog(@"删除失败");
    }
目录
相关文章
|
2月前
|
搜索推荐 数据管理 定位技术
iOS应用开发中有多种主流框架
iOS应用开发中有多种主流框架
233 60
|
28天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
121 66
|
5月前
|
物联网 区块链 vr&ar
未来已来:探索区块链、物联网与虚拟现实技术的融合与应用安卓与iOS开发中的跨平台框架选择
【8月更文挑战第30天】在科技的巨轮下,新技术不断涌现,引领着社会进步。本文将聚焦于当前最前沿的技术——区块链、物联网和虚拟现实,探讨它们各自的发展趋势及其在未来可能的应用场景。我们将从这些技术的基本定义出发,逐步深入到它们的相互作用和集成应用,最后展望它们如何共同塑造一个全新的数字生态系统。
|
2月前
|
iOS开发 开发者
探索iOS开发中的SwiftUI框架
【10月更文挑战第39天】在苹果的生态系统中,SwiftUI框架以其声明式语法和易用性成为开发者的新宠。本文将深入SwiftUI的核心概念,通过实际案例展示如何利用这一框架快速构建用户界面,并探讨其对iOS应用开发流程的影响。
|
3月前
|
移动开发 网络协议 小程序
基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v9.1版已发布
RainbowChat是一套基于开源IM聊天框架 MobileIMSDK 的产品级移动端IM系统。RainbowChat源于真实运营的产品,解决了大量的屏幕适配、细节优化、机器兼容问题
74 5
|
2月前
|
开发框架 Dart Android开发
安卓与iOS的跨平台开发:Flutter框架深度解析
在移动应用开发的海洋中,Flutter作为一艘灵活的帆船,正引领着开发者们驶向跨平台开发的新纪元。本文将揭开Flutter神秘的面纱,从其架构到核心特性,再到实际应用案例,我们将一同探索这个由谷歌打造的开源UI工具包如何让安卓与iOS应用开发变得更加高效而统一。你将看到,借助Flutter,打造精美、高性能的应用不再是难题,而是变成了一场创造性的旅程。
|
3月前
|
Swift iOS开发 开发者
探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】在苹果生态系统中,SwiftUI的引入无疑为iOS应用开发带来了革命性的变化。本文将通过深入浅出的方式,带领读者了解SwiftUI的基本概念、核心优势以及如何在实际项目中运用这一框架。我们将从一个简单的例子开始,逐步深入到更复杂的应用场景,让初学者能够快速上手,同时也为有经验的开发者提供一些深度使用的技巧和策略。
63 1
|
4月前
|
iOS开发 开发者 UED
探索iOS应用开发中的SwiftUI框架
【9月更文挑战第26天】 在iOS开发的海洋中,SwiftUI犹如一艘现代的快艇,引领着开发者们驶向更加高效与直观的编程体验。本文将带你领略SwiftUI的魅力,从其设计理念到实际应用,我们将一步步揭开它如何简化界面构建过程的面纱。通过对比传统方式,你将看到SwiftUI如何让代码变得像诗一样优美,同时保持强大的功能性和灵活性。准备好让你的iOS开发技能加速升级,一起驾驭这股新潮流吧!
|
4月前
|
前端开发 iOS开发 开发者
探索iOS开发中的SwiftUI框架
【9月更文挑战第21天】在iOS应用开发的广阔天地中,SwiftUI框架如一股清新之风,为开发者带来了声明式语法的便捷与高效。本文将深入探讨SwiftUI的核心概念、布局方式及数据绑定机制,同时通过实例演示如何运用SwiftUI构建用户界面,旨在引领读者领略SwiftUI的魅力,并激发其对iOS开发新趋势的思考与实践。
51 6
|
5月前
|
搜索推荐 前端开发 算法
基于用户画像及协同过滤算法的音乐推荐系统,采用Django框架、bootstrap前端,MySQL数据库
本文介绍了一个基于用户画像和协同过滤算法的音乐推荐系统,使用Django框架、Bootstrap前端和MySQL数据库构建,旨在为用户提供个性化的音乐推荐服务,提高推荐准确性和用户满意度。
389 7
基于用户画像及协同过滤算法的音乐推荐系统,采用Django框架、bootstrap前端,MySQL数据库