Mybatis笔记二:接口式编程
旧方法的弊端
在Mybatis笔记一中,我们使用命名空间+id的方式实现了Mybatis的执行,不过这里的命名空间是我们随便写的,id也是随意写的,这种方式其实是有弊端的,例如我们在执行的时候用的这个
list =sqlSession.selectList("Message.selectOneMessage",1);
这里有一个不好的地方,第二个参数是Object类型的,我们输入1,但是没办法保证类型安全,没办法保证其他人调用的时候也输入Integer类型,所以这次,我要换一个类型安全的方式,接口式编程
接口式编程
使用接口,首先我们要新建一个接口,我起名为MessageMapper
package com.vae.springboot.study.mapper;
import com.vae.springboot.study.bean.Message;
public interface MessageMapper {
public Message getMsgById(Integer id);
}
有了接口之后,我们的Message.xml类的配置文件需要和接口进行绑定一下
首先,namespace从自定义的 Message换成了接口的地址
其次,每个语句Id换成了接口的名称,而不是随意写的了,更换之后的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 -->
<mapper namespace="com.vae.springboot.study.mapper.MessageMapper">
<!--
数据库查询数据
insert、select、delete、update:sql语句类型
id:sql语句唯一标识
resultType:结果返回值类型-包名+类名 或 基本数据类型
parameterType:匹配字段值-包名+类名 或 基本数据类型
-->
<select id="getMsgById" parameterType="com.vae.springboot.study.bean.Message" resultType="com.vae.springboot.study.bean.Message">
select * from message where ID=#{ID}
</select>
</mapper>
可以对比笔记一发现,我们更改,只改了两个地方
<mapper namespace="com.vae.springboot.study.mapper.MessageMapper">
<select id="getMsgById" parameterType="com.vae.springboot.study.bean.Message" resultType="com.vae.springboot.study.bean.Message">
select * from message where ID=#{ID}
</select>
namespace和id
最后,我们来调用一下,SqlSessionFactory使用的频率太高了,所以上一篇我已经介绍了,封装成DBAcess类了
@Test
public void getOneNew() throws IOException {
DBAcess dbAcess=new DBAcess();
SqlSession sqlSession = dbAcess.getSqlSession();
try {
MessageMapper mapper =sqlSession.getMapper (MessageMapper.class);
Message message=mapper.getMsgById(1);
System.out.println(mapper);
System.out.println(message.getId()+message.getCommand()+message.getDescription());
}finally {
sqlSession.close();
}
执行一下,结果也是ok的,这里需要解释一下
我们使用的是接口,接口怎么可能调用方法呢?原因是自动的帮我们生成了一个实现类:代理对象
可以看看我执行后输出的结果
org.apache.ibatis.binding.MapperProxy@38d08cb5
1查看精彩内容
Proxy代理类。
接口式编程的好处
- 返回值确定
- 参数确定,我写Integer,你就只能传入Integer
- 我不仅可以使用Mybatis,也可以使用Hibernate或者其他的工具,耦合度降低了
接口式编程的增删改查
上面我演示了接口式编程的查,现在演示一下其他的操作,增删改查
先来看看我的实体类的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 -->
<mapper namespace="com.website.mapper.ProductMapper">
<!--
数据库查询数据
insert、select、delete、update:sql语句类型
id:sql语句唯一标识
resultType:结果返回值类型-包名+类名 或 基本数据类型
parameterType:匹配字段值-包名+类名 或 基本数据类型
-->
<select id="getAll" parameterType="com.website.entity.Product" resultType="com.website.entity.Product">
select * from Product where 1=1
<if test="name !=null and !"".equals(name.trim())">and name =#{name}</if>
<if test="type !=null and !"".equals(type.trim())">and type like '%' #{type} '%'</if>
</select>
<select id="getOneById" parameterType="com.website.entity.Product" resultType="com.website.entity.Product">
select * from Product where ID=#{ID}
</select>
<insert id="insert" parameterType="com.website.entity.Product">
insert into Product values(#{id},#{name},#{price},#{type})
</insert>
<delete id="delete" parameterType="Integer">
delete from Product where ID = #{id}
</delete>
<update id="update" parameterType="com.website.entity.Product">
update Product set id=#{id},name=#{name},price=#{price},type=#{type} where id =#{id};
</update>
</mapper>
这里面,增删改查,我都写了。可以发现一点,我在插入或者更新的时候,需要对一个对象进行操作,我写的参数都是对象实体类的字段名,这一点很方便。
最后看看我的测试类吧
package com.website.controller;
import com.website.DB.DBAcess;
import com.website.entity.Product;
import com.website.mapper.ProductMapper;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import static org.junit.Assert.*;
public class ProductControllerTest {
@Test
public void list() throws IOException {
Product product=new Product();
List<Product> list=new ArrayList<>();
DBAcess dbAcess=new DBAcess();
SqlSession sqlSession = dbAcess.getSqlSession();
try {
ProductMapper mapper =sqlSession.getMapper (ProductMapper.class);
list =mapper.getAll(product);
System.out.println(list.size());
System.out.println(list);
}finally {
sqlSession.close();
}
}
@Test
public void getOne() throws IOException {
Product product=new Product();
DBAcess dbAcess=new DBAcess();
SqlSession sqlSession = dbAcess.getSqlSession();
try {
ProductMapper mapper =sqlSession.getMapper (ProductMapper.class);
product=mapper.getOneById(1);
System.out.println("------------"+product.getId());
System.out.println("------------"+product.getName());
System.out.println("------------"+product.getType());
System.out.println("------------"+product.getPrice());
}finally {
sqlSession.close();
}
}
@Test
public void delete() throws IOException {
DBAcess dbAcess=new DBAcess();
SqlSession sqlSession = dbAcess.getSqlSession();
try {
ProductMapper mapper =sqlSession.getMapper (ProductMapper.class);
mapper.delete(2);
sqlSession.commit();
}finally {
sqlSession.close();
}
}
@Test
public void insert() throws IOException {
Product product=new Product();
product.setId(3);
product.setName("IMac");
product.setType("电脑");
product.setPrice(15000.0);
DBAcess dbAcess=new DBAcess();
SqlSession sqlSession = dbAcess.getSqlSession();
try {
ProductMapper mapper =sqlSession.getMapper (ProductMapper.class);
mapper.insert(product);
sqlSession.commit();
}finally {
sqlSession.close();
}
}
@Test
public void update() throws IOException {
Product product=new Product();
product.setId(3);
product.setName("IMac Pro");
product.setType("台式电脑");
product.setPrice(14500.0);
DBAcess dbAcess=new DBAcess();
SqlSession sqlSession = dbAcess.getSqlSession();
try {
ProductMapper mapper =sqlSession.getMapper (ProductMapper.class);
mapper.update(product);
sqlSession.commit();
}finally {
sqlSession.close();
}
}
}
可以发现,还是有不少的重复代码的,不爽啊。这个简单的操作上我还是喜欢JPA
| 注意:查询不需要commit,其他的增删改都需要commit |
Mybatis笔记二:接口式编程的更多相关文章
- 通过自动回复机器人学Mybatis 笔记:接口式编程
[接口式编程]尚未遇见Spring --> 代码量反而增加 1.增加约定,减少犯错的可能(不用直接去写字符串 修改点1:命名空间 修改点2:增加接口,方法名与配置文件中的id对应 package ...
- 通过自动回复机器人学Mybatis笔记:接口式编程
[接口式编程]尚未遇见Spring --> 代码量反而增加 1.增加约定,减少犯错的可能(不用直接去写字符串 修改点1:命名空间 修改点2:增加接口,方法名与配置文件中的id对应 package ...
- MyBatis的接口式编程Demo
很久没细看过MyBatis了,时间一长就容易忘记. 下面是一个接口式编程的例子. 这里的例子一共分为4步: 1 首先要有一个namespace为接口的全类名的映射文件,该例中是 IMyUser.xml ...
- MyBatis3-topic04,05 -接口式编程
笔记要点 /**接口式编程: * 1. 原生: Dao 接口-->Dao接口的实现类 * mybatis: Mapper --> 有一个与之对应的 XXMapper.xml * 2. Sq ...
- MyBatis源码解析【7】接口式编程
前言 这个分类比较连续,如果这里看不懂,或者第一次看,请回顾之前的博客 http://www.cnblogs.com/linkstar/category/1027239.html 修改例子 在我们实际 ...
- mybaits接口式编程
Mybatis是接口式编程实现对.xml中sql语句的执行,其过程如下(取自慕课网视频<通过自动回复机器人学Mybatis---加强版>): 1.加载配置信息2.通过加载配置信息加载一个代 ...
- 早期MyBatis开发与接口式Mybatis开发的简介
早期MyBatis开发与接口式Mybatis开发的简介 一.早期版本的myBatis使用 导jar包 1.配置mybatis.xml的配置文件 1) ...
- MyBatis笔记二:配置
MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...
- Scala学习教程笔记二之函数式编程、Object对象、伴生对象、继承、Trait、
1:Scala之函数式编程学习笔记: :Scala函数式编程学习: 1.1:Scala定义一个简单的类,包含field以及方法,创建类的对象,并且调用其方法: class User { private ...
随机推荐
- 67 个JavaScript和CSS实用工具、库与资源
在这篇文章中,我不会与大家谈论大型的前端框架,如 React.Angular.Vue 等,也没有涉及那些流行的代码编辑器,如 Atom.VS Code.Sublime,我只想与大家分享一个有助于提升开 ...
- BZOJ4321queue2——DP/递推
题目描述 n 个沙茶,被编号 1~n.排完队之后,每个沙茶希望,自己的相邻的两 人只要无一个人的编号和自己的编号相差为 1(+1 或-1)就行: 现在想知道,存在多少方案满足沙茶们如此不苛刻的条件. ...
- word 2013 题注、图注、插入图片自动修改大小、批量更新题注编号
1 .题注 图片下面的文字说明,如 图 1.1.1 2.图注 图的标题格式,可以右键修改段落为居中,选中图片,点下此格式快捷居中等其他格式 3. 题注插入 效果 如下 4.题注自动居中对齐 先点击图 ...
- 【BZOJ2940】条纹(博弈论)
[BZOJ2940]条纹(博弈论) 题面 BZOJ 神TM权限题. 题解 我们把题目看成取石子的话,题目就变成了这样: 有一堆\(m\)个石头,每次可以取走\(c,z,n\)个,每次取完之后可以把当前 ...
- 【LOJ6036】编码(2-sat)
[LOJ6036]编码(2-sat) 题面 LOJ 题解 很显然的一个暴力: 枚举每个串中的?是什么,然后把和它有前缀关系的串全部给找出来,不合法的连边处理一下,那么直接跑\(2-sat\)就做完了. ...
- [算法进阶0x10]基本数据结构C作业总结
t1-Supermarket 超市利润 题目大意 给定n个商品,每个商品有利润pi和过期时间di.每天只能卖一个商品,过期商品不能卖.求如何安排每天卖的商品可以使收益最大. 分析 一开始打了一个复杂度 ...
- 「2017 山东三轮集训 Day7 解题报告
「2017 山东三轮集训 Day7」Easy 练习一下动态点分 每个点开一个线段树维护子树到它的距离 然后随便查询一下就可以了 注意线段树开大点... Code: #include <cstdi ...
- bzoj1831 逆序对 (dp+树状数组)
注意到,所有的-1应该是一个不降的序列,否则不会更优那就先求出来不是-1的的逆序对个数,然后设f[i][j]表示第i个-1放成j的前i个-1带来的最小逆序对数量这个可以树状数组来求 #include& ...
- springboot 后台运行
https://zhuanlan.zhihu.com/p/25102504?refer=dreawer 酱油一篇,整理一下关于Spring Boot后台运行的一些配置方式.在介绍后台运行配置之前,我们 ...
- A1099. Build A Binary Search Tree
A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...