一.首先创建模型类

User.h

#import <Foundation/Foundation.h>

@interface User : NSObject

@property(nonatomic,assign)NSInteger ids;

@property(nonatomic,strong)NSString *name;

@property(nonatomic,strong)NSString *classes;

@property(nonatomic,strong)NSString *grade;

@end

二.创建数据库的单例类 FMDBData

FMDBData.h

@interface FMDBData : NSObject

//单例类

+(instancetype)sharedFMDBData;

//增加数据自定义方法

-(BOOL)insertUser:(User *)user;

//删除数据自定义方法

-(BOOL)deleteUser:(User *)user;

//修改数据自定义方法

-(BOOL)updateUser:(User *)user;

//查询数据自定义方法

-(NSMutableArray *)getAll;

//查询单个数据

-(User *)getMessage:(NSString *)name;

@end

FMDBData.m

导入FMDB头文件

#import "FMDatabase.h"

//全局静态变量

//数据库

static FMDatabase *fmdb;

//对象

static FMDBData *DBdata;

@implementation FMDBData

//创建单例类的方法 - dispatch_once   只执行一次

+(instancetype)sharedFMDBData

{

static dispatch_once_t onceToken;

dispatch_once(&onceToken, ^{

DBdata = [[FMDBData alloc]init];

[DBdata initDB];

});

return DBdata;

}

+(instancetype)allocWithZone:(struct _NSZone *)zone

{

if (!DBdata) {

DBdata = [super allocWithZone:zone];

}

return DBdata;

}

-(id)copy

{

return self;

}

-(id)mutableCopy

{

return self;

}

-(void)initDB

{

//沙盒路径

NSString *doucmentPach = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject];

//拼接路径

NSString *pach = [doucmentPach stringByAppendingString:@"user.sqlite"];

//根据路径创建数据库

fmdb = [[FMDatabase alloc]initWithPath:pach];

if ([fmdb open]) {

//创建数据表

[fmdb executeUpdate:@"create table user(ids integer primary key autoincrement, name text, classes text, grade text)"];

NSLog(@"创建成功");

[fmdb close];

}

else

{

NSLog(@"创建失败");

}

}

//实现增加数据自定义方法

-(BOOL)insertUser:(User *)user

{

[fmdb open];

NSLog(@"%@",user.name);

BOOL isb = [fmdb executeUpdate:@"insert into user values (null,?,?,?)",user.name,user.classes,user.grade];

if (isb) {

NSLog(@"插入成功");

}

else

{

NSLog(@"插入失败");

}

[fmdb close];

return isb;

}

//实现删除数据自定义方法

-(BOOL)deleteUser:(User *)user

{

[fmdb open];

NSLog(@"%@",user.name);

BOOL isb = [fmdb executeUpdate:@"delete from user where name = ?",user.name];

if (isb) {

NSLog(@"删除成功");

}

else

{

NSLog(@"删除失败");

}

[fmdb close];

return isb;

}

//实现修改自定义方法

-(BOOL)updateUser:(User *)user

{

[fmdb open];

NSLog(@"%@",user.name);

NSString *str = [NSString stringWithFormat:@"update user set name = '%@' , classes = '%@' , grade = '%@' where ids = %ld",user.name,user.classes,user.grade,user.ids];

BOOL isb = [fmdb executeUpdate:str];

if (isb) {

NSLog(@"修改成功");

}

else

{

NSLog(@"修改失败");

}

[fmdb close];

return isb;

}

//查询所有

-(NSMutableArray *)getAll

{

//打开数据库

[fmdb open];

//创建可变数组

NSMutableArray *arr = [NSMutableArray array];

//创建结果对象接受数据库的操作结果

FMResultSet *fmset = [fmdb executeQuery:@"select * from user"];

//通过循环

while ([fmset next])

{

User *user = [[User alloc] init];

//用模型类对象接受数据库内容

user.ids = [fmset intForColumn:@"ids"];

user.name = [fmset stringForColumn:@"name"];

user.classes = [fmset stringForColumn:@"classes"];

user.grade = [fmset stringForColumn:@"grade"];

NSLog(@"%@",user.classes);

//将内容加入数组

[arr addObject:user];

}

//关闭数据库

[fmdb close];

return arr;

}

//查询单个数据

-(User *)getMessage:(NSString *)name

{

[fmdb open];

User *user = [[User alloc] init];

FMResultSet *fmset = [fmdb executeQuery:@"select * from user where name = ?",name];

while ([fmset next])

{

user.ids = [fmset intForColumn:@"ids"];

user.name = [fmset stringForColumn:@"name"];

user.classes = [fmset stringForColumn:@"classes"];

user.grade = [fmset stringForColumn:@"grade"];

}

[fmdb close];

return user;

}

@end

三.单例类的使用

1.删除按钮

- (IBAction)DeleteBtn:(id)sender {

//初始化FMDB

FMDBData *handle = [FMDBData sharedFMDBData];

//初始化单例类

User *user = [[User alloc] init];

//为 单例类的name赋值

user.name = self.NameTF.text;

//执行删除事件

BOOL isb =  [handle deleteUser:user];

// [table reloadData];

if (isb) {

[[[UIAlertView alloc] initWithTitle:@"提示" message:@"删除成功" delegate:nil cancelButtonTitle:@"确定" otherButtonTitles:nil, nil] show];

}else{

[[[UIAlertView alloc] initWithTitle:@"提示" message:@"删除失败" delegate:nil cancelButtonTitle:@"确定" otherButtonTitles:nil, nil] show];

}

[table reloadData];

}

2.查询按钮

- (IBAction)SelectBtn:(id)sender {

FMDBData *handle = [FMDBData sharedFMDBData];

if ([self.NameTF.text isEqualToString:@""]) {

arr = [handle getAll];

}

else

{

User *user=[handle getMessage:self.NameTF.text];

arr=[[NSMutableArray alloc]initWithObjects:user,nil];

}

[table reloadData];

}

3.添加按钮

-(void)click

{

//数据库

FMDBData *handle = [FMDBData sharedFMDBData];

//单例类

User *user = [[User alloc] init];

//保存数据

user.name = self.tfname.text;

user.classes = self.tfclass.text;

user.grade = self.tfscore.text;

//执行数据添加方法

BOOL isb =  [handle insertUser:user];

if (isb)

{

//

[self dismissViewControllerAnimated:YES completion:nil];

}

else

{

[[[UIAlertView alloc] initWithTitle:@"提示" message:@"保存失败" delegate:nil cancelButtonTitle:@"确定" otherButtonTitles:nil, nil] show];

}

}

4更新按钮 (传参为数据模型体)

-(void)click

{

FMDBData *hander=[FMDBData sharedFMDBData];

self.user.name = self.tfname.text;

self.user.classes = self.tfclass.text;

self.user.grade = self.tfscore .text;

NSLog(@"id:%ld",self.user.ids);

BOOL isb =  [hander updateUser:self.user];

if (isb) {

[self dismissViewControllerAnimated:YES completion:nil];

}else{

[[[UIAlertView alloc] initWithTitle:@"提示" message:@"修改失败" delegate:nil cancelButtonTitle:@"确定" otherButtonTitles:nil, nil] show];

}

}

FMDB实用攻略的更多相关文章

  1. git实用攻略(二)

    最近团队的版本控制从svn切换到了git,虽说已经使用git有2年多了,也写了一个实用攻略,但是github上的项目使用经验和公司内部团队协作的使用经验还有很多不同.补充下新的使用体会. 首先还是看一 ...

  2. git实用攻略

    Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. 下面是实用教程,免基础. 一.安装git https://git-scm.com/downloads 二.git创建 ...

  3. 教你MySQL Binlog实用攻略

    本文由云+社区发表 1.概述 binlog是Mysql sever层维护的一种二进制日志,与innodb引擎中的redo/undo log是完全不同的日志:其主要是用来记录对mysql数据更新或潜在发 ...

  4. 安卓APP动态调试-IDA实用攻略

    0x00 前言 随着智能手机的普及,移动APP已经贯穿到人们生活的各个领域.越来越多的人甚至已经对这些APP应用产生了依赖,包括手机QQ.游戏.导航地图.微博.微信.手机支付等等,尤其2015年春节期 ...

  5. 安卓APP动态调试(IDA实用攻略)

    转自:http://drops.wooyun.org/mobile/5942 0x00 前言 随着智能手机的普及,移动APP已经贯穿到人们生活的各个领域.越来越多的人甚至已经对这些APP应用产生了依赖 ...

  6. 面向Web应用的并发压力测试工具——Locust实用攻略

    1. 概述 该方案写作目的在于描述一个基于Locust实现的压力测试,文中详细地描述了如何利用locustfile.py文件定义期望达成的测试用例,并利用Locust对目标站点进行并发压力测试. 特别 ...

  7. [经验] Win7减肥攻略(删文件不删功能、简化优化系统不简优化性能)

    [经验] Win7减肥攻略(删文件不删功能.简化优化系统不简优化性能) ☆心梦无痕☆ 发表于 2014-1-24 11:15:04 https://www.itsk.com/thread-316471 ...

  8. IIS 7完全攻略之日志记录配置(摘自网络)

    IIS 7完全攻略之日志记录配置 作者:泉之源 [IT168 专稿]除了 Windows 提供的日志记录功能外,IIS 7.0 还可以提供其他日志记录功能.例如,可以选择日志文件格式并指定要记录的请求 ...

  9. 30天,O2O速成攻略【8.15济南站】

    活动概况 时间:2015年08月15日13:30-16:30 地点:山东大学凤岐茶社(山东大学中心校区北门18号楼东连廊一层) 主办:APICloud.蚁巡 网址:www.apicloud.com 费 ...

随机推荐

  1. 记录一些容易忘记的属性 -- UINavigationController

    //设置导航栏的风格    self.navigationController.navigationBar.barStyle = UIBarStyleDefault;    //设置导航栏是否透明 N ...

  2. ubuntu频繁掉线 转

    好长好长时间没来百度空间了,最近闲来无事,正好弥补之前的空缺了!跟Ubuntu打交道已有很长一段时间了,期间遇到了很多问题,我把遇到的一些问题及找到的解决方案记录下来,我想这可能会对那些跟我有同样境遇 ...

  3. Python使用CGIHTTPServer调用shell作为cgi脚本

    #!/bin/bash echo "Content-Type:text/html" echo "" echo "hello world!" ...

  4. BZOJ 3670 && BZOJ 3620 && BZOJ 3942 KMP

    最近感到KMP不会啊,以前都是背板的现在要理解了. #include <iostream> #include <cstring> #include <cstdio> ...

  5. 1、webservice的简单使用

    1.新建一个web端项目 2.点击添加项,选择web服务 3.在已经建好的项目中写一个方法 4.发布(发布方法选文件系统,web需要管理员权限) 生成文件夹: 5.配置IIS(略) 6.调用webse ...

  6. Python12期培训班-day1-三级菜单代码分享

    #!/usr/bin/env python3 import sys import os zonecode = { '广东省': {'广州市':['越秀区','海珠区','荔湾区','天河区'], '深 ...

  7. C和Objective-C的语法概要

    C语言的三个基本要素是数据.语句和函数,支持面向过程编程(POP). C语言有数据,数据分为常量和变量,数据的类型分为字符类型和数字类型,数字类型分为整数类型和浮点数类型,复合数据的类型有数组和结构, ...

  8. 将war包部署到服务器的详细步骤

    第一步: 先将项目打包成war文件,也就是将在项目上单击鼠标右键,选择Export: 选择WAR file,点击下一步: 会出现如下所示,选择你要保存的位置,点击完成: 在你所选择的地方会有个如下所示 ...

  9. HTTP请求 GET POST 网络编程实现(转)

    尊重原作者收集的资料,复制粘贴只为了避免作者文章出处哪天抽风了访问不了了导致资料消失. 原文地址 http://bbs.neworigin.net/forum.php?mod=viewthread&a ...

  10. SQLite手工注入方法小结

    SQLite 官网下载:www.sqlite.org/download.html sqlite管理工具:http://www.yunqa.de/delphi/products/sqlitespy/in ...