Flutter开发App的未来及其在各行业的应用潜力分析
1718
2023-03-05
Mybatis 动态表名+Map参数传递+批量操作详解
需求:
之前项目一个变动,需要对3张mysql数据库表数据进行清洗,3张表表名不同,表结构完全相同,需要对这3张表进行相同的增、改、查动作,一开始比较紧急先对一张表进行操作,后来复制了3个一样的 service、dao、mapper等。后来对代码进行优化,研究了一下动态表名的处理。
1,查询操作:
查询操作只需要传入动态表名的时候,传递参数仍然是map
mapper.xml内,需要使用statementType="STATEMENT",采用非预编译模式
mapper.xml内,动态表名的获取使用 ${tableName}
2,批量插入操作:
查询操作只需要传入动态表名的时候,传递参数仍然是map
mapper.xml内,不需要使用statementType="STATEMENT",否则会在运行时报错提示语法错误(具体原因不是很清楚)。
动态表名的获取使用 ${tableName}, 而insert 的 collection 属性名为传入参数的map内的key名,不需要任何修饰符。
list内容使用 #{item.guid}来获取,而不是$。
补充知识:mybatis动态传入表名并返回map,返回空间点的坐标
mybatis学习中
动态传入表名并返回某几个字段map,取某个空间表的shape字段的坐标。代码如下
xml文件
select t.shape.minx as X,t.shape.miny as Y from ${sourceObj} t where OBJECTID = ${featureId}
&lhttp://t;/select>
注意statementType必须,且值必须是大写的STATEMENT,参数传入为多个,用map。
dao文件
public void selectLocByPK(String sourceObj, Long featureId) {
params.put("sourceObj", "sde."+sourceObj);
params.put("featureId", featureId);
Map map = this.getSqlSessionTemplate().selectOne("selectLocationByPrimaryKey", params);
Double x = (Double)map.get("X");
Double y = (Double)map.get("Y");
System.out.println(x+","+y);
}
注意查http://询的是sde用户下的表名是参数传递的sourceObj,因为用其他用户连接的数据库 所以查询其他用户下的表的时候必须用用户名加表名。当然前提你这个用户有查询其他用户表的权限。params类型是HashMap。xml文件中取值时候必须要跟此地方绑定的key值一直,不然取到为null.此处key为xml文件的时候查询列的别名。
只是一条数据,多条数据可以用selectList 方法 返回List ,xml基本不用变。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~