FMDB是iOS平台用OC语言封装了SQLite API的数据库框架,其优点是:
FMDatabase:一个FMDatabase对象就代表一个单独的SQLite数据库用来执行SQL语句。
FMResultSet:使用FMDatabase执行查询后的结果集。
FMDatabaseQueue:用于在多线程中执行多个查询或更新,它是线程安全的。
NSSearchPathForDirectoriesInDomains方法返回的是一个数组类型的数据,所以这里是获取它返回数组的最后一个元素。
NSSearchPathForDirectoriesInDomains
函数用于获取指定目录的路径。它的参数分别表示:
目标目录的类型(Search Path Directory Type):这是一个枚举值,用于指定你希望获取的目录的类型。常见的类型包括:
NSDocumentDirectory
:文档目录,通常用于存储用户生成的文件,例如文档或用户数据。NSLibraryDirectory
:库目录,通常用于存储应用程序的支持文件和数据。NSCachesDirectory
:缓存目录,通常用于存储可以随时重建的临时文件或缓存数据。NSApplicationSupportDirectory
:应用程序支持目录,用于存储应用程序支持的数据文件。目标目录的域(Search Path Domain Mask):这是一个枚举值,用于指定搜索目录的域。常见的域包括:
NSUserDomainMask
:搜索用户的主目录,通常在此域中搜索应用特定的目录。NSLocalDomainMask
:搜索本地机器上的目录,通常在此域中搜索系统级的目录。NSNetworkDomainMask
:搜索网络上的目录,通常在此域中搜索网络共享目录。NSAllDomainsMask
:搜索所有域。是否展开波浪符号(Expanding Tilde to Path):这是一个布尔值,如果设置为 YES
,则会将波浪符号 (~
) 扩展为用户的主目录路径。这通常用于获取用户特定的目录路径。如果设置为 NO
,则波浪符号将保持不变。
stringByAppendingPathComponent是路径拼接,会在字符串前自动添加“/”,成为完整路径。
在创建文件的时候,会有几种情况:
CREATE TABLE IF NOT EXISTS collectionData:
意思是你创建了一个叫做collectionData的数据库,自己创建的话也可以改为自己方便识别的名字。
mainLabel text NOT NULL:
意思就是你在刚才的collectionData数据库里边添加了一个text类型的名叫mainLabel的一个索引,其它代码意思也相似。
以下用代码说明:
#import "test.h"
@implementation test
- (void)getData {
//获取数据库文件路径
NSString *doc = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
//stringByAppendingPathComponent拼接路径
NSString *fileName = [doc stringByAppendingPathComponent:@"collectionData.sqlite"];
NSLog(@"%@", fileName);
//获得数据库
self.collectionDatabase = [FMDatabase databaseWithPath:fileName];
//打开数据库
if ([self.collectionDatabase open]) {
//创表
BOOL result = [self.collectionDatabase executeUpdate:@"CREATE TABLE IF NOT EXISTS collectionData (mainLabel text NOT NULL, nameLabel text NOT NULL, imageURL text NOT NULL, networkURL text NOT NULL, dateLabel text NOT NULL, nowLocation text NOT NULL, goodState text NOT NULL, collectionState text NOT NULL, id text NOT NULL);"];
if (result) {
NSLog(@"创表成功");
} else {
NSLog(@"创表失败");
}
}
}
//FMDB的增删改查
//插入数据
- (void)insertData {
if ([self.collectionDatabase open]) {
NSString *string = @"aaa";
//INSERT INTO collectionData意思是向collectionData插入数据,(mainLabel, nameLabel, imageURL, networkURL, dateLabel, nowLocation, goodState, collectionState, id)表示你要赋值的索引,(?, ?, ?, ?, ?, ?, ?, ?, ?);", string, string, string, string, string, string, string, string, string表示你要赋的值
BOOL result = [self.collectionDatabase executeUpdate:@"INSERT INTO collectionData (mainLabel, nameLabel, imageURL, networkURL, dateLabel, nowLocation, goodState, collectionState, id) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?);", string, string, string, string, string, string, string, string, string];
if (!result) {
NSLog(@"增加次数失败");
} else {
NSLog(@"增加次数成功");
}
//关闭文件
[self.collectionDatabase close];
}
}
//更新数据
- (void) updateData {
if ([self.collectionDatabase open]) {
//UPDATE collectionData SET id = ? WHERE nameLabel = ?意思是当nameLabel = ?条件成立的时候,更新collectionData中的id索引对应的数据
NSString *sql = @"UPDATE collectionData SET id = ? WHERE nameLabel = ?";
BOOL result = [self.collectionDatabase executeUpdate:sql, @"1", @"aaa"];
if (!result) {
NSLog(@"数据修改失败");
} else {
NSLog(@"数据修改成功");
}
[self.collectionDatabase close];
}
}
//删除数据
- (void)deleteData {
if ([self.collectionDatabase open]) {
//delete from collectionData WHERE collectionState = ?意思是当collectionState = ?条件成立后删除collectionData数据库中的一组数据
NSString *sql = @"delete from collectionData WHERE collectionState = ?";
BOOL result = [self.collectionDatabase executeUpdate:sql, @"bbb"];
if (!result) {
NSLog(@"数据删除失败");
} else {
NSLog(@"数据删除成功");
}
[self.collectionDatabase close];
}
}
- (void)queryData {
if ([self.collectionDatabase open]) {
//SELECT * FROM collectionData:选择collectionData中的数据,*处也可以改为WHERE条件。
FMResultSet *resultSet = [self.collectionDatabase executeQuery:@"SELECT * FROM collectionData"];
while ([resultSet next]) {
NSString *mainLabel = [resultSet stringForColumn:@"mainLabel"];
NSLog(@"mainLabel = %@", mainLabel);
}
[self.collectionDatabase close];
}
}
@end