iOS FMDatabase 本地数据库的创建和几个基本使用方法

转自:http://blog.it985.com/3677.html

使用数据库之前当然要先在网上下载FMDB的库,然后添加到自己的工程里面去。没有的请点击下面的来下载
fmdb
在FrameWork里添加“libsqulite3.0.dylib”,不然库托进去后会引起大量报错。

一般来说,我们把一个应用的数据库建在当前程序的沙盒里,所以,我们要先取得沙盒的路径
在AppDelegate.m中


1

2

3

4

5

6

- (NSString *) dataFilePath//应用程序的沙盒路径

{

    NSArray *path = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);

    NSString *document = [path objectAtIndex:0];

    return [document stringByAppendingPathComponent:@"StudentData.sqlite"];

}

如果其他文件中也要使用数据库的话,取得沙盒路径后把路径设为全局变量
在AppDelegate.h中


1

@property (strong, nonatomic) NSString *dbPath;

在AppDelegate.m中


1

2

3

4

5

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

    AppDelegate *myDelegate = [[UIApplication sharedApplication] delegate];

    myDelegate.dbPath = [self dataFilePath];

    return YES;

}

路径准备好之后,下一步就是在本地创建数据库和表
数据库的语句基本上都是很容易从字面上看懂的
在AppDelegate.m中


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

- (void)createTable

{

    AppDelegate *myDelegate = [[UIApplication sharedApplication] delegate];

    NSFileManager *fileManager = [NSFileManager defaultManager];

    FMDatabase *db = [FMDatabase databaseWithPath:myDelegate.dbPath];

    if (![fileManager fileExistsAtPath:myDelegate.dbPath]) {

        NSLog(@"还未创建数据库,现在正在创建数据库");

        if ([db open]) {

            

            [db executeUpdate:@"create table if not exists StudentList (name text, address text, id text)"];

            

            [db close];

        }else{

            NSLog(@"database open error");

        }

    }

    NSLog(@"FMDatabase:---------%@",db);

}

这样,我们就创建了一个名为“db”的数据库,和名为“StudentList”的表。
值得注意的是,创建数据库之后如果要使用的话一定要在使用之前进行[db open],使用结束后[db close]。这是千万不能忘的。
之后我们要在其他.m文件使用库的话就可以像下面这样
如果要在表中插入一组新的数据


1

2

3

4

5

6

7

8

9

10

11

12

13

14

AppDelegate *myDelegate = [[UIApplication sharedApplication] delegate];

FMDatabase *db = [FMDatabase databaseWithPath:myDelegate.dbPath];

[db open];

NSString *name = @"苹果";

NSString *address = @"安徽";

int i = 1;

NSString *id = [NSString stringWithFormat:@"%d",i];

res = [db executeUpdate:@"INSERT INTO StudentList (name, address, id) VALUES (?, ?, ?)", name, address, id];

if (res == NO) {

    NSLog(@"数据插入失败");

    }else{

     NSLog(@"数据插入成功");

    }

[db close];

修改数据库(把id为1的地址和姓名修改掉)


1

res = [db executeUpdate:@"UPDATE StudentList SET name = ?, address = ? WHERE id = ?",@"橘子",@"芜湖",1];

查询数据库(查询id为1的姓名和地址)


1

2

NSString *nameOut = [db stringForQuery:@"SELECT name FROM StudentList WHERE id = ?",1];

NSString *addressOut=  [db stringForQuery:@"SELECT address FROM StudentList WHERE id = ?",1];

删除数据库(删除id为1的数据)


1

res = [db executeUpdate:@"DELETE FROM StudentList WHERE id = ?",1];

说明一下上面的”res”是检测是否出错的标志位,如果不想用的话可以不用的。还有,想往数据库加入整型数据的话可能会报错,建议把整型转换成字符串再添加,像下面这样。


1

2

3

int i = 1;

NSString *id = [NSString stringWithFormat:@"%d",i];

res = [db executeUpdate:@"INSERT INTO StudentList (name, address, id) VALUES (?, ?, ?)", name, address, id];

时间: 2024-12-19 09:50:49

iOS FMDatabase 本地数据库的创建和几个基本使用方法的相关文章

iOS App初始化或者升级,涉及本地数据库迁移的问题

总体思路 一般app启动之后,都有一个初始化的过程.此外后续app升级,还需要考虑数据迁移.所以初始化和数据迁移的框架,在初期的版本就要考虑好 总结一下我们的app采取的方案: 1.在持久化的文件夹内(比如UserDefaults或者Documents目录),用一个字段保存老版本号 2.在开始初始化之前,读取老版本号,以及当前版本号 3.如果该应用是第一次加载,那么老版本号就取不到(因为是初次加载,这个字段还没有保存),那么就可以执行初始化过程:如果取到了老版本号,就不执行初始化 4.初始化完成

iOS学习之sqlite的创建数据库,表,插入查看数据

目录(?)[-] 新建项目sqliteDemo添加使用sqlite的库libsqlite3dylib sqlite 的方法 获取沙盒目录并创建或打开数据库 创建数据表 插入数据 查询数据库并打印数据 iOS sqlite数据库操作.步骤是: 先加入sqlite开发库libsqlite3.dylib, 新建或打开数据库, 创建数据表, 插入数据, 查询数据并打印 1.新建项目sqliteDemo,添加使用sqlite的库libsqlite3.dylib 2.sqlite 的方法 sqlite3  

Windows Phone本地数据库(SQLCE):10、创建数据库(翻译) (转)

这是“windows phone mango本地数据库(sqlce)”系列短片文章的第十篇. 为了让你开始在Windows Phone Mango中使用数据库,这一系列短片文章将覆盖所有你需要知道的知识点.我将谈谈创建一个windows phone mango本地数据库. 1.创建数据库 在你创建了DataContext对象后,你可以创建本地数据库并且执行一些额外的数据库操作. 注释:数据库被创造后,它是自动分配的一个版本.为了确定数据库版本,使用DatabaseSchemaUpdater 类.

创建本地数据库

一.通过SYSDBA登录数据库: 二.创建用户并设置密码: create user XXXX(用户名) identified by XXXX(密码);--创建用户名和密码 grant dba to pad;--赋权 三.创建数据链: create database link XXXX(另一个用户所在数据库) connect to "XXXX(要拷贝数据的用户名)" identified by "XXXX(要考博数据的密码)" using 'XXXX(另一个用户所在数

iOS CoreData数据库之创建详解

CoreData数据库简介 CoreData介绍 CoreData是一门功能强大的数据持久化技术,位于SQLite数据库之上,它避免了SQL的复杂性,能让我们以更自然的方式与数据库进行交互.CoreData提供数据–OC对象映射关系来实现数据与对象管理,这样无需任何SQL语句就能操作他们. CoreData数据持久化框架是Cocoa API的一部分,?次在iOS5 版本的系统中出现,它允许按照实体-属性-值模型组织数据,并以XML.?进制文件或者SQLite数据?件的格式持久化数据 CoreDa

【转】 iOS学习之sqlite的创建数据库,表,插入查看数据

原文:  http://blog.csdn.net/totogo2010/article/details/7702207 iOS sqlite数据库操作.步骤是: 先加入sqlite开发库libsqlite3.dylib, 新建或打开数据库, 创建数据表, 插入数据, 查询数据并打印 1.新建项目sqliteDemo,添加使用sqlite的库libsqlite3.dylib 2.sqlite 的方法 sqlite3          *db, 数据库句柄,跟文件句柄FILE很类似 sqlite3

QT 创建本地数据库(SQLite数据库)存储数据

注意:QT自带SQLITE数据库,不需要再安装 1.创建一个包含创建.查询.修改和删除数据库的数据库类(DataBase) DataBase.h头文件 #pragma once #include <QObject> #include <QtSql/QSqlDatabase> #include <QtSql/QSqlQuery> #include <QtSql/QSqlDriver> #include <QtSql/QSqlError> #incl

IOS开发之数据库FMDB

IOS开发之数据库FMDB 1.简介 需求作用:如果需要保存大量的结构较为复杂的数据时候, 使用数据库, 例如交规考试项目 常用的数据库: (1)Microsoft SQL Server 2000/2008:中小企业使用较多 (2)Oracle:比较复杂, 大企业使用较多 (3)Mysql数据库:网站使用较多 (4)sqlite:本地数据库, 访问数据足够快, 直接访问文件  足够简单, 功能相对其他数据库软件不是特别齐全, 足够用了  足够小, 系统不超过1M, 适合在移动端上使用 2. Me

IOS开发之数据库FMDB的使用

本文中主要介绍ios数据库常用的软件以及常用的数据库操作方法. 1.数据库基本知识介绍 数据量小,结构简单,数据保存可采用归档,plist(xml格式),存进去的效率很低: 数据复杂,格式多,量大,用数据库存取效率高,比如交规考试项目的数据存储; 本地数据--->网络数据--->本地(一次取数据,多次取数据) 1.1常用数据库 (1).MicroSoft SQL Server ...2000/2008 中小企业使用较多 (2).Oracle,比较复杂,大企业使用较多 (3).Mysql 数据库