ibatis 中 $与#的区别

1、在Ibatis中我们使用SqlMap进行Sql查询时需要引用参数,在参数引用中遇到的符号#和$之间的区分为,#可以进行与编译,进行类型匹配,而$不进行数据类型匹配。
2、对于变量部分,应当使用#,这样可以有效的防止sql注入,未来,#都是用到了prepareStement,这样对效率也有一定的提升。
3、$中间的变量就是直接替换成值的。#会根据变量的类型来进行替换。
    比如:title的类型是string,值是"标题"的时候。
   $title$ = 标题,#title# = '标题'。
4、$只是简单的字符拼接而已,对于非变量部分,那只能使用$,实际上,在很多场合,$也是有很多实际意义的。
    例如:select * from $tableName$ 对于不同的表执行统一的查询。
          update $tableName$ set status = #status# 每个实体一张表,改变不用实体的状态。
特别提醒一下, $只是字符串拼接, 所以要特别小心sql注入问题。

;