博客
关于我
每日总结[5 20191005]MyBatis之输入输出映射
阅读量:324 次
发布时间:2019-03-04

本文共 1592 字,大约阅读时间需要 5 分钟。

(1)头脑风暴,把我能想到的写下来:

(一) 输入输出映射部分。

先复习通过动态代理的方式实现Mybatis:

首先,新建Mapper包,其下有UserMapper接口和同名的UserMapper.xml,在SqlMapConfig.xml中写<mapper package="xxx.xx.Mapper">,进行包扫描。在接口中的方法需要与UserMapper.xml中的statement一致。
新建UserEx类,(扩展类,用于后续添加属性),和UserPacking类(包装类),其中有UserEx类型的UserEx属性。
接下来,通过Mybatis实现一些select需求:
需求1:
sql语句: select * from user where sex='1' and username like '%vin%'
如果我们不传入"1"和"%vin%"的参数,想执行全查呢,可以使用<if>标签。如果传入了性别参数就按性别参数查,如果传入了姓名参数还可以按姓名参数模糊查询,如果不传参数的话就全查。
在UserMapper.xml中写:

[改: and username like ‘%${userEx.username}%’]

因为userex是userPacking类的属性,所以<if test>中是可以通过getter方法读取到它的。

可以把上述的判断模块提出来,提取需要注意:不能有<where>,不能是多表查询:

usersex=#{ userex.sex}
and username like '$%userex.name%'

[补充:

sql语句:select count() from user where…可以用来统计元组个数]*

需求2:

sql语句:

select* from user where id='1' or id='2' or id='3'

因为这会涉及多个id,可以在UserPacking类中添加List ids属性,这样就可以通过传入UserPacking类,由它的getter方法获取ids属性,再通过标签,如下所示:

[改:

]

这时如果提到<sql>中,需要让<if test="ids!=null">

还有一种写法:
sql语句:

select * from user where userid in('1','2','3');

对应的:

[改:

]

需求三:

sql语句:select userid as myID,username as myname,useradress as myadress
其中,"as"是可以省略的。
这里就需要要到resultMap了。

以上所示的对应的是我们在sql语句中写的那个列名的别名,而type则是映射以后的类,而对应的是映射成的类的属性。(注意:这里必须是直接拥有的,可以通过getter方法获得的,不能是其父类的属性。)

在单元测试中输出得到的User类集合,它每个对象都会输出对应属性。

转载地址:http://qbjh.baihongyu.com/

你可能感兴趣的文章
NET3.0+中使软件发出声音[整理篇]<转>
查看>>
net::err_aborted 错误码 404
查看>>
NetApp凭借领先的混合云数据与服务把握数字化转型机遇
查看>>
NetAssist网络调试工具使用指南 (附NetAssist工具包)
查看>>
Netbeans 8.1启动参数配置
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
NetBeans之JSP开发环境的搭建...
查看>>
NetBeans之改变难看的JSP脚本标签的背景色...
查看>>
netbeans生成的maven工程没有web.xml文件 如何新建
查看>>
netcat的端口转发功能的实现
查看>>
NetCore 上传,断点续传,可支持流上传
查看>>
Netcraft报告: let's encrypt和Comodo发布成千上万的网络钓鱼证书
查看>>
Netem功能
查看>>
netfilter应用场景
查看>>
Netflix:当你按下“播放”的时候发生了什么?
查看>>
Netflix推荐系统:从评分预测到消费者法则
查看>>
netframework 4.0内置处理JSON对象
查看>>
Netgear WN604 downloadFile.php 信息泄露漏洞复现(CVE-2024-6646)
查看>>
Netgear wndr3700v2 路由器刷OpenWrt打造全能服务器(十一)备份
查看>>
netlink2.6.32内核实现源码
查看>>