mybatis之动态代理

本文详细解析了MyBatis动态代理的四个核心规则,包括Mapper.xml的namespace与mapper接口全类名一致,方法名与statement id相同,输入参数类型匹配,以及输出参数类型一致。通过具体代码示例,深入理解MyBatis动态代理的工作原理。
摘要由CSDN通过智能技术生成

mybatis的动态代理需要写相关的mapper接口(Dao),它有如下的规则:

1、Mapper.xml文件中的namespace与mapper接口的全类名相同。
2、Mapper接口方法名和Mapper.xml中定义的每个statement的id相同。
3、Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同。
4、Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同。

是什么意思呢?先看第一条,代码如下,先创建一个mapper的dao接口。

package com.dao;

import java.util.List;

import com.pojo.QueryVo;
import com.pojo.User;

public interface UserDao {
	
}

然后创建mapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper 
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.dao.UserDao">
</mapper>

可以看到namespace的类如就是指的是创建的Maper的dao接口。

再看第二条,先看如下代码代码。

先看dao接口

package com.dao;

import java.util.List;

import com.pojo.QueryVo;
import com.pojo.User;

public interface UserDao {
	public int findUser(User user);

}

再看mapper配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper 
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.dao.UserDao">
	<insert id="findUser" parameterType="com.pojo.User" >
		insert into user(id,username,sex,birthday,address) values(#{id},#{username},#{sex},#{birthday},#{address}) 
	</insert>
</mapper>

可以看到<insert/> biao标签中的id 属性的内容和dao中的方法名称相同。

再看第三条,同样的上面的代码。dao中的输入参数是User类型,mapper.xml中的输入参数也是User 类型。

再看第四条。代码如下

package com.dao;

import java.util.List;

import com.pojo.QueryVo;
import com.pojo.User;

public interface UserDao {
	public List<User> findUserByIdsa(List<Integer> integers) ;
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper 
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.dao.UserDao">
    <sql id="selectUserAll">
		select * from user 
	</sql>
<select id="findUserByIdsa" resultType="User">
		<include refid="selectUserAll"></include>
			<where>
				id in
				<foreach collection="list" open="(" close=")" item="id" separator=",">
			#{id}
		</foreach>
			</where>
	</select>
</mapper>

可以看到mapper.xml中的返回类型是User ,dao中接受的为LIst的User 类型。

 

下面是测试代码。

public void One() throws IOException{
		String resource = "mybatis.comfiguration.xml" ;
		InputStream in = Resources.getResourceAsStream(resource);
		SqlSessionFactory builder = new SqlSessionFactoryBuilder().build(in);
		SqlSession session = builder.openSession();
		User user = new User();
		user.setId(3);
		user.setBirthday(new Date());
		user.setSex("男");
		user.setUsername("刘");
		user.setAddress("伤害");
		session.getMapper(UserDao.class).findUser(user);
		session.commit();
		session.close();
	}

这是insert 的代码

public void Arraylist() throws IOException{
		String resource = "mybatis.comfiguration.xml" ;
		InputStream is = Resources.getResourceAsStream(resource);
		SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
		SqlSession session = factory.openSession();
		List<Integer> integers = new ArrayList<Integer>();
		integers.add(1) ;
		integers.add(2) ;
		integers.add(3) ;
		List<User> user = session.getMapper(UserDao.class).findUserByIdsa(integers);
		for (User user2 : user) {
			System.out.println(user2);
		}
	}

这是select的代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>