我想以listArray的形式从objective-c中的sqlite db中获取数据(就像在java android中一样)。
这里我有这个
的java类模型如何将这些类转换为在减速(.h)和实现(.m)中混淆的客观c代码
第1类
public class RecordingList {
public ArrayList<RecordingItem> Items = new ArrayList<RecordingItem>();
}
第2课
public class RecordingItem {
public int ID;
public String RecordingTitle;
public String RecordingSubTitle;
public String RecordingAudioPath;
public String RecordingDuration;
public String RecordingNotePath;
public String Date;
public String Time;
public String PlayListId;
public ArrayList<RecordingAttachments> recordingAttachmentses = new ArrayList<RecordingAttachments>();
}
我试图在Objective-c中获取数据,如此
- (NSArray*) getAllNotes
{
const char *dbpath = [databasePath UTF8String];
if (sqlite3_open(dbpath, &database) == SQLITE_OK)
{
NSString *querySQL = [NSString stringWithFormat:
@"SELECT * FROM recordingItem"];
const char *query_stmt = [querySQL UTF8String];
NSMutableArray *resultArray = [[NSMutableArray alloc]init];
if (sqlite3_prepare_v2(database,
query_stmt, -1, &statement, NULL) == SQLITE_OK)
{
if (sqlite3_step(statement) == SQLITE_ROW)
{
NSString *name = [[NSString alloc] initWithUTF8String:
(const char *) sqlite3_column_text(statement, 0)];
[resultArray addObject:name];
NSString *department = [[NSString alloc] initWithUTF8String:
(const char *) sqlite3_column_text(statement, 1)];
[resultArray addObject:department];
NSString *year = [[NSString alloc]initWithUTF8String:
(const char *) sqlite3_column_text(statement, 2)];
[resultArray addObject:year];
return resultArray;
}
else{
NSLog(@"Not found");
return nil;
}
sqlite3_reset(statement);
}
}
return nil;
}
但这不是我想要的,我想在对象列表中获取数据,我该怎么做?
先谢谢
答案 0 :(得分:1)
首先,建议您自己开始使用Objective C基础知识。之后,您将能够在几分钟内重写Java类
如果您不想使用CoreData(建议使用,如果您只定位iOS),那么您可以使用例如。 FMDatabase更易于使用,并隐藏了您在此处撰写的所有原生内容
还有一个通知:您将name
,department
,year
一个接一个地添加到数组中,创建一个ObjC @interface
,它将保存所有数据:
< / p>
@interface Data : NSObject
@property (nonatomic, strong) NSString *name;
@property (nonatomic, strong) NSString *department;
@property (nonatomic, strong) NSString *year;
@end
并使用它:
NSMutableArray *resultArray = [NSMutableArray new];
// fetch ...
Data *data = [[Data alloc] init];
data.name = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 0)];
// other fields ...
[resultArray addObject:data];
再一次注意:you can now create参数化数组就像在Java中一样。