1

我正在循环从 SQLite3 数据库生成的 FMDB 结果集,创建稍后使用的对象。数据内容由各种用户使用各种文本编辑器和编码创建。

一些记录是有问题的,列值返回 nil,即使列中有文本。

例如,当我运行命令行查询但 FMDB 方法 stringForColumn 返回 nil 时,我看到数据库中列的文本。我还看到潜在的原因是列内容中的高 ascii 字符,这很可能是用户从 MS Word 复制和粘贴文本到达那里的。我的问题是处理这种类型的“脏”数据的最佳方法是什么,意识到某些数据可能在带有这些字符的数据库中?

在此处输入图像描述

NSMutableDictionary *words = [[NSMutableDictionary alloc] init];
FMResultSet *rs = [db executeQuery:@"SELECT * FROM `foo` WHERE 1"];

while ([rs next]) {
    Word *myWord = [[Word alloc] init];  

    //Coming in as a nil value eventhough there is text in the database column
    [myWord setDefinition:[rs stringForColumn:@"definition"]];

    [words setObject:[myWord definition] forKey:[myWord term]];
}
4

2 回答 2

1

即使您有不同的用户从多个文本编辑器输入代码和编码,它们也必须标准化为数据库设置的编码。似乎这可能与 FMDB 未正确处理存储在数据库中的编码的翻译有关。也许既然您知道数据的编码,您可以提取内容并进行自己的“翻译”?尝试使用 dataForColumn 或 UTF8StringForColumnIndex 直接提取数据,看看你会得到什么。

顺便说一句,“哪里”没有错,但我会说这是多余的。我还要补充一点,因为它没有任何用途,它可能会误导或混淆那些不熟悉 sql 的人。

于 2012-10-09T18:38:03.883 回答
-3

您的选择语句中的“位置”不正确。

于 2012-04-14T01:23:57.937 回答