博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis学习(三)——接口式编程
阅读量:5255 次
发布时间:2019-06-14

本文共 3253 字,大约阅读时间需要 10 分钟。

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

1、全局配置文件mybatis_config.xml(和上一节一样)

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和接口就一一对应了

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();    }}

 

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

转载于:https://www.cnblogs.com/pjfmeng/p/7676653.html

你可能感兴趣的文章
D3.js 之 d3-shap 简介(转)
查看>>
制作满天星空
查看>>
类和结构
查看>>
CSS3选择器(二)之属性选择器
查看>>
adidas crazylight 2018 performance analysis review
查看>>
typeset shell 用法
查看>>
python 之 循环语句
查看>>
刀光拖尾效果
查看>>
心得25--JDK新特性9-泛型1-加深介绍
查看>>
[转]ceph网络通信模块_以monitor模块为例
查看>>
HDOJ 1754 I Hate It(线段树基本操作)
查看>>
Ext.Net学习笔记01:在ASP.NET WebForm中使用Ext.Net
查看>>
latex tree
查看>>
jquery 三级关联选择效果
查看>>
Css 特性之 transition和transform
查看>>
安装NVIDIA驱动时禁用自带nouveau驱动
查看>>
函数调用可视化
查看>>
HDU-1255 覆盖的面积 (扫描线)
查看>>
关于开罗
查看>>
css3学习01
查看>>