cocoa - 在 Cocoa 中构建字符串时使用单引号

标签 cocoa string

我正在 Cocoa 中构建一个字符串,用作 SQL 语句,该语句将被传递到 sqlite 的 FMDB 包装器中;但是,数据库会因 BAD_ACCESS 故障而崩溃。我有以下代码:

prefix = @"SELECT * FROM Table WHERE Field1 LIKE '%";

middle = @"%' 或 Field2 LIKE '%";

后缀=@"%'ORDERY BY";

orderby = @"%' ORDER BY 字段名称";

sqlStatement = [NSString stringWithFormat:@"%@%@%@%@%@%@", 前缀, searchString, 中间, searchString, 后缀, orderby];

在运行时,sqlStatement 最终包含如下内容:

SELECT * FROM Table WHERE Field1 LIKE\'%A%\' OR Field2 LIKE\'%A%\' ORDER BY 字段名称

由于某种原因,在字符串中添加了\,这导致数据库崩溃。

有什么想法可以防止\出现在我的字符串中吗?

更新: 当我通过 NSLog 输出变量时,我得到以下信息: SELECT * FROM Table WHERE Field1 LIKE 'OX1.87A8013DBD18F-1027' OR Field2 LIKE 'OX1.87A8013DBD18F-1027'ORDER BY 字段名。

问题似乎出在字符串中使用 %A 。即使我对 sqlStatement 变量进行硬编码以包含“%A%”,%A 似乎也会转换为内存地址或其他内容。如果我执行“%ABAP%”,我会得到类似“OX1.87A8013DBD18F-1027BAP”的输出。请注意,我失去了 % 符号。

最佳答案

我猜测您正在使用 sqlite,在这种情况下您需要稍微不同地执行此操作。首先像这样创建查询:

SELECT * FROM Table WHERE Field1 LIKE ?001 OR Field2 LIKE ?002 ORDER BY Fieldnames

?000 语法用于参数。

然后您可以使用 sqlite3_bind_text 来绑定(bind)您的参数:

sqlite3_bind_text(statement, 1, [@"%bar%" UTF8String], -1, SQLITE_STATIC);
sqlite3_bind_text(statement, 2, [@"%foo%" UTF8String], -1, SQLITE_STATIC); 

希望这能为您指明正确的方向。

关于cocoa - 在 Cocoa 中构建字符串时使用单引号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/614633/

相关文章:

java - 字符串到整数的转换

c - 向用户读入字符串,直到使用 "."

cocoa - Swift 构建失败 : target might include it's own product

macos - 不使用 NSMatrix 的单选按钮

objective-c - 如何获取 OS X 中复选框的值

java - 字符串修剪异常

macos - 如何在 OS X 下的视网膜/非视网膜屏幕上使用相同的方法加载不在资源目录中的图像?

macos - Cocoa OS X 绑定(bind)和重要数据模型

python - 去除字符串中的常见字母

c - 如何修改字符串并返回它?