JAVA框架 Mybaits 动态代理
一、动态代理:
mybaits给咱们提供一套动态代理,我们只需要按他的要求写接口即可,mybatis帮做动态代理,相当于咱们写的接口的实现类。底层通过反射实例化代理对象,通过代理对象调用相应的方法,
执行相应的数据库语句。
接口:
package jd.com.proxydao; import jd.com.mybaitstest.account; import java.io.IOException;
import java.util.List; public interface AccMapper {
List<account> selectDemo(String name) throws IOException;
void updateDemo(account ac) throws IOException;
}
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="jd.com.proxydao.AccMapper" >
<select id="selectDemo" resultType="jd.com.mybaitstest.account" parameterType="java.lang.String" > SELECT * FROM t_account WHERE NAME LIKE '%${value}%';
</select>
<insert id="updateDemo" parameterType="jd.com.mybaitstest.account"> <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer"> SELECT LAST_INSERT_ID();
</selectKey>
INSERT INTO t_account(NAME ,money) VALUES(#{name},#{money});
</insert>
</mapper>
注意:
mapper文件和接口的对应的关系:
1)mapper文件的namespace的值和接口的相对路径一致。
2)mapper文件的id值和接口的方法的名字一致。
3)mapper的resultType的返回类型和对应的方法的返回值类型一致,没有resultType的话,那方法的返回值为void。
4)mapper文件的parameterType的参数类型和方法的参数类型一致。
5)mapper文件和接口需要在同一目录下。
需要注意:mapper文件和接口在同一个目录中!
测试代码:
package jd.com.proxydao; import jd.com.mybaitstest.account;
import jd.com.Utils.session;
import org.apache.ibatis.session.SqlSession;
import org.junit.jupiter.api.Test; import java.io.IOException;
import java.util.List; public class TestDemo {
@Test
public void testdemo1() throws IOException {
SqlSession sqlSession=session.getSession();
AccMapper ac=sqlSession.getMapper(AccMapper.class);
List<account> acc1=ac.selectDemo("ok");
account acz=new account();
acz.setId();
acz.setMoney();
ac.updateDemo(acz);
sqlSession.commit();
sqlSession.close();
System.out.println("acc1 = " + acc1);
}
}
工具类:
package jd.com.Utils; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.IOException;
import java.io.InputStream; public class session {
private static SqlSessionFactory sqlSessionFactory; public static SqlSession getSession(){
String resource="SqlMapConfig.xml";
try {
InputStream inp= Resources.getResourceAsStream(resource);
sqlSessionFactory= new SqlSessionFactoryBuilder().build(inp);
SqlSession sqlSession=sqlSessionFactory.openSession();
return sqlSession;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}
问题汇总:
如果你使用的maven进行开发的时候,因为maven的资源目录:resources目录下。这是会抛出:
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): jd.com.proxydao.AccMapper.selectDemo 错误。
我们看下maven编译完打包的target目录:
没有我们写的AccMapper.xml,编译的时候没有把我们mapper文件编译进去。需要在pom.xml添加如下配置:
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
</resources>
在次运行的时候我们看下:
我们mapper文件编译到相应的目录下面。
总结:
1)动态代理对象在调用sqlsession.selectone()和 sqlsession.seleclist(),是根据sql执行的返回值决定,如果返回值是list就用selectlist反之selectone。
2)mybaits官方推荐使用mapper代理方法来开发mapper接口,程序不用开发接口实现类。使用mapper接口,可以使用pojo对象来传入参数。
JAVA框架 Mybaits 动态代理的更多相关文章
- JAVA框架 Mybaits 动态sql
动态sql 一:if标签使用: 我们在查询的时候,有时候由于查询的条件的不确定性,导致where的后面的条件的不同,这时候就需要我们进行where后面的条件进行拼接. Mapper配置文件: < ...
- Java 反射 设计模式 动态代理机制详解 [ 转载 ]
Java 反射 设计模式 动态代理机制详解 [ 转载 ] @author 亦山 原文链接:http://blog.csdn.net/luanlouis/article/details/24589193 ...
- 杨晓峰-Java核心技术-6 动态代理 反射 MD
目录 第6讲 | 动态代理是基于什么原理? 典型回答 考点分析 知识扩展 反射机制及其演进 动态代理 精选留言 Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAnd ...
- 深度剖析java中JDK动态代理机制
https://www.jb51.net/article/110342.htm 本篇文章主要介绍了深度剖析java中JDK动态代理机制 ,动态代理避免了开发人员编写各个繁锁的静态代理类,只需简单地指定 ...
- JavaWeb_(Mybatis框架)Mapper动态代理开发_三
系列博文: JavaWeb_(Mybatis框架)JDBC操作数据库和Mybatis框架操作数据库区别_一 传送门 JavaWeb_(Mybatis框架)使用Mybatis对表进行增.删.改.查操作_ ...
- 一文读懂Java中的动态代理
从代理模式说起 回顾前文: 设计模式系列之代理模式(Proxy Pattern) 要读懂动态代理,应从代理模式说起.而实现代理模式,常见有下面两种实现: (1) 代理类关联目标对象,实现目标对象实现的 ...
- 使用Java中的动态代理实现数据库连接池
2002 年 12 月 05 日 作者通过使用JAVA中的动态代理实现数据库连接池,使使用者可以以普通的jdbc连接的使用习惯来使用连接池. 数据库连接池在编写应用服务是经常需要用到的模块,太过频繁的 ...
- java 笔记(3) —— 动态代理,静态代理,cglib代理
0.代理模式 代理模式是常用的java设计模式,他的特征是代理类与委托类有同样的接口. 代理类主要负责为委托类预处理消息.过滤消息.把消息转发给委托类,以及事后处理消息等. 代理类与委托类之间通常会存 ...
- java中的动态代理机制
java中的动态代理机制 在java的动态代理机制中,有两个重要的类或接口,一个是 InvocationHandler(Interface).另一个则是 Proxy(Class),这一个类和接口是实现 ...
随机推荐
- 获取本机的ip地址(排除虚拟机,蓝牙等ip)
项目中遇到了要获取本地ip的需求,网上查找资料遇到很多坑,很多Java获取本机ip地址的方法要么是根本获取不到,要么是获取的有问题. 网上常见的方法如下 InetAddress.getLocalHos ...
- POJ3436(KB11-A 最大流)
ACM Computer Factory Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8133 Accepted: 2 ...
- PHP 协程最简洁的讲解
协程,又称微线程,纤程.英文名Coroutine.协程的概念很早就提出来了,但直到最近几年才在某些语言(如Lua)中得到广泛应用. 子程序,或者称为函数,在所有语言中都是层级调用,比如A调用B,B在执 ...
- page、request、session和application有什么区别?
转自:http://liuyuru.iteye.com/blog/773367 1.简单说 page指当前页面.在一个jsp页面里有效 2.request 指从http请求到服务器处理结束,返回响应的 ...
- BCG库的一个bug
作者:朱金灿 来源:http://blog.csdn.net/clever101 同事在使用BCG库图表组件(BCG库的版本为BCGCBPRO1510)时遇到一个问题,就是图表标题总是出现乱码, ...
- Python学习笔记之——requests库
requests库一个优雅而简单的用于Python的HTTP库,可以极大的简化我们发送http请求及获取响应的代码. requests是python的第三方库,所以使用之前需要先安装. 1.安装之后就 ...
- MariaDB MySQL变量取值避免四舍五入的方法
MySQL变量取值避免四舍五入的方法 By:授客 QQ:1033553122 在一些对数据精确度要求比较高的场景(比如资金结算)下,变量取值时不能对变量值进行四舍五入操作,这时候就要做些预处理工作. ...
- 关于SQLSERVER走起公众帐号推送视频的通知
关于SQLSERVER走起公众帐号推送视频的通知 为了SQLSERVER走起这个微博帐号和微信帐号更加多样化,内容更加丰富 也为了发挥微信.微博的媒介传播威力,在以后的微博.微信每日推送中会在适当的时 ...
- [SQLSERVER] 把TransactionLog截断
注意:以下语句非常危险 --BACKUP LOG MyDb TO DISK=’NUL:’
- mysql中InnoDB表为什么要建议用自增列做主键
InnoDB引擎表的特点 1.InnoDB引擎表是基于B+树的索引组织表(IOT) 关于B+树 (图片来源于网上) B+ 树的特点: (1)所有关键字都出现在叶子结点的链表中(稠密索引),且链表中的关 ...