博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MyBatis3-以接口方式编程
阅读量:6590 次
发布时间:2019-06-24

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

以下内容引用自,不过内容有修改:

继前一篇文章,已经配置好MyBatis的环境,并且实现了一个简单的查询。请注意,这种方式是用SqlSession实例来直接执行已映射的SQL语句:

session.selectOne("com.jsoft.testmybatis.models.UserMapper.selectUserByID", 1)

其实还有更简单的方法,而且是更好的方法,使用合理描述参数和SQL语句返回值的接口(比如IUserOperation.class),这样现在就可以至此那个更简单,更安全的代码,没有容易发生的字符串文字和转换的错误.下面是详细过程:

建立com.jsoft.testmybatis.inter 这个包,并建立接口类IUserOperation , 内容如下:

package com.jsoft.testmybatis.inter;import com.jsoft.testmybatis.models.User;public interface IUserOperation {    public User selectUserByID(int id);}

注意:这里面有一个方法名selectUserByID必须与User.xml里面配置的select的id对应(<select id="selectUserByID");并且mapper的namespace也要改成<mapper namespace="com.jsoft.testmybatis.inter.IUserOperation">,可以看出是对应接口的。

重写测试代码:

public class App {    public static void main( String[] args ) throws IOException    {        InputStream inputStream = Resources.getResourceAsStream("Configuration.xml");        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);        SqlSession session = sqlSessionFactory.openSession();        try {            IUserOperation userOperation = session.getMapper(IUserOperation.class);            User user = userOperation.selectUserByID(1);            System.out.println(user.getUserAddress());            System.out.println(user.getUserName());        } finally {            session.close();        }    }}

测试结果:

整个工程的结构如下:

 

测试工程:

==>如有问题,请联系我:easonjim#163.com,或者下方发表评论。<==

转载地址:http://rfuio.baihongyu.com/

你可能感兴趣的文章
如何在Root的手机上开启ViewServer,使得HierachyViewer能够连接
查看>>
重写和重载
查看>>
RDIFramework.NET ━ .NET快速信息化系统开发框架 V3.2-新增锁定用户与解除锁定用户的功能...
查看>>
vue1.0 的过滤器
查看>>
如何删除anaconda
查看>>
Mybatis3.3——源码阅读笔记
查看>>
oracle中的trunc函数操作
查看>>
杂牌蓝牙在2003系统使用新驱动的破解方法!
查看>>
EventCache表太大, 怎么办?
查看>>
Top 10 mistakes in Eclipse Plug-in Development
查看>>
Directx教程(23) 简单的光照模型(2)
查看>>
使用sphinx来创建文档
查看>>
[转]用了docker是否还有必要使用openstack?
查看>>
Java 并发性和多线程
查看>>
IE6下frameset横向滚动条BUG
查看>>
命令查看java的class字节码文件
查看>>
软件下载链接获取方法
查看>>
Oracle 的一个非常好的触发器例子
查看>>
Python线程专题9:线程终止与挂起、实用工具函数
查看>>
HTTP协议入门
查看>>