zoukankan      html  css  js  c++  java
  • Mybatis的Dao层实现:代理开发方式

    代理开发方式只要写好接口就行了,不需要像传统实现方式那样自己去实现接口,由Mybatis 框架根据接口定义创建接口的动态代理对象

    Mapper 接口开发需要遵循以下规范:

    1) Mapper.xml文件中的namespace与mapper接口的全限定名相同

    2) Mapper接口方法名和Mapper.xml中定义的每个statement的id相同

    3) Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql的parameterType的类型相同

    4) Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同


    编写映射文件mapper.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.dao.UserMapper">
        <!--    查询操作-->
        <select id="findAll" resultType="com.domain.User">
            select * from User
        </select>
        <!--    插入操作-->
        <insert id="add" parameterType="com.domain.User">
            insert into User values (#{id},#{username},#{password})
        </insert>
        <!--    修改数据-->
        <update id="update" parameterType="com.domain.User">
            update User set password = #{password} where username=#{username}
        </update>
        <!--    删除操作-->
        <delete id="delete" parameterType="com.domain.User">
            delete from User where username=#{username}
        </delete>
    
    </mapper>
    

    编写核心文件

    <?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>
        <!--    指定默认的环境名称-->
        <environments default="development">
            <!--        指定当前环境名称-->
            <environment id="development">
                <!--            事务管理器-->
                <transactionManager type="JDBC"></transactionManager>
                <!--            指定当前数据类型是连接池-->
                <dataSource type="POOLED">
                    <property name="driver" value="com.mysql.jdbc.Driver"/>
                    <property name="url" value="jdbc:mysql://localhost:3306/one"/>
                    <property name="username" value="root"/>
                    <property name="password" value="admin123"/>
                </dataSource>
            </environment>
        </environments>
    
        <!--    加载映射文件-->
        <mappers>
            <mapper resource="com/mapper/UserMapper.xml"></mapper>
        </mappers>
    
    </configuration>
    

    编写接口UserMapper

    package com.dao;
    
    import com.domain.User;
    
    import java.util.List;
    
    public interface UserMapper {
    
         List<User> findAll();
    
    }
    
    

    测试

     @Test
        public void test2() throws IOException {
            //        加载核心配置文件
            InputStream resource = Resources.getResourceAsStream("sqlMapConfig.xml");
    //        获得sqlSession工厂对象
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resource);
    //        获得SqlSession对象
            SqlSession sqlSession = sqlSessionFactory.openSession();
    //        获得Mybatis框架生成的UserMapper接口实现类
            UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
            List<User> list = userMapper.findAll();
            System.out.println(list);
    //        释放资源
            sqlSession.close();
        }
    
  • 相关阅读:
    2.最详细的WSDD配置文件注释
    1.Apache Axis配置文件WSDD详解
    26. Intellij IDEA 启动项目ClassNotFoundException
    警告: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property ..
    Java 远程通讯技术及原理分析
    Hibernate 中配置属性详解(hibernate.properties)
    SSH之IDEA2017整合Struts2+Spring+Hibernate
    java对象与json对象间的相互转换
    25.怎样在IDEA中使用JUnit4和JUnitGenerator V2.0自动生成测试模块
    24. 在IDEA中使用JUnit进行方法测试
  • 原文地址:https://www.cnblogs.com/lyd447113735/p/14427612.html
Copyright © 2011-2022 走看看