zoukankan      html  css  js  c++  java
  • 数据库

     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;"];

    }

  • 相关阅读:
    js中location.href的用法
    entityframework单例模式泛型用法
    [C#]从URL中获取路径的最简单方法-new Uri(url).AbsolutePath
    等到花儿也谢了的await
    ASP.NET MVC下的异步Action的定义和执行原理
    实际案例:在现有代码中通过async/await实现并行
    ASP.NET MVC Controllers and Actions
    扩展HtmlHelper
    iOS开发网络篇—XML数据的解析
    IOS学习:常用第三方库(GDataXMLNode:xml解析库)
  • 原文地址:https://www.cnblogs.com/guangleijia/p/4846617.html
Copyright © 2011-2022 走看看