从印度兵力分布聊聊Mybatis中#和$的区别
简介
大家在使用Mybatis的过程中可能都会自己去写SQL语句,并且需要向SQL语句传入参数。
但是在Mybatis中,传参的语法有两种,#{name} 和 ${name},两者有什么区别呢?一起来看看吧。
举个例子
最近印度比较嚣张,频繁挑起边境冲突,那么印度是不是这么有底气呢?
我们看一下印度的兵力分布表:
其实印度军队还是挺强大的,是南亚的顶级军事强国。他拥有世界第三规模的现役部队,并且其陆军规模是世界第二。
印度是世界最大的武器进口国,进口当然有利有弊,弊端就是本国的武器研发实力不强。当然印度是世界上少数拥有核武器的国家。
查询举例
好了,有了印度的兵力分布表之后,我们怎么在mybatis中编写sql语句通过编号来查询印度的兵力分布呢?
<select id="getIndiaTroopsById" resultType="com.flydean.IndiaTroop">
select * from troops t
where t.id =#{id}
</select>
大家一般都会像上面那样编写查询sql语句。
上面我们使用了#{id}作为传递的参数。那么#{id}有什么特点呢?
#{id}的特点
首先,#{id}表示传递过来的id是String格式的,比如我传递过来的id=2,那么sql语句将会被解析为:
select * from troops t where t.id = '2'
第二,#{id}是会经过预编译的,也就是说上面的sql语句会会动态解析成一个参数标记符?:
select * from troops t where t.id = ?