我正在通过 Excel 中的 Microsoft Query 访问 Firebird 数据库。
我在 Excel 中有一个包含 4 位数字的参数字段。我的一个 DB 表有一列 ( TP.PHASE_CODE
),其中包含 9 位相位代码,我需要返回以指定为参数的 4 位代码开头的任何 9 位代码。
例如,如果我的参数字段包含“8000”,我需要在另一个表/列中查找并返回任何相位代码,即LIKE '8000%'
.
我想知道如何在 SQL 中完成此操作,因为它看起来不像“?” 表示参数可以包含在 LIKE 语句中。(如果我输入 4 位数字,查询工作正常,但它不会让我在那里使用参数。)
有问题的陈述是这样的: TP.PHASE_CODE like '?%'
这是我的完整代码:
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
关于完成此查询的替代方法的任何想法?