您的位置:首页 > 其它

ibatis 动态SQL like 的写法和 大于小于不等于的写法

2007-03-24 16:34 561 查看
visitdate >= #startvisitdate# and visitdate <= #endvisitdate# and visitpage_ip <> '/jsp/getstrip.jsp' and visitpage_ip != '/version/jsp/getstrip.jsp' group by visitpage_ip order by coun desc

在通常情况下iBATIS的参数在sqlmap中使用#param#的形式,参数名以'#'包着,但当使用sql的LIKE语句时就发生了问题,在单引号中无法使用#param#这种形式

当应用SELECT * FROM TABLE WHERE COL LIKE 'value%'时如果要把'value'以参数代替,可以把整个LIKE后面的字符串全改为参数,即 SELECT * FROM TABLE WHERE COL LIKE #param#,此时参数param的值为字符串"value%"。

但有时上面这种情况会使程序变复杂,所以用参数只代替'value'时就要碰到在单引号内使用参数的问题。这时是使用'$'将参数名包起来,即SELECT * FROM TABLE WHERE COL LIKE '$param$%',此时参数param的值就是字符串"value"。

在网上看到另一种方法,就是SELECT * FROM TABLE WHERE COL LIKE #param#||'%'。这个方法我试过了,同样有效,此时参数param的值同样是字符串"value"。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: