首页 技术 正文
技术 2022年11月6日
0 收藏 649 点赞 646 浏览 898 个字

例如:

···

insert into TEST1(
<if test="base_id!=null and base_id!=''">
base_id,
</if>
<if test="name!=null and name!=''">
name,
</if>
<if test="age!=null and age!=''">
age,
</if>
<if test="address!=null and address!=''">
address,
</if>
<if test="year!=null and year!=''">
year
</if>
) VALUES (
<if test="base_id!=null and base_id!=''">
#{base_id},
</if>
<if test="name!=null and name!=''">
#{name},
</if>
<if test="age!=null and age!=''">
#{age},
</if>
<if test="address!=null and address!=''">
#{address},
</if>
<if test="year!=null and year!=''">
to_date(#{year},'yyyy-MM-dd HH24:mi:ss')
</if>
)

···

这样的代码可以用如下的方式在mybatis的Provider里面使用:

InsProvider.kt:

fun insertCommonByParamMap(paramMap: HashMap<String, *>): String {
return "<script>" + paramMap.get("sql").toString() + "</script>"
}
把SQL和参数全部放到Map里面,mybatis会自动解析出来

Mapper文件里如下方式调用:
@InsertProvider(type = InsProvider::class, method = "insertCommonByParamMap")
fun insertCommonByParamMap(paramMap: HashMap<String, *>): Int

java代码与kotlin相似,这里不再赘述
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,088
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,564
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,413
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,186
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,822
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,905