如何从objective-c中的对象列表中的sqlite db中获取数据?

时间:2016-03-31 06:44:20

标签: ios objective-c sqlite nsmutablearray

我想以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;
    }

但这不是我想要的,我想在对象列表中获取数据,我该怎么做?

先谢谢

1 个答案:

答案 0 :(得分:1)

首先,建议您自己开始使用Objective C基础知识。之后,您将能够在几分钟内重写Java类 如果您不想使用CoreData(建议使用,如果您只定位iOS),那么您可以使用例如。 FMDatabase更易于使用,并隐藏了您在此处撰写的所有原生内容 还有一个通知:您将namedepartmentyear一个接一个地添加到数组中,创建一个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中一样。