全部,
我将 SQL 查询存储为我的 java 应用程序的 XML 以提高可维护性。
我的部分查询需要参数化,因此我创建了可以在创建查询字符串时用值替换的标识符。
例如
WHERE CB.callback_date >= TO_DATE('$LASTDATE$','DD/MM/YYYY')
AND CB.callback_date < TO_DATE('$FROMDATE$','DD/MM/YYYY')
我的应用程序中有一个函数可以替换这些子字符串。
public static String xmlQueryPrep(String prep)
{
//add dates to query
prep.replace("'$LASTDATE$'", "'20/10/2013'");
prep.replace("'$FROMDATE$'", "'18/10/2013'");
prep.replace("<", "<").replace(">", ">");
return prep;
}
出于某种原因,它正在替换 < 和 > 的 ASCII 代码,但它没有替换我的标记
输出
WHERE CB.callback_date >= TO_DATE('$LASTDATE$','DD/MM/YYYY')
AND CB.callback_date < TO_DATE('$FROMDATE$','DD/MM/YYYY')
为什么不能正确更换?