序言
在web项目开发中,一般都采用MVC架构模式,Mybatis是持久层的框架,所以其应该被写成Dao模式
Dao代码
UserDao
package com.tangbaobao.mybits.dao;
import com.tangbaobao.mybits.pojo.User;
/**
*@author 唐学俊
*@version 2018年1月14日下午5:51:05
*
*/
public interface UserDao {
//查询
public User findUserById(Integer id);
}
UserDaoImpl实现类:
package com.tangbaobao.mybits.dao;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import com.tangbaobao.mybits.pojo.User;
/**
* @author 唐学俊
* @version 2018年1月14日下午5:52:21
*
*/
public class UserDaoImpl implements UserDao {
// 注入sqlSession对象
private SqlSessionFactory sqlSessionFactory;
// 用构造方法注入
public UserDaoImpl(SqlSessionFactory sqlSessionFactory) {
this.sqlSessionFactory = sqlSessionFactory;
}
@Override
public User findUserById(Integer id) {
// 获取sqlsession
SqlSession session = sqlSessionFactory.openSession();
User user = session.selectOne("test.selectUserById", id);
return user;
}
}
SqlMapCongfig.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<typeAliases>
<!-- alias的大小写可以忽略 -->
<!-- <typeAlias type="com.tangbaobao.mybits.pojo.User" alias="user"/> -->
<!-- package的name属性中填写包名-->
<package name="com.tangbaobao.mybits.pojo" />
</typeAliases>
<environments default="development">
<environment id="development">
<!-- 使用jdbc事务管理 -->
<transactionManager type="JDBC" />
<!-- 数据库连接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url"
value="jdbc:mysql://localhost:3306/mybatis?useSSL=false" />
<property name="username" value="root" />
<property name="password" value="960624" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/tangbaobao/mybits/pojo/User.xml" />
</mappers>
</configuration>
MpperUser.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.tangbaobao.mybits.mapper.UserMapper">
<!-- 根据id查询用户 -->
<select id="selectUserById" resultType="User"
parameterType="java.lang.Integer">
select * from user where id = #{v}
</select>
<!-- 模糊查询 方式一:用占位符查询(防止注入): "%"#{}"%" select * from username like "%"'五'"%"
方式二:用专用查询符号(不防止注入): like '%${value}%' -->
<select id="selectUserByName" resultType="com.tangbaobao.mybits.pojo.User"
parameterType="java.lang.String">
select * from user where username like "%"#{haha}"%"
</select>
<!-- 添加数据 -->
<insert id="insertUser" parameterType="com.tangbaobao.mybits.pojo.User">
<!-- 返回插入的主键 -->
<selectKey keyProperty="id" resultType="Integer" order = "AFTER">
select LAST_INSERT_ID()
</selectKey>
insert into user(username,birthday,address,id,sex)
values(#{username},#{birthday},#{address},#{id},#{sex})
</insert>
<!-- 修改 -->
<update id="updateUser" parameterType="com.tangbaobao.mybits.pojo.User">
update user
set username = #{username},sex = #{sex},birthday = #{birthday},address = #{address}
where id = #{id}
</update>
<!-- 删除 -->
<delete id="deleteUser" parameterType="Integer" >
delete from user where id = #{id}
</delete>
</mapper>
测试类:
package com.tangbaobao.mybits.app;
/**
*@author 唐学俊
*@version 2018年1月14日下午5:57:58
*
*/
import java.io.IOException;
import java.io.InputStream;
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.tangbaobao.mybits.dao.UserDao;
import com.tangbaobao.mybits.dao.UserDaoImpl;
import com.tangbaobao.mybits.pojo.User;
public class Test2 {
private SqlSessionFactory sessionFactory;
@Before
public void before() throws IOException {
// 1.加载配置文件
InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
// 2.获得工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
sessionFactory = builder.build(in);
System.out.println("开始");
}
@Test
public void DaoFindUser() {
UserDao dao = new UserDaoImpl(sessionFactory);
User user = dao.findUserById(10);
System.out.println(user);
}
}
在传统的Dao中弊处显而易见,每次要写很多重复的代码,于是Mybatis为我们提供了Mapper动态代理创建DaoImpl
在Java中内置的动态代理是通过实现同一个接口进行对目标对象代理,所以Mybatis采用了此种代理方式,常见的代理方式还有第三方的CgLIb代理,感兴趣的童鞋可以百度
使用Mapper代理DaoImpl必须遵循以下规则:
- 接口中的方法返回值类型必须与Mapper.xml中的ResultType类型一致
- 接口中的方法的形参类型必须与Mapper.xml中的ParameterType类型一致
- 方法名称必须与Mapper.xml中操作类型的Id一致
- Mapper.xml中mapper属性的namespace的值须以接口的全包名命名
遵循以上规则,才能使用动态代理生成实现类
Mybatis配置文件说明
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- rypeAliases给类起个别名,以后使用可以不写全包名
Mybatis内置了几种常用的类型,比如:
别名
Integer int
String string
别名对大小写不敏感
-->
<typeAliases>
<!-- alias的大小写可以忽略 -->
<!-- <typeAlias type="com.tangbaobao.mybits.pojo.User" alias="user"/> -->
<!-- package的name属性中填写包名-->
<package name="com.tangbaobao.mybits.pojo" />
</typeAliases>
<environments default="development">
<environment id="development">
<!-- 使用jdbc事务管理 -->
<transactionManager type="JDBC" />
<!-- 数据库连接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url"
value="jdbc:mysql://localhost:3306/mybatis?useSSL=false" />
<property name="username" value="root" />
<property name="password" value="960624" />
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/tangbaobao/mybits/pojo/User.xml" />
<mapper class=""/>
<!-- 使用Package来加载配置文件必须遵守以下规则:
1.Mapper.xml的名称必须与对应接口名称一致
2.Mapper.xml与接口必须在同一文件夹下
比如:com.tangbaobao.mybits.mapper.UserMapper 则XML命名为UserMapper.xml
由于包配置不用指定某一个接口,可以扫描此包下的所有配置及其映射,使得开发简单,规范,也是官方推荐的
-->
<package name="com.tangbaobao.mybits.mapper"/>
</mappers>
</configuration>