初识Mybatis(四)之普通配置Dao和Mapper配置Dao

序言

在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必须遵循以下规则:

  1. 接口中的方法返回值类型必须与Mapper.xml中的ResultType类型一致
  2. 接口中的方法的形参类型必须与Mapper.xml中的ParameterType类型一致
  3. 方法名称必须与Mapper.xml中操作类型的Id一致
  4. 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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值