ios数据存储方式FMDB
从网上下载FMDB的原码,将其拖入到项目中,然后在Link Binary With Libraries中添加libsqlite3.dylib,就可以用了
实现如下:
- #import "ViewController.h"
- #import "FMDatabase.h"
- #import "FMDatabaseAdditions.h"
- #import "FMDatabaseQueue.h"
- @interface ViewController ()
- @end
- @implementation ViewController
- - (void)viewDidLoad
- {
- [super viewDidLoad];
- // Do any additional setup after loading the view, typically from a nib.
- }
- - (void)didReceiveMemoryWarning
- {
- [super didReceiveMemoryWarning];
- // Dispose of any resources that can be recreated.
- }
- - (void)dealloc {
- [_nameText release];
- [_ageText release];
- [_sexText release];
- [_showLabel release];
- [super dealloc];
- }
- - (void)viewDidUnload {
- [self setNameText:nil];
- [self setAgeText:nil];
- [self setSexText:nil];
- [self setShowLabel:nil];
- [super viewDidUnload];
- }
- //保存
- - (IBAction)saveBtn:(id)sender {
- FMDatabase* database=[FMDatabase databaseWithPath:[self databasePath]];
- if (![database open]) {
- NSLog(@"Open database failed");
- return;
- }
- if (![database tableExists:@"user"]) {
- [database executeUpdate:@"create table user (id integer primary key autoincrement not null,name text,age integer,sex text)"];
- }
- BOOL insert=[database executeUpdate:@"insert into user (name,age,sex) values (?,?,?)",_nameText.text,[NSNumber numberWithInteger:[_ageText.text integerValue]],_sexText.text];
- //下面注释的也能实现数据的插入,只不过它是传入了字典
- // NSMutableDictionary* argsDict=[NSMutableDictionary dictionary];
- // [argsDict setObject:_nameText.text forKey:@"name"];
- // [argsDict setObject:_ageText.text forKey:@"age"];
- // [argsDict setObject:_sexText.text forKey:@"sex"];
- // BOOL insert=[database executeUpdate:@"insert into user (name,age,sex) values (:name,:age,:sex)" withParameterDictionary:argsDict];
- if (insert) {
- UIAlertView* alert=[[UIAlertView alloc] initWithTitle:@"提示" message:@"保存成功" delegate:nil cancelButtonTitle:nil otherButtonTitles:@"确定",nil];
- [alert show];
- [alert release];
- }else{
- NSLog(@"insert failed");
- }
- [database close];
- //下面注释的这一段也是创建表只不过它是多线程安全的,而上面的在多线程中是不安全的
- // FMDatabaseQueue* queue=[FMDatabaseQueue databaseQueueWithPath:[self databasePath]];
- // [queue inDatabase:^(FMDatabase* database){
- // if (![database tableExists:@"user"]) {
- // [database executeUpdate:@"create table user (id integer primary key autoincrement not null,name text,age integer,sex text)"];
- // }
- // BOOL insert=[database executeUpdate:@"insert into user (name,age,sex) values (?,?,?)",_nameText.text,[NSNumber numberWithInteger:[_ageText.text integerValue]],_sexText.text];
- // if (insert) {
- // UIAlertView* alert=[[UIAlertView alloc] initWithTitle:@"提示" message:@"保存成功" delegate:nil cancelButtonTitle:nil otherButtonTitles:@"确定",nil];
- // [alert show];
- // [alert release];
- // }else{
- // NSLog(@"insert failed");
- // }
- //
- // }];
- // [queue close];
- }
- //显示所有数据库中的数据
- - (IBAction)showBtn:(id)sender {
- FMDatabase* database=[FMDatabase databaseWithPath:[self databasePath]];
- if (![database open]) {
- return;
- }
- //注意 此处的FMResultSet可以不用关闭,因为数据库关闭的时候FMResultSet自动关闭
- FMResultSet* resultSet=[database executeQuery:@"select* from user"];
- NSString* str=@"";
- while ([resultSet next]) {
- NSString* name=[resultSet stringForColumn:@"name"];
- NSInteger age=[resultSet intForColumn:@"age"];
- NSString* sex=[resultSet stringForColumn:@"sex"];
- str=[str stringByAppendingFormat:@"Name:%@,Age:%d,Sex:%@\n",name,age,sex];
- NSLog(@"Name:%@,Age:%d,Sex:%@\n",name,age,sex);
- }
- _showLabel.text=str;
- [database close];
- }
- //查询
- - (IBAction)checkBtn:(id)sender {
- FMDatabase* database=[FMDatabase databaseWithPath:[self databasePath]];
- if (![database open]) {
- return;
- }
- FMResultSet* resultSet=[database executeQuery:@"select* from user where name = ?",@"chen"];
- NSString* str=@"";
- while ([resultSet next]) {
- NSString* name=[resultSet stringForColumn:@"name"];
- NSInteger age=[resultSet intForColumn:@"age"];
- NSString* sex=[resultSet stringForColumn:@"sex"];
- str=[str stringByAppendingFormat:@"Name:%@,Age:%d,Sex:%@\n",name,age,sex];
- }
- _showLabel.text=str;
- [database close];
- }
- //删除
- - (IBAction)deleteBtn:(id)sender {
- FMDatabase* database=[FMDatabase databaseWithPath:[self databasePath]];
- if (![database open]) {
- return;
- }
- BOOL delete=[database executeUpdate:@"delete from user where name = ?",@"chen"];
- if (delete) {
- UIAlertView* alert=[[UIAlertView alloc] initWithTitle:@"提示" message:@"删除成功" delegate:nil cancelButtonTitle:nil otherButtonTitles:@"确定",nil];
- [alert show];
- [alert release];
- }
- [database close];
- }
- //更新
- - (IBAction)updateBtn:(id)sender {
- FMDatabase* database=[FMDatabase databaseWithPath:[self databasePath]];
- if (![database open]) {
- return;
- }
- BOOL update=[database executeUpdate:@"update user set age = ? where name= ?",[NSNumber numberWithInt:20],@"chen"];
- if (update) {
- UIAlertView* alert=[[UIAlertView alloc] initWithTitle:@"提示" message:@"更新成功" delegate:nil cancelButtonTitle:nil otherButtonTitles:@"确定",nil];
- [alert show];
- [alert release];
- }
- [database close];
- }
- -(NSString* )databasePath
- {
- NSString* path=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
- NSString* dbPath=[path stringByAppendingPathComponent:@"user.db"];
- return dbPath;
- }
- @end
ios数据存储方式FMDB的更多相关文章
- iOS - 数据存储方式(本地化)
iOS中数据存储方式 一般使用以下4种:(已更新) .NSKeyedAchiever//序列化 存放对象 .NSUserDefaults//本质是plist存储 NSData.NSString.NSN ...
- IOS 数据存储之 FMDB 详解
FMDB是用于进行数据存储的第三方的框架,它与SQLite与Core Data相比较,存在很多优势. FMDB是面向对象的,它以OC的方式封装了SQLite的C语言API,使用起来更加的方便,不需要过 ...
- IOS数据存储之FMDB数据库
前言: 最近几天一直在折腾数据库存储,之前文章(http://www.cnblogs.com/whoislcj/p/5485959.html)介绍了Sqlite 数据库,SQLite是一种小型的轻量级 ...
- ios中常见数据存储方式以及SQLite常用的语句
在iOS中,根据不同的需求对应的有多种数据存储方式: 1.NSUserdefaults 将数据存储到沙盒中(library),方便易用,但是只能存储系统提供的数据类型(plist),不能存储自定义的 ...
- IOS开发数据存储篇—IOS中的几种数据存储方式
IOS开发数据存储篇—IOS中的几种数据存储方式 发表于2016/4/5 21:02:09 421人阅读 分类: 数据存储 在项目开发当中,我们经常会对一些数据进行本地缓存处理.离线缓存的数据一般都 ...
- iOS 应用数据存储方式(XML属性列表-plist)
iOS 应用数据存储方式(XML属性列表-plist) 一.ios应用常用的数据存储方式 1.plist(XML属性列表归档) 2.偏好设置 3.NSKeydeArchiver归档(存储自定义对象) ...
- iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist)
iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist) 一.ios应用常用的数据存储方式 1.plist(XML属性列表归档) 2.偏好设置 3.NSKeydeArchiver归档(存 ...
- iOS开发UI篇—ios应用数据存储方式(偏好设置)
iOS开发UI篇—ios应用数据存储方式(偏好设置) 一.简单介绍 很多iOS应用都支持偏好设置,比如保存用户名.密码.字体大小等设置,iOS提供了一套标准的解决方案来为应用加入偏好设置功能 每个应用 ...
- iOS开发UI篇—ios应用数据存储方式(归档)
iOS开发UI篇—ios应用数据存储方式(归档) 一.简单说明 在使用plist进行数据存储和读取,只适用于系统自带的一些常用类型才能用,且必须先获取路径相对麻烦: 偏好设置(将所有的东西都保存在同 ...
随机推荐
- Foundation框架 - NSNumber类
NSNumber类 NSFormatter #import <Foundation/Foundation.h> int main(int argc, const char * argv[] ...
- org.hibernate.exception.ConstraintViolationException: could not delete:
转自:http://fireinwind.iteye.com/blog/848515 异常描述: org.hibernate.exception.ConstraintViolationExceptio ...
- linux 压缩、解压缩及归档工具
linux下主要的压缩.归档工具 compress/uncompress: .Z gzip/gunzip: .gz bzip2/bunzip2: .bz2 xz/unxz: .xz zip/unzi ...
- 执行时的C程序
数据和代码 编程语言理论经典对立之中的一个就是代码和数据的差别.有些语言如LISP把两者视为一体,其它语言如C语言则维持两者的差别.编译绝大部分工作都跟翻译代码有关,必要的数据存储管理的绝不部分都在执 ...
- undefined reference to `std::cout'等错误
(1)gcc和g++都是GNU(组织)的一个编译器. (2)后缀名为.c的程序和.cpp的程序g++都会当成是c++的源程序来处理.而gcc不然,gcc会把.c的程序处理成c程序. (3)对于.cpp ...
- 【Java】Java_13 分支结构
Java中常见的两种分支结构: <1>If语句:使用布尔表达式或者布尔类型值作为分支条件来进行分支控制. <2>switch语句:对多个整形值进行匹配,从而实现分支控制. 1. ...
- Maven 命令行创建项目时 Could not find goal ‘create’ in plugin org.apache.maven.plugins:...
使用maven3.3.9 版本,进行命令行创建项目时输入以下命令创建失败 mvn archetype:create -DgroupId=com.zang.maven -DartifactId=sys ...
- Webpack 的 HtmlWebpackPlugin 如何控制某个 chunks 的 inject 位置?
https://segmentfault.com/q/1010000006591131 通过修改 HtmlWebpackPlugin 源码实现了 修改后的配置: new HtmlWebpackPlug ...
- C++之栈、队列基本用法
1.C++栈的基本用法: #include<stack> (1)push():向栈内压入一个成员: (2)pop():栈顶弹出一个成员: (3)empty():栈为空返回true,否则返回 ...
- PILE读书笔记_文件I/O
open函数 int open(const char *pathname, int flags, mode_t mode); 参数说明: (1)pathname: 表示要打开的文件路径 (2)flag ...