• 域名认证
  • 作品:144
  • 案例:19|
  • 教程:7743|
  • 资讯:880|
  • 资源:416|
  • 总访问量:1646030|

导航菜单
酷讯网络工作室_源码交易平台,源码商城,网站定制开发,免费模版下载,网络技术服务,游戏源码,站长教程欢迎你.
简单了解java ibatis #及$的区别和用法

简单了解java ibatis #及$的区别和用法

浏览次数:

作者: 淡淡的风

信息来源:

更新日期: 2022-01-05 10:40:20

文章简介

1、#和$两者含义不同#:会进行预编译,而且进行类型匹配;$:不进行数据类型匹配。示例:变量name的类型是string, 值是"张三"$name$ = 张三#name# ='张三'因此

  • 正文开始

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)能同时使用#和$的时候,最好用#

以上就是本文的全部内容,希望对大家的学习学习有所帮助,也希望大家多多支持我们。

收藏此文 ( ) 打赏本站

如果本文对你有所帮助请打赏本站

  • 打赏方法如下:
  • 支付宝打赏
    支付宝扫描打赏
    微信打赏
    微信扫描打赏

精彩评论