文档章节

I-初入MyBatis,基础概念(不断更新)

Ieenben
 Ieenben
发布于 2015/05/13 15:19
字数 573
阅读 52
收藏 2
  • properties --- 用于提供一系列的键值对组成的属性信息,该属性信息可以用于整个配置文件中。

  • settings --- 用于设置 MyBatis 的运行时方式,比如是否启用延迟加载等。

  • typeAliases --- 为 Java 类型指定别名,可以在 XML 文件中用别名取代 Java 类的全限定名。

  • typeHandlers --- 在 MyBatis 通过 PreparedStatement 为占位符设置值,或者从 ResultSet 取出值时,特定类型的类型处理器会被执行。

  • objectFactory --- MyBatis 通过 ObjectFactory 来创建结果对象。可以通过继承 DefaultObjectFactory 来实现自己的 ObjectFactory 类。

  • plugins --- 用于配置一系列拦截器,用于拦截映射 SQL 语句的执行。可以通过实现 Interceptor 接口来实现自己的拦截器。

  • environments --- 用于配置数据源信息,包括连接池、事务属性等。

  • mappers --- 程序中所有用到的 SQL 映射文件都在这里列出,这些映射 SQL 都被 MyBatis 管理。


第一步:配置全局文件:Configuration.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> 
        <typeAlias alias="User" type="com.ieen.mybatis.model.User"/> 
    </typeAliases>
    
    <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://127.0.0.1:3306/testmybatis" />
            <property name="username" value="root"/>
            <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>
    
    <mappers>
        <mapper resource="com/ieen/mybatis/model/UserMapper.xml"/>
    </mappers>
    
</configuration>

Mybatis是通过sessionfactory产生sqlsession,由sqlsession对数据的增删改查和事务提交等。(使用代码)

java.io.Reader reader = Resources.getResourceAsReader("Configuration.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
SqlSession sqlSession = sqlSessionFactory.openSession();


第二步:编写对应model的mapper映射文件:示例(UserMapper.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.ieen.mybatis.model.UserMapper">
    <select id="selectUserByID" parameterType="int" resultType="User">
        select * from user where id = #{id}
    </select>
</mapper>


第三步:使用方法一(直接访问):

    SqlSessionFactory sqlSessionFactory;
    java.io.Reader reader;
    SqlSession session;
    try{
        reader = Resources.getResourceAsReader("Configuration.xml");
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
        session= sqlSessionFactory.openSession();
        User user = (User) session.selectOne("com.ieen.mybatis.model.UserMapper.selectUserByID",2);
        System.out.println(user.getUserAddress());
        System.out.println(user.getUserName());
        session.close();
    }catch(Exception e){
        e.printStackTrace();
    }


方法二:(接口定义)定义一个接口,创建与映射文件xml里面的sql语句的访问方法。

访问UserMapper.xml的接口定义; 

public interface UserMapper
{
    public User selectUserByID(int id);
}

使用方法:

UserMapper userMapper = sqlsession.getMapper(UserMapper.class);
User user = userMapper.selectUserByID(2);

    该方法的注意事项:(1)namespace改成接口 UserMapper的路径;

(2)接口名称与XML文件的<mapper namespace="com.ieen.mybatis.model.UserMapper">配置一致。



© 著作权归作者所有

共有 人打赏支持
Ieenben
粉丝 4
博文 35
码字总数 5025
作品 0
广州
CommonWeb基于(easyui +spring4.2.4 +mybatis 3.3)(一)

Common Web项目框架,采用(jquery easyui +spring4.2.4 +mybatis 3.3),集成了基础的菜单、用户、权限管理,便于大家快速开展自己的项目。开发人员只需要关注业务逻辑部分开发,基础的框架、...

Martin_Luo
2016/03/15
245
0
【说云精选】 容器化与 Docker 专刊 第一期

Docker 技术经历了数年的发展,已经逐渐成了气候,完善的工具链让Docker 不再是那个拄着拐杖走路的服务,如今的 Docker 已经能够做好应用的开发部署工作。今天我们开始更新「容器化与 Docker...

西秦说云
01/02
0
0
服务器后端开发系列——《实战Memcached内存缓存系统》

1、实战Memcached缓存系统(1)Memcached基础及示例程序 内容:建筑Memcached背景知识和入门示例程序。 2、实战Memcached缓存系统(2)Memcached Java API基础之MemcachedClient 内容:以Mem...

晨曦之光
2012/04/24
88
0
nbfujx/Goku.WebService.Bus

Goku.WebService.Bus 基于SpringBoot + Spring + Apache CXF +Mybatis 开发SOAP的 WebService 服务 备注 版本 说明 1.0.0版本 2.0.0版本 springboot启动 原理 Mybatis基于动态代理实现Mappe...

nbfujx
01/02
0
0
入行IT三年来的感想-20180413

任何行为都是由目的驱动的。 写博客是为了审视自己的行为,及时更正方向,同时可以与同道中人交流,达到提升自己的目的。 从2015年9月踏入IT行业以来,我明白了自己事业追求的方向。从中我可...

vincerten
04/13
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Shiro | 实现权限验证完整版

写在前面的话 提及权限,就会想到安全,是一个十分棘手的话题。这里只是作为学校Shiro的一个记录,而不是,权限就应该这样设计之类的。 Shiro框架 1、Shiro是基于Apache开源的强大灵活的开源...

冯文议
今天
1
0
linux 系统的运行级别

运行级别 运行级别 | 含义 0 关机 1 单用户模式,可以想象为windows 的安全模式,主要用于修复系统 2 不完全的命令模式,不含NFS服务 3 完全的命令行模式,就是标准的字符界面 4 系统保留 5 ...

Linux学习笔记
今天
2
0
学习设计模式——命令模式

任何模式的出现,都是为了解决一些特定的场景的耦合问题,以达到对修改封闭,对扩展开放的效果。命令模式也不例外: 命令模式是为了解决命令的请求者和命令的实现者之间的耦合关系。 解决了这...

江左煤郎
今天
3
0
字典树收集(非线程安全,后续做线程安全改进)

将500W个单词放进一个数据结构进行存储,然后进行快速比对,判断一个单词是不是这个500W单词之中的;来了一个单词前缀,给出500w个单词中有多少个单词是该前缀. 1、这个需求首先需要设计好数据结...

算法之名
昨天
15
0
GRASP设计模式

此文参考了这篇博客,建议读者阅读原文。 面向对象(Object-Oriented,OO)是当下软件开发的主流方法。在OO分析与设计中,我们首先从问题领域中抽象出领域模型,在领域模型中以适当的粒度归纳...

克虏伯
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部