• 数据库


     FMDB 是基于 SQLite 封装的 面向对对象(OC) 的API.

    • FMDB是iOS平台的SQLite数据库框架
    • FMDB以OC的方式封装了SQLite的C语言API

    FMDB 需要libsqlite3.0 系统库的支持

    /////////////////////////  实现代码   ////////////////////////////////////////////////

    #import "PPFMDBTool.h"

    #import "PPShop.h"

    #import "FMDB.h"

    @implementation PPFMDBTool

    SingletonM(fmdbTool)

    static FMDatabase *_db;

    + (void)initialize

    {

        // 1. 打开数据库

        _db = [FMDatabase databaseWithPath:[[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)  lastObject] stringByAppendingPathComponent:@"shop.sqilte"]];

        

        BOOL isSuc = [_db open];

        

        if (isSuc) {

            // 2. 创建表

            [_db executeUpdate:@"CREATE TABLE IF NOT EXISTS t_shop (id integer PRIMARY KEY, name text NOT NULL, price real);"];

        }else{

            LogGreen(@"打开数据库 -- 失败");

        }

    }

    + (void)insertShop:(PPShop *)shop

    {

        [_db executeUpdateWithFormat:@"INSERT INTO t_shop(name, price) VALUES (%@, %f);", shop.name, shop.price];

    }

    + (NSArray *)shops

    {

        // 查询 - 得到结果集

        FMResultSet *set = [_db executeQuery:@"SELECT * FROM t_shop;"];

        

        NSMutableArray *shops = [NSMutableArray array];

        // 不断往下取数据

        while ([set next]) {

            // 获得当前所指向的数据

            PPShop *shop = [[PPShop alloc] init];

            shop.name = [set stringForColumn:@"name"];

            shop.price = [set doubleForColumn:@"price"];

            [shops addObject:shop];

        }

        return shops;

    }

    + (void)deleteShop{

        // 删除 价格低于500 的记录

        [_db executeUpdate:@"DELETE FROM t_shop WHERE price < 5000;"];

    }

  • 相关阅读:
    16 类成员
    [Tips] WSL ubuntu 18.04 安装python3
    [Tips]ubuntu安装go
    [Notes] 随笔的标题格式说明
    [Tips]Ubuntu手动修改DNS
    [BUG]Ubuntu 16.04 出现“sudo unable to resolve host”
    [Tips]ubuntu 换源
    [Tips]将本地git文件夹上传云端
    [Notes] Dockerfile中COPY命令的简单性
    [BUG]Ubuntu server 16.04安装,无网卡驱动解决
  • 原文地址:https://www.cnblogs.com/guangleijia/p/4846617.html
Copyright © 2020-2023  润新知