zoukankan      html  css  js  c++  java
  • mybatis学习(三)——接口式编程

    对于上一节中的查询我们还可以通过接口的方式进行编程,开发环境和上一节一样

    1、全局配置文件mybatis_config.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>
        <environments default="development">
            <environment id="development">
                <transactionManager type="JDBC" />
                <!-- 配置数据库源信息 -->
                <dataSource type="POOLED">
                    <property name="driver" value="com.mysql.jdbc.Driver" />
                    <property name="url" value="jdbc:mysql://localhost:3306/spring_mybatis" />
                    <property name="username" value="root" />
                    <property name="password" value="pjf520" />
                </dataSource>
            </environment>
        </environments>
    </configuration>

    2、JAVA代码实体类(和上一节一样)

    package com.pjf.mybatis.po;
    
    public class Hotel {
        private int hotelId;
        private String hotelName;
        private String hotelAddress;
        private int price;
    
        public int getHotelId() {
            return hotelId;
        }
    
        public void setHotelId(int hotelId) {
            this.hotelId = hotelId;
        }
    
        public String getHotelName() {
            return hotelName;
        }
    
        public void setHotelName(String hotelName) {
            this.hotelName = hotelName;
        }
    
        public String getHotelAddress() {
            return hotelAddress;
        }
    
        public void setHotelAddress(String hotelAddress) {
            this.hotelAddress = hotelAddress;
        }
    
        public int getPrice() {
            return price;
        }
    
        public void setPrice(int price) {
            this.price = price;
        }
    
        @Override
        public String toString() {
            return "Hotel [hotelId=" + hotelId + ", hotelName=" + hotelName + ", hotelAddress=" + hotelAddress + ", price="
                    + price + "]";
        }
    
    }

    3、(新增)编写hotelMapper接口

    package com.pjf.mybatis.dao;
    
    import com.pjf.mybatis.po.Hotel;
    
    public interface HotelMapper {
    
        public Hotel getHotel(Integer i);
    }

    4、(修改)编写sql映射文件hotelMapper.xml

    这里修改了namespace,定义为接口的类全名,上一节这里可以随便写。

    然后修改了sql的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" >
    <!-- 这里的namespace写hotelMapper接口的类全名,和接口一一对应 -->
    <mapper namespace="com.pjf.mybatis.dao.HotelMapper">
    
        <!-- 这里的id写hotelMapper接口对应的方法名 -->
        <select id="getHotel" resultType="com.pjf.mybatis.po.Hotel">
            select id,hotel_name as
            hotelName, hotel_address as hotelAddress, price from hotel
            where
            id=#{id}
        </select>
    
    </mapper>

    5、(修改)编写测试类

    package com.pjf.mybatis;
    
    import java.io.IOException;
    import java.io.InputStream;
    import org.apache.ibatis.io.Resources;
    import org.apache.ibatis.session.SqlSession;
    import org.apache.ibatis.session.SqlSessionFactory;
    import org.apache.ibatis.session.SqlSessionFactoryBuilder;
    import org.junit.Test;
    
    import com.pjf.mybatis.dao.HotelMapper;
    import com.pjf.mybatis.po.Hotel;
    
    public class TestHotel {
    
        public SqlSessionFactory sqlSessionFactory() throws IOException {
            // mybatis的配置文件
            String resource = "mybatis_config.xml";
            // 使用类加载器加载mybatis的配置文件(它也加载关联的映射文件)TestHotel.class.getClassLoader()
            InputStream is = Resources.getResourceAsStream(resource);
            // 构建sqlSession的工厂
            SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
            return sessionFactory;
        }
    
        @Test
        public void getHotel() throws IOException {
            //如果有多个会话,会新建多个SqlSessionFactory,将重复的内容通过函数提取出来了
            SqlSessionFactory sessionFactory = sqlSessionFactory();
            // 打开jdbc会话
            SqlSession session = sessionFactory.openSession();
            // 创建hotelMapper类的实例
            // 虽然这是个接口,但是mybatis会通过动态代理新建一个实体类
            // 可以通过System.out.println(hotelMapper.getClass())查看该类的类型
            // 输出class com.sun.proxy.$Proxy5,可以看到是一个代理类
            HotelMapper hotelMapper = session.getMapper(HotelMapper.class);
            System.out.println(hotelMapper.getClass());
    
            Hotel hotel = hotelMapper.getHotel(1001);
            System.out.println(hotel);
            session.close();
        }
    }

     

    可以看到结果和之前一致。

  • 相关阅读:
    C++下载IE缓存大文件
    C++网页数据流转为本地文件,URLDownloadToFile
    关于CLISTCTRL的删除和vector的删除,必须倒序删除
    字符串转为 时间。时间差,几天,几小时,几分
    MFCS删除文件夹,非空文件夹
    string的c_str();转换成的是const char*类型 string的c_str();转换成CString,虽然可用,但是意义不一样,变量string不能共用。
    对话框透明,控件不透明(控件显示背景图)
    执行处理程序“System.Web.Mvc.HttpHandlerUtil+ServerExecuteHttpHandlerWrapper”的子请求时出错。
    ffmpeg使用示例
    js图片放大效果
  • 原文地址:https://www.cnblogs.com/pjfmeng/p/7676653.html
Copyright © 2011-2022 走看看