FMDB操作 SQLite的查询操作方法
FMDB的查询方法简单操作
- (FMResultSet*)executeQuery:(NSString*)sql, ...;
- (FMResultSet*)executeQueryWithFormat:(NSString*)format, ...;
- (FMResultSet*)executeQuery:(NSString*)sql withArgumentsInArray:(NSArray*)arguments;
- (FMResultSet*)executeQuery:(NSString*)sql withParameterDictionary:(NSDictionary*)arguments;
写在前面:网上的资料
1.创建一个数据库,并创建表testTable
@"create table if not exists testTable('id' integer primary key autoincrement,'name' text, 'age' integer, 'birth' text)"
在里面插入数据,如图所示
data:image/s3,"s3://crabby-images/33101/33101290cfc1b707fb480a206a15c3b305d5d145" alt=""
下面来进行测试
- (FMResultSet *)executeQuery:(NSString*)sql, ...;
[_db executeQuery:@"select name,age from testTable"];
data:image/s3,"s3://crabby-images/84732/84732a97b0ccb1b3a79848c0a39396d0911f06aa" alt=""
现在换一种查询方式
[_db executeQuery:@"select ?,? from testTable;",@"name",@"age"];
data:image/s3,"s3://crabby-images/ce4d3/ce4d3b3c3259b27ffe6fae323dd7f18949f17172" alt=""
并没有查询到我们想要的数据,我们在where语句中试一下
[_db executeQuery:@"select name,age from testTable where name = ?;", @"zhangsan"];
这里我门找到了name = zhangsan的数据
data:image/s3,"s3://crabby-images/24809/24809c3ab9bdc9407e44375acf364e124741f2bd" alt=""
接下来我们查询age,
[_db executeQuery:@"select name,age from testTable where age = ?;", @(18)];
data:image/s3,"s3://crabby-images/416fd/416fd9f10c4ebb6407648ec371b5053622ccdd72" alt=""
也查到我们想要的数据。上面的查询语句中,我们传入的age是NSNumber类型的,我们试一下能否是String类型
[_db executeQuery:@"select name,age from testTable where age = ?;", @"18"];
这里也是能够查询到的,截图和上面一样,就不再重复上传了
我们再来尝试满足两个条件人意一个条件的情况,看看结果
[_db executeQuery:@"select name,age from testTable where age = ? or name = ?;", @(18), @"zhangsan"];
data:image/s3,"s3://crabby-images/371a8/371a83997048995ccbc8da3eeee7a67e243b4c4c" alt=""
总结一下,?只能够用来对数据进行占位,不能对列名称进行占位
PS;[_db executeQuery:@"select name,age from testTable where ? = ?;", @"name",@"zhangsan"];
出现了意想不到的效果。
- (FMResultSet*)executeQueryWithFormat:(NSString*)format, ...;
[_db executeQueryWithFormat:@"select %@,%@ from testTable",@"name", @"age"];
data:image/s3,"s3://crabby-images/d633e/d633ea452595aa2d73c57d878c0f8b9d5a361e21" alt=""
仍然没有找多我们想要的数据,着复合我们的预期
[_db executeQueryWithFormat:@"select name,age from testTable where name = %@;", @"zhangsan"]
data:image/s3,"s3://crabby-images/54d56/54d5668933cc6b21d05ce2ad3c4cc38bcedcdcc7" alt=""
结果如上。PS,由于结果相同,我没有重新截图,直接使用刚才的截图
[_db executeQueryWithFormat:@"select name,age from testTable where age = %@;", @"18"];
这里age = %@, 年龄也是@”“类型,能够查询到数据
data:image/s3,"s3://crabby-images/cf300/cf3001ec5736b538df61c833d70f29a726319382" alt=""
接下来尝试数据类型不对应的情况
age = %@;", @(18) 和上面的结果相同
age = %d;", 18 和上面结果相同
age = %d;", @"18"
会出现查询失败,并且控制台为可输入状态,真机不清楚
age = %@;", 18
这个会直接崩溃。不能这样写
- (FMResultSet*)executeQuery:(NSString*)sql withArgumentsInArray:(NSArray*)arguments;
[_db executeQuery:@"select name, age from testTable where name = ? or age = ?" withArgumentsInArray:@[@"zhangsan", @(18)]];
全部使用?,并且后面使用OC对象
data:image/s3,"s3://crabby-images/de60f/de60f5d79cf73563b80e3f2dc84e934a9081b88c" alt=""
[_db executeQuery:@"select name, age from testTable where name = %@ or age = %@" withArgumentsInArray:@[@"zhangsan", @(18)]]
使用frrmat方式,会报错,信息如下
data:image/s3,"s3://crabby-images/c483d/c483d617de9a07058e24ae8732a031ea0cc6a1a8" alt=""
- (FMResultSet*)executeQuery:(NSString*)sql withParameterDictionary:(NSDictionary*)arguments;
使用字典.个人进行尝试
[_db executeQuery:@"select name, age from testTable where name = :name or age = :age;" withParameterDictionary:@{@"name":@"zhangsan",@"age":@(18)}];
成功得到结果。
data:image/s3,"s3://crabby-images/35333/35333f7fbe0f1cf6cf4b64c797557f4406cb205e" alt=""
上看的例子,: name 和ket name是对应的,可以用其他的代替,例如
[_db executeQuery:@"select name, age from testTable where name = :value1 or age = :value2;" withParameterDictionary:@{@"value1":@"zhangsan",@"value2":@(18)}]
这样也是能够得到上面的结果。
总结。查询语句中,为了代码的可读性,我们可能会使用占位符。FDMB中,占位符只能对我门需要传入的值进行占位,不能对选项进行占位,例如
select name , age from table where nane = ‘hahaha’ or age = ’18’
我门只能对hahaha和18,这两个需要传入的值进行占位,name,age ,table 都是不能够的进行占位的