温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java ibatis #及$的区别和用法是什么

发布时间:2020-10-30 15:35:58 来源:亿速云 阅读:143 作者:Leah 栏目:开发技术

java ibatis #及$的区别和用法是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

1、#和$两者含义不同

#:会进行预编译,而且进行类型匹配;

$:不进行数据类型匹配。

示例:变量name的类型是string, 值是"张三"

$name$ = 张三
#name# ='张三'

因此使用$就会报错,若要使用$的话,需要修改为'$name$';

2、两者的实现方式不同

2.1)$ 作用相等于是字符串拼接,

select * from users where name= $name$

等效于

StringBuffer sb = newStringBuffer(256);
sb.append("select * from users where name=").append(name);
sb.toString();

2.2)# 作用相当于变量替换

select * from users where name = #name#

等效于

prepareStement=stmt.createPrepareStement("select * from users where name = ?")
prepareStement.setString(1,'张三');//自动进行java类型和jdbc类型转换

3、#和$使用场景不同

3.1)变量的传递,必须使用#。可以防止sql注入,#是用prepareStement,提示效率

#方式一般用于传入添加/修改的值或查询/删除的where条件

3.2)$只是简单的字符拼接而已,对于非变量部分,那只能使用$,实际上,在很多场合,$也是有很多实际意义的

$方式一般用于传入数据库对象(如传入表名)

例如:

  • select * from $tableName$ 对于不同的表执行统一的查询
  • update $tableName$ set name = #name# 每个实体一张表,改变不用实体的状态特别说明,$只是字符串拼接,所以要特别小心sql注入问题。

3.3)能同时使用#和$的时候,最好用#

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI