JDK动态代理与mybatis sqlsession.getMapper()
在UserDao定义抽象方法后,可不用上述提到的写UserDaoImpl 实现类的方法来完成增删改查
<?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="Dao.UserDao">
<!-- id 为接口中查询方法的方法名 也可自定义
resultType:表示结果类型,遍历resultSet得到的java类型 ==全限定名称== !
-->
<select id="userList" resultType="entity.User">
select id,username,password from test01 order by id
</select>
<insert id="insertUser">
insert into test01 values (#{id},#{username},#{password})
</insert>
<delete id="deleteUser" >
delete from test01 where id=#{id}
</delete>
<select id="selectUserById" resultType="entity.User" parameterType="int">
select id,username,password from test01 where id=#{id}
</select>
<select id="selectUserByIdOrUsername" resultType="entity.User" >
select id,username,password from test01 where id=#{uid} or username=#{username}
</select>
</mapper>
测试类
import Dao.UserDao;
import entity.User;
import org.apache.ibatis.session.SqlSession;
import utils.MybatisUtils;
import java.io.IOException;
import java.util.List;
/**
* Created with IntelliJ IDEA.
*
* @Auther: 风离
* @Date: 2021/03/09/11:10
* @Description:
* 测试 mybatis动态代理
*/
public class Test2 {
public static void main(String[] args) throws IOException {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserDao userDao=sqlSession.getMapper(UserDao.class);
//System.out.println(UserDao.class.getName());
//List<User> list= userDao.userList();
//list.forEach(user -> System.out.println(user));
//System.out.println(userDao.selectUserById(777).toString());
userDao.selectUserByIdOrUsername(777,"风离").forEach(user -> System.out.println(user.toString()));
sqlSession.close();
}
}
按查找条件查询多条内容
动态代理概述
简单一句话,动态代理就是要生成一个包装类对象,由于代理的对象是动态的,所以叫动态代理。由于我们需要增强,这个增强是需要留给开发人员开发代码的,因此代理类不能直接包含被代理对象,而是一个InvocationHandler,该InvocationHandler包含被代理对象,并负责分发请求给被代理对象,分发前后均可以做增强。从原理可以看出,JDK动态代理是“对象”的代理。
版权声明:本文为CSDN博主「赵举飞」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/flyfeifei66/article/details/81481222