mybatis 入门进阶之 mapper
由于上节 《mybatis 入门优化》中的dao实现类耦合了user.xml中的statment的id,例如:src.main.resource.userMapper.findUserByName。
这节采用mapper接口的方式实现dao。
IWebUserDao.java
package com.mozi.dao; import java.util.List;
import com.mozi.entity.*; public interface IWebUserDao {
/**根据用户名称模糊查询用户信息*/
public List<WebUser> findUserByName(String username); /** 添加用户*/
public void insertUser(WebUser user); /** 根据ID删除用户*/
public void deleteUser(String id); /** 根据ID更新用户*/
public void updateUser(WebUser user);
}
sqlmap\userMapper.xml,
注意:
1、mapper配置中的namespace必须与接口去路径一致如:com.mozi.dao.IWebUserDao。
2、mapper的statment的id跟接口中的方法名一致,参数类型一致。
<?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">
<!-- namespace命名空间,作用就是对sql进行分类化的管理,理解为sql隔离
注意:使用mapper代理开发时,namespace有特殊作用
-->
<mapper namespace="com.mozi.dao.IWebUserDao">
<resultMap id="BaseResultMap" type="com.mozi.entity.WebUser" >
<id column="Name" property="name" jdbcType="VARCHAR" />
<result column="TrueName" property="trueName" jdbcType="VARCHAR" />
<result column="Pass" property="pass" jdbcType="VARCHAR" />
</resultMap>
<sql id="Base_Column_List" >
Name, TrueName, Pass
</sql> <select id="findUserById" parameterType="int" resultType="com.mozi.entity.WebUser" >
select * from WebUsers where id=#{id}
</select> <select id="findUserByName" parameterType="java.lang.String" resultType="com.mozi.entity.WebUser" >
select * from WebUsers where Name LIKE '%${value}%'
</select> <select id="findUserByName2" parameterType="java.lang.String" resultMap ="BaseResultMap" >
select * from WebUsers where Name LIKE '%${value}%'
</select> <!-- 添加用户 -->
<insert id="insertUser" parameterType="com.mozi.entity.WebUser" >
<!--
使用mysql的uuid(),实现非自增主键的返回。
执行过程:通过uuid()得到主键,将主键设置到user对象的Id的属性中,其次,在insert执行时,从user对象中取出Id属性值;
-->
insert into WebUsers (Name,TrueName,Pass) values(#{name},#{trueName},#{pass})
</insert> <!-- 删除用户 --> <delete id="deleteUser" parameterType="java.lang.String">
delete from WebUsers where Name=#{name}
</delete>
<!-- 更新用户 -->
<update id="updateUser" parameterType="com.mozi.entity.WebUser">
update WebUsers set Name=#{name},TrueName=#{trueName},Pass=#{pass}
where Name=#{name}
</update>
</mapper>
WebUserDaoMybatis3.java
package com.mozi.dao.impl; import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory; import com.mozi.dao.IWebUserDao;
import com.mozi.entity.WebUser; public class WebUserDaoMybatis3 implements IWebUserDao {
private SqlSessionFactory sqlSessionFactory;
// 需要向dao实现类中注入SqlSessionFactory
// 通过构造方法注入
public WebUserDaoMybatis3(SqlSessionFactory sqlSessionFactory) {
this.sqlSessionFactory = sqlSessionFactory;
} @Override
public List<WebUser> findUserByName(String username) {
SqlSession sqlSession = sqlSessionFactory.openSession(); // 创建Usermapper对象,mybatis自动生成mapper代理对象
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
List<WebUser> list = mapper.findUserByName(username);
sqlSession.close(); return list;
} @Override
public void insertUser(WebUser user) {
SqlSession sqlSession = sqlSessionFactory.openSession();
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
// 执行插入操作
mapper.insertUser(user);
// 提交事务
sqlSession.commit();
// 释放资源
sqlSession.close();
} @Override
public void deleteUser(String id) {
SqlSession sqlSession = sqlSessionFactory.openSession();
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
// 执行插入操作
mapper.deleteUser(id);
// 提交事务
sqlSession.commit();
// 释放资源
sqlSession.close();
} @Override
public void updateUser(WebUser user) {
SqlSession sqlSession = sqlSessionFactory.openSession();
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
// 执行插入操作
mapper.updateUser(user);
// 提交事务
sqlSession.commit();
// 释放资源
sqlSession.close();
} }
测试类WebUserDaoImplTest.java
package com.mozi.test.java; import static org.junit.Assert.*; import java.io.IOException;
import java.io.InputStream;
import java.util.List; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test; import com.mozi.dao.IWebUserDao;
import com.mozi.dao.impl.WebUserDaoJdbc;
import com.mozi.dao.impl.WebUserDaoMybatis;
import com.mozi.dao.impl.WebUserDaoMybatis2;
import com.mozi.dao.impl.WebUserDaoMybatis3;
import com.mozi.entity.WebUser; public class WebUserDaoImplTest { private static SqlSessionFactory sqlSessionFactory = null; private static IWebUserDao dao = null; static{
String resource = "SqlMapConfig.xml";
InputStream inputStream = null;
try {
inputStream = Resources.getResourceAsStream(resource);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
dao = new WebUserDaoMybatis3(sqlSessionFactory);
} @Test
public void findUserByName() {
List<WebUser> userList = dao.findUserByName("aa");
System.out.println(userList);
assertNotNull(userList);
} @Test
public void insertUser() {
WebUser user = new WebUser();
user.setName("5");
user.setTrueName("lisi");
user.setPass("5");
dao.insertUser(user);
} @Test
public void deleteUser() {
dao.deleteUser("5");
} @Test
public void updateUser() {
WebUser user = new WebUser();
user.setName("5");
user.setTrueName("lisi");
user.setPass("666"); dao.updateUser(user);
}
}
mybatis 入门进阶之 mapper的更多相关文章
- MyBatis入门程序之Mapper代理方式
Mapper代理的开发方式,程序员只需要编写mapper接口(相当于dao接口)即可,MyBatis会自动为mapper接口生成动态代理实现类. 一.开发规范 1.mapper接口的全限定名要和map ...
- mybatis 入门进阶之 pojo
有时候我们dao方法声明的入参需要是自定义的pojo,以满足复杂的查询条件. IWebUserCustomDao.java package com.mozi.dao; import java.util ...
- mybatis入门篇:Mapper接口/关联查询/新增数据
1.数据准备 2.编写实体类 package com.forest.owl.entity; import java.util.Date; public class User { private Lon ...
- MyBatis入门程序之mapper映射文件常用配置命令
1.ResultMap高级结果映射 如果查询出的列名和属性名不一致,可以通过ResultMap做映射,放在statement的输出类型中 如下: 2.动态SQL,使用各种动态标签实现动态拼接sql,常 ...
- mybatis入门基础(二)----原始dao的开发和mapper代理开发
承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...
- Spring Boot入门系列(十七)整合Mybatis,创建自定义mapper 实现多表关联查询!
之前讲了Springboot整合Mybatis,介绍了如何自动生成pojo实体类.mapper类和对应的mapper.xml 文件,并实现最基本的增删改查功能.mybatis 插件自动生成的mappe ...
- MyBatis1:MyBatis入门
MyBatis是什么 MyBatis是什么,MyBatis的jar包中有它的官方文档,文档是这么描述MyBatis的: MyBatis is a first class persistence fra ...
- MyBatis入门基础(一)
一:对原生态JDBC问题的总结 新项目要使用mybatis作为持久层框架,由于本人之前一直使用的Hibernate,对mybatis的用法实在欠缺,最近几天计划把mybatis学习一哈,特将学习笔记记 ...
- MyBatis入门案例、增删改查
一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...
随机推荐
- 大约xib连接错误bug正确
今天code什么时候,发现xib除了加载问题,研究发现的一个问题 在连接的时候, object一定要选择,您连接view,代替 File's Owner 版权声明:本文博客原创文章,博客,未经同意,不 ...
- C#yield return和yield break
C#yield return和yield break 晚上好,各位.今天结合书中所讲和MSDN所查,聊下yield关键字,它是我们简化迭代器的关键. 如果你在语句中使用了yield关键字,则意味着它在 ...
- 从.net复制源代码中国农历阵列,必要做日历
从.net复制源代码中国农历阵列,必要做日历 const { 闰月的月份.春节的阳历日期(农历正月初一).农历的每一个月天数 } c_arrLunarInfo: array [1900 .. 2100 ...
- Spring IOC 之Bean作用域
当你创建一个bean定义的时候,你创建了一份通过那种bean定义的bean的创建类的真正实力的处方.bean的定义是一个处方 的想法是很重要的的.因为这意味着,对于一个类你可以创建很多对象实例从一个单 ...
- mcstructs-MircoCStructs用C语言实现的微型数据结构库
以C语言的方式,我将逐步实现以下算法: 我的Github地址为:https://github.com/tfa2012/mcstructs 1 线性链表 2 环形缓冲区 3 Hash表
- 小猪Android越来越方式 Day 5 - part 2
小猪的Android入门之路 Day 5 - part 2 Activity片段:Fragment(碎片) ------转载请注明出处 ...
- Castle扩展Ibatis.Net
使用Castle扩展Ibatis.Net,面向接口编程-更优雅的代码 使用Ibatis.Net做项目半年了,甚是喜欢,感觉确实是个简单.轻巧的O/R Mapping框架,特别是将Sql配置在Xml文件 ...
- 【jar包】图片的异步加载--【 Imageloader】
Android Imageloader图片异步加载 Imageloader是一个在android平台下简单的下载.显示.缓存空间的图片加载库. 异步下载网络图片并可以在UI线程更新View,使用二级缓 ...
- ASP.Net中应用百度编辑器(UEditor)上传图片和上传附件失败-解决方案
第一步: 第二步: 第三步: 第四步:
- 网络地址到物理地址的映射(ARP)
网络的互连首先要解决的问题就是网络地址到物理地址的映射,以太网接口分配的是一个48位的物理地址,而IP地址却只有32位,因此无法将它编码到IP地址中.有人建议可以构建一个中央数据库存储所有网络中的网络 ...