ibatis中的like用法

sweat89 2012-12-01 12:38:51
比如:
select * from emp where title like '%$title$%'
能查出结果,但是你懂得,有sql injection。

换这种:
select * from emp where title like '%' || #title# || '%'

日志打印出来的SQL是:
select * from emp where title like '%' || ? || '%'

在线等。。。
...全文
148 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
sweat89 2012-12-01
  • 打赏
  • 举报
回复
引用 3 楼 Whu_benluobo 的回复:
select * from emp where title like '%$title$%' 能查出结果,但是你懂得,有sql injection。 ibatis不会有SQL注入 楼主写的就是对的 就这么用没问题的
好像会有注入的哦。。
sweat89 2012-12-01
  • 打赏
  • 举报
回复
呵呵,找到原因了。 我用的是mysql,而mysql的字符串连接操作是用concat而非 ||
Whu_benluobo 2012-12-01
  • 打赏
  • 举报
回复
select * from emp where title like '%$title$%' 能查出结果,但是你懂得,有sql injection。 ibatis不会有SQL注入 楼主写的就是对的 就这么用没问题的
sweat89 2012-12-01
  • 打赏
  • 举报
回复
引用 1 楼 xingfuzhuzi1314 的回复:
我就是用的select * from emp where title like '%' || #title# || '%' ,LZ你不能查询出结果吗? sqlid的参数类型,一般都是Map,或者StringJava code??123456789101112131415<select id="getAddressPoolConfigCount" resultClas……
我的参数不是MAP,是parameterClass,按理说它会调用VO的getTitle方法取值吧。跟参数无关吧
xingfuzhuzi1314 2012-12-01
  • 打赏
  • 举报
回复
我就是用的select * from emp where title like '%' || #title# || '%' ,LZ你不能查询出结果吗? sqlid的参数类型,一般都是Map,或者String
<select id="getAddressPoolConfigCount" resultClass="Integer"
		parameterClass="Map">
		select count(*) from TMS_ADDRESS_POOL_CONFIG tapc, SYS_CITY
		sc,SYS_PROVINCE sp where tapc.PROVINCE_ID = sp.PROVINCE_ID and
		tapc.CITY_ID = sc.CITY_ID
		<isNotEmpty prepend="AND" property="provinceId">
			tapc.PROVINCE_ID like '%' || #provinceId#|| '%'
		</isNotEmpty>
		<isNotEmpty prepend="AND" property="cityId">
			tapc.CITY_ID like '%' || #cityId#|| '%'
		</isNotEmpty>
		<isNotEmpty prepend="AND" property="configFlag">
			tapc.CONFIG_FLAG like '%' || #configFlag#|| '%'
		</isNotEmpty>
	</select>

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧