使用 '?' SQL LIKE语句中的参数

use*_*582 4 sql parameters excel firebird sql-like

初学者问题在这里......

我通过Excel中的Microsoft Query访问Firebird数据库.

我在Excel中有一个包含4位数字的参数字段.我的一个DB表有一个包含9位相位代码的列(TP.PHASE_CODE),我需要返回以指定为参数的4位数代码开头的9位数代码.

例如,如果我的参数字段包含'8000',我需要找到并返回LIKE'8000%'的另一个表/列中的任何阶段代码

我想知道如何在SQL中实现这一点,因为它看起来不像'?' 表示参数可以包含在LIKE语句中.(如果我用4位数字写,查询工作正常,但它不会让我在那里使用参数.)

有问题的陈述是这样的: TP.PHASE_CODE喜欢'?%'

这是我的完整代码:

SELECT C.COSTS_ID, C.AREA_ID, S.SUB_NUMBER, S.SUB_NAME, TP.PHASE_CODE, TP.PHASE_DESC,       TI.ITEM_NUMBER, TI.ITEM_DESC,TI.ORDER_UNIT,
C.UNIT_COST, TI.TLPE_ITEMS_ID FROM TLPE_ITEMS TI
INNER JOIN TLPE_PHASES TP ON TI.TLPE_PHASES_ID = TP.TLPE_PHASES_ID
LEFT OUTER JOIN COSTS C ON C.TLPE_ITEMS_ID = TI.TLPE_ITEMS_ID
LEFT OUTER JOIN AREA A ON C.AREA_ID = A.AREA_ID
LEFT OUTER JOIN SUPPLIER S ON C.SUB_NUMBER = S.SUB_NUMBER

WHERE (C.AREA_ID = 1 OR C.AREA_ID = ?) and S.SUB_NUMBER = ? and TI.ITEM_NUMBER = ? and **TP.PHASE_CODE like '?%'**

ORDER BY TP.PHASE_CODE
Run Code Online (Sandbox Code Playgroud)

有关完成此查询的其他方法的任何想法?

非常感谢!

Mar*_*eel 5

如果你使用`LIKE'?%',那么问号是文字文本,而不是参数占位符.

您可以使用LIKE ? || '%',或者如果您的参数本身从不包含LIKE模式:STARTING WITH ?如果您要查询的字段已编入索引,则可能更有效.