比较 Coldfusion cfquery 中的两个字符值

Comparing two character values in a Coldfusion cfquery

我有一个数据库字段,其中包含 VARCHAR 个值,例如

XY23(CX Web)

我正在写一个类似

的查询
SELECT qPdfs.filename, qPdfs.code, qObjects.id
FROM qPdfs, qObjects
WHERE qPdfs.code = qObjects.code

或喜欢

SELECT qPdfs.filename, qPdfs.code, qObjects.id
FROM qPdfs, qObjects
WHERE <cfqueryparam value="#qObjects.code#" cfsqltype="CF_SQL_VARCHAR"> = <cfqueryparam value="#qPdfs.code#" cfsqltype="CF_SQL_VARCHAR">

但我收到一条错误消息,例如

XY23(CX Web) must be interpretable as a valid number in the current locale.

有什么帮助吗?

谢谢

两个数据库列的类型都是varchar吗?如果是这样,则 QoQ 可能会根据列的内容应用一些隐式转换。如果某些代码都是数字,则 QoQ 可能会在执行比较之前尝试在内部将它们转换为数字。因此错误。 cfqueryparam 在这里无济于事,因为它只能用于文字,不能用于查询列。如果直接相等比较即 ColName = ColName 导致该错误,请尝试强制转换:

WHERE CAST(qPdfs.code AS VARCHAR) = CAST(qObjects.code AS VARCHAR)

注意:QoQ 字符串比较区分大小写,因此您可能希望先将列转换为 upper/lower 大小写。