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)
有关完成此查询的其他方法的任何想法?
非常感谢!
如果你使用`LIKE'?%',那么问号是文字文本,而不是参数占位符.
您可以使用LIKE ? || '%',或者如果您的参数本身从不包含LIKE模式:STARTING WITH ?如果您要查询的字段已编入索引,则可能更有效.