使用cocoaPods将FMDB下载到工程

第一步:引入框架,引入支持类库(libsqlite3.0.tbd)

#import <FMDB.h>

声明属性

@interface ViewController ()

/// 声明数据库对象
@property (nonatomic, strong) FMDatabase *dataBase;
/// 声明存储路径
@property (nonatomic, strong) NSString *filePath;

@end

#pragma mark - 创建表

- (void)viewDidLoad {
    [super viewDidLoad];

    // 创建表
    [self createTable];
}

#pragma mark - 创建表
- (void)createTable
{
    // 第一步:创建sql语句
    NSString *createSql = @"create table if not exists t_student(id integer primary key autoincrement not null, name text not null, age integer not null, sex text not null)";

    // 第二步:找到存储路径
    NSString *document = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:];

    self.filePath = [document stringByAppendingPathComponent:@"student.sqlite"];
    NSLog(@"%@", self.filePath);

    // 第三步:使用路径初始化FMDB对象
    self.dataBase = [FMDatabase databaseWithPath:self.filePath];

    // 第四步:数据库执行相关的操作
    // 需要判断数据库打开的时候才进行执行语句
    if ([self.dataBase open]) {
        BOOL result = [self.dataBase executeUpdate:createSql];
        if (result) {
            NSLog(@"建表成功");
        } else {
            NSLog(@"建表失败");
        }
    }

    // 第五步:关闭数据库
    [self.dataBase close];
}

#pragma mark - 添加学生

- (IBAction)insertIntoActon:(id)sender {

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

    // 第二步:进行相关操作
    NSArray *nameArray = [NSArray arrayWithObjects:@"MBBoy", @"炸天", @"小明", nil];
    ; i < nameArray.count; i ++) {
        NSString *name = [nameArray objectAtIndex:i];
        // 插入语句
        NSString *insertSql = @"insert into t_student(name, age, sex) values (?, ?, ?)";
        BOOL result = [self.dataBase executeUpdate:insertSql, name, @, @"男"];

        if (result) {
            NSLog(@"插入成功");
        } else {
            NSLog(@"插入失败");
            NSLog(@"%d", result);
        }

    }

    // 第五步:关闭数据库
    [self.dataBase close];
}

#pragma mark - 更改学生

- (IBAction)upDateAction:(id)sender {

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

    BOOL result = [self.dataBase executeUpdate:@"update t_student set name = ? where name = ?", @"孟玲旭", @"MBBoy"];
    if (result) {
        NSLog(@"更改成功");
    } else {
        NSLog(@"更改失败");
    }

    [self.dataBase close];
}

#pragma mark - 删除学生

- (IBAction)deleteAction:(id)sender {

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

    BOOL result = [self.dataBase executeUpdate:@"delete from t_student where name = ?", @"孟玲旭"];

    if (result) {
        NSLog(@"删除成功");
    } else {
        NSLog(@"删除失败");
    }

}

#pragma mark - 查询学生

- (IBAction)searchAction:(id)sender {

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

    // 查询结果使用的类FMResultSet

    FMResultSet *resultSet = [self.dataBase executeQuery:@"select * from t_student"];

    // 遍历除需要的所有内容
    while ([resultSet next]) {
        NSString *name = [resultSet objectForColumnName:@"name"];
        NSInteger age = [resultSet intForColumn:@"age"];
        NSString *sex = [resultSet objectForColumnName:@"sex"];
        NSLog(@"name = %@, age = %ld, sex = %@", name, age, sex);
    }

    [self.dataBase close];
}

#pragma mark - 插入很多学生

- (IBAction)insertManyStudent:(id)sender {

    // 已队列的形式添加数据是FMDB比较常用的添加方式

    // FMDB不支持多个线程同时操作, 所以一般以串行的实现方式实现相关操作。

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

    // 第一步:创建操作对类
    FMDatabaseQueue *queue = [FMDatabaseQueue databaseQueueWithPath:self.filePath];

    // 标识:记录是否成功
    __block BOOL isSuccess = YES;

    // 第二步:把所需要的事件打包放在操作队列中
    [queue inTransaction:^(FMDatabase *db, BOOL *rollback) {

        // 串行队列
        isSuccess = [db executeUpdate:, @"男"] && isSuccess;

        isSuccess = [db executeUpdate:, @"女"] && isSuccess;

        isSuccess = [db executeUpdate:, @"女"] && isSuccess;
        // 如果有错误
        if (!isSuccess) {
            // block返回的参数rollback进行处理(bool 类型的指针)
            *rollback = YES;
            return ;
        }
    }];

    [self.dataBase close];
}

FMDB的简单用法的更多相关文章

  1. CATransition(os开发之画面切换) 的简单用法

    CATransition 的简单用法 //引进CATransition 时要添加包“QuartzCore.framework”,然后引进“#import <QuartzCore/QuartzCo ...

  2. jquery.validate.js 表单验证简单用法

    引入jquery.validate.js插件以及Jquery,在最后加上这个插件的方法名来引用.$('form').validate(); <!DOCTYPE html PUBLIC " ...

  3. NSCharacterSet 简单用法

    NSCharacterSet 简单用法 NSCharacterSet其实是许多字符或者数字或者符号的组合,在网络处理的时候会用到 NSMutableCharacterSet *base = [NSMu ...

  4. [转]Valgrind简单用法

    [转]Valgrind简单用法 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html Valgrind的主要作者Julian S ...

  5. Oracle的substr函数简单用法

    substr(字符串,截取开始位置,截取长度) //返回截取的字 substr('Hello World',0,1) //返回结果为 'H'  *从字符串第一个字符开始截取长度为1的字符串 subst ...

  6. Ext.Net学习笔记19:Ext.Net FormPanel 简单用法

    Ext.Net学习笔记19:Ext.Net FormPanel 简单用法 FormPanel是一个常用的控件,Ext.Net中的FormPanel控件同样具有非常丰富的功能,在接下来的笔记中我们将一起 ...

  7. TransactionScope简单用法

    记录TransactionScope简单用法,示例如下: void Test() { using (TransactionScope scope = new TransactionScope()) { ...

  8. WPF之Treeview控件简单用法

    TreeView:表示显示在树结构中分层数据具有项目可展开和折叠的控件 TreeView 的内容是可以包含丰富内容的 TreeViewItem 控件,如 Button 和 Image 控件.TreeV ...

  9. listActivity和ExpandableListActivity的简单用法

    http://www.cnblogs.com/limingblogs/archive/2011/10/09/2204866.html 今天自己简单的总结了listActivity和Expandable ...

随机推荐

  1. 乘方快速幂 OR 乘法快速幂

    关于快速幂这个算法,已经不想多说,很早也就会了这个算法,但是原来一直靠着模板云里雾里的,最近重新学习,发现忽视了一个重要的问题,就是若取模的数大于int型,即若为__int64的时候应该怎么办,这样就 ...

  2. Run Loop简介

    做了一年多的IOS开发,对IOS和Objective-C深层次的了解还十分有限,大多还停留在会用API的级别,这是件挺可悲的事情.想学好一门语言还是需要深层次的了解它,这样才能在使用的时候得心应手,出 ...

  3. 批量检查APK是否具有指定的权限。

    为测试组的妹子提供的. 效果如下: 目录结构如下: 源代码思路: 1.将apk文件变为zip文件.这里是修改后缀 2.解压文件到指定目录.可以只解压其中mainfest.xml文件 3.移动xml文件 ...

  4. java实现FFT变换(转)

    源:java实现FFT变换 /************************************************************************* * Compilati ...

  5. 功率W与dBm的对照表及关系(转)

    源:功率W与dBm的对照表及关系 功率W与dBm的对照表 dBm          Watts                          dBm            Watts  0     ...

  6. IOS开发中UIAlertController(警告框)的使用

    步骤一.初始化: UIAlertController * inputname = [UIAlertController alertControllerWithTitle:@"未输入账户&qu ...

  7. 【转】Linux目录下/dev/shm的理解和使用

    一般来说,现场部署  都要根据内存的大小来设定/dev/shm的大小,大部分使用的是默认的值! Linux目录下/dev/shm的理解和使用 [日期:2014-05-16] 来源:Linux社区  作 ...

  8. Binary转换成Hex字符串

    想调优别人的代码,网上搜索一下Binary to Hexstring的转换,全是利用printf.scanf之类实现的,效率好低,还是自己想个简单的办法吧! .......此处省略一万字....... ...

  9. 【java基础】内部类,局部内部类,匿名内部类、静态内部类、接口中的内部类

    内部类: 1.定义在一个类中的内部类,内部类的实例化伴随着外围类所定义的方法来构造,内部类对象有外围类的隐式引用,所以内部类可以直接访问外围类的外围类的域,包括私有的,这是内部类的访问特权,所以比常规 ...

  10. thinkPHP的学习

    1.版本,以3.1为主,因为手册是基于这个的,最新的版本,还没有对应的手册 2.发现一个问题,echo 中文时,出现乱码,而调用模版则正常. 3.写url的注意大小写.index和Index是不同的 ...