<mapper namespace="cn.smbms.dao.user.UserMapper">
select语句有很多属性可以详细配置每一条语句
id
parameterType
resultType
resultMap:数据库字段信息与对象属性不一致;复杂的联合查询
resultMap自动映射匹配前提:字段名column与属性名property一致
resultMap的自动映射级别(autoMappingBehavior)三个匹配级别:
PARTIAL(默认):自动匹配所有属性,内部嵌套除外
NONE:禁止自动匹配
FULL:自动匹配所有
<settings>
<setting name="autoMappingBehavior" value="NONE"/>
settings>
resultMap与resultTypeu二者不能同时存在,本质上都是Map数据结构
属性 | 描述 |
---|---|
id | 在命名空间中唯一的标识符,可以被用来引用这条语句 |
parameterType | 将会传入这条语句的参数类的完全限定名或别名 |
resultType | 从这条语句中返回的期望类型的类的完全限定名或别名。注意集合情形,那应该是集合可以包含的类型,而不能是集合本身。使用resultType或resultMap,但不能同时使用 |
resultMap | 命名引用外部的resultMap |
flushCache | 将其设置为true,不论语句什么时候被调用,都会导致缓存被清空。默认值:false |
useCache | 将其设置为true,将会导致本条语句的结果被缓存。默认值:true |
timeout | 这个设置驱动程序等待数据库返回请求结果,并抛出异常时间的最大等待值。默认不设置(驱动自行处理) |
fetchSize | 这是暗示驱动程序每次批量返回的结果行数 |
statementType | STATEMENT,PREPARED或CALLABLE的一种。让MyBatis选择使用Statement,PreparedStatement或CallableStatement。默认值:PREPARED |
resultSetType | FORWARD_ONLY|SCROLL_SENSITIVE|SCROLL_INSENSITIVE中的一种。默认是不设置(驱动自行处理) |
<insert id="add" parameterType="User" >
insert into smbms_user (userCode,userName,userPassword)
values ( #{userCode},#{userName},#{userPassword})
insert>
注意:insert、update、delete元素均没有resultType属性
<update id ="modify" parameterType="User">
update smbms_user
set userCode = #{userCode},
userName = #{userName},
userPassword = #{userPassword}
where id = #{id}
update>
<delete id ="deleteUserById" parameterType="int">
delete from smbms_user where id = #{id}
delete>
DAO层接口方法常见的返回类型
Java对象、Map、List等复杂数据类型
int:(增删改)更新操作时,影响的数据行数
MyBatis参数入参
resultMap属性
resultMap子元素
id:一般对应数据库中该行的主键id,设置此项可提高MyBatis性能
result:映射到JavaBean的某个“简单类型”属性
association:映射到JavaBean的某个“复杂类型”属性,比如JavaBean类
复杂的类型关联,一对一
内部嵌套:映射一个嵌套JavaBean属性
属性:
property:映射数据库列的实体对象的属性
javaType:完整Java类名或者别名
resultMap:引用外部resultMap
子元素:
id
result:property、column
collection:映射到JavaBean的某个“复杂类型”属性,比如集合
一个订单对应一个用户
//接口:
public User findAll();
一个用户会有多个订单List
//接口:
public List findAll();
实体类
:User中有角色Id连接角色表(一个用户一个地址);有用户Id连接地址表(一个用户多个收获地址)
……
private Role role; //Role整个类封装,一对一
private List<Address> addressList; //Address的封装,一对多
dao:
public User findUserById(Integer id);
public User findAddressListUser(Integer id);
Mapper.xml
<resultMap id="UserMap" type="User">
<id property="id" column="id">id>
<result property="userName" column="userName">result>
<result property="userPassword" column="userPassword">result>
<association property="role" javaType="Role">
<id property="id" column="id">id>
<result property="roleName" column="roleName">result>
association>
resultMap>
<select id="findUserById" resultMap="UserMap">
select a.id, userName, userPassword, b.roleName
from smbms_user a LEFT JOIN smbms_role b ON a.userRole = b.id
where a.id=#{id}
select>
<resultMap id="UserAddress" type="User">
<id property="id" column="id">id>
<result property="userName" column="userName">result>
<result property="userPassword" column="userPassword">result>
<collection property="addressList" ofType="Address">
<id property="id" column="addrid">id>
<result property="addressDesc" column="addressDesc">result>
<result property="contact" column="contact">result>
collection>
resultMap>
<select id="findAddressListUser" resultMap="UserAddress">
select a.id, userName, d.id as addrid, d.addressDesc, d.contact
from smbms_user a LEFT JOIN smbms_address d ON a.id = d.userId
where a.id=#{id}
select>
测试类:
@Test
public void findUserById() {
SqlSession sqlSession = MyBatisUtil.createSqlSession();
UserDao userDao = sqlSession.getMapper(UserDao.class);
User user = userDao.findUserById(1);
System.out.println("输出=====================");
System.out.println("用户名:\t\t用户密码:\t用户角色:\t");
System.out.println(user.getUserName()+"\t"+user.getUserPassword()+"\t\t"+user.getRole().getRoleName());
MyBatisUtil.closeSqlSession(sqlSession);
}
@Test
public void findAddressListUser() {
SqlSession sqlSession = MyBatisUtil.createSqlSession();
UserDao userDao = sqlSession.getMapper(UserDao.class);
User user = userDao.findAddressListUser(1);
for(Address address : user.getAddressList()) {
System.out.println("该用户的地址有:"+address.getAddressDesc());
}
MyBatisUtil.closeSqlSession(sqlSession);
}
`