首页 > 其他 > 详细

1、Mybatis官方文档-入门

时间:2020-12-23 15:05:00      阅读:34      评论:0      收藏:0      [点我收藏+]

Mybatis官方文档-入门

入门

第一个Mybatis程序

首先是Mybatis的HelloWorld,要使用mybatis需要进行以下几步:

1、导入jar,一般使用pom.xml,即maven进行导入

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.3</version>
        </dependency>

2、构建SqlSessionFactory,有两种方法,一种是通过xml文件,另一种是使用Java类,主要使用第一种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="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${username}"/>
        <property name="password" value="${password}"/>
      </dataSource>
    </environment>
  </environments>
  <mappers>
    <mapper resource="org/mybatis/example/BlogMapper.xml"/>
  </mappers>
</configuration>

需要注意的是:

  • 首先这里的${url}是从properties文件里面读出来的,所以要进行配置

    <properties resource="db.properties"></properties>
    

    其中这个db.properties,也是在resources的目录下面。

我这里的一个配置是:

<?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>
    <properties resource="db.properties"></properties>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${m-driver}"/>
                <property name="url" value="${m-url}"/>
                <property name="username" value="${m-username}"/>
                <property name="password" value="${m-password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="mapper/BlogMapper.xml"/>
    </mappers>
</configuration>

目录结构是:

技术分享图片

到这一步我们已经配置好xml文件了,下一步是创建SqlSessionFactory的示例。

String resource = "org/mybatis/example/mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

指的注意的是其中的Resources.get.....这个类和方法是mybatis自带的。

第三步是从SqlSessionFactory中获取SqlSession。

try (SqlSession session = sqlSessionFactory.openSession()) {
  Blog blog = (Blog) session.selectOne("org.mybatis.example.BlogMapper.selectBlog", 101);
}

上面这是第一种执行sql的方法,第二种方法是

try (SqlSession session = sqlSessionFactory.openSession()) {
  BlogMapper mapper = session.getMapper(BlogMapper.class);
  Blog blog = mapper.selectBlog(101);
}

涉及的代码如下:

  • Blog

    @Data
    @ToString
    public class Blog {
            private String id;
            private String title;
            private String author;
            private Date createTime;
            private int views;
    }
    
  • BlogMapper

    public interface BlogMapper {
        Blog selectBlog(String id);
    }
    
  • BlogMapper.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.lvgj.mapper.BlogMapper">
        <select id="selectBlog" resultType="com.lvgj.pojo.Blog">
        select * from blog where id = #{id}
      </select>
    </mapper>
    
  • 创建数据库

    CREATE TABLE `blog` (
      `id` varchar(50) NOT NULL COMMENT ‘博客id‘,
      `title` varchar(100) NOT NULL COMMENT ‘博客标题‘,
      `author` varchar(30) NOT NULL COMMENT ‘博客作者‘,
      `create_time` datetime NOT NULL COMMENT ‘创建时间‘,
      `views` int(30) NOT NULL COMMENT ‘浏览量‘
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8
    

    应该得到的答案:

技术分享图片

探究已映射的SQL语句

文件:

<?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="org.mybatis.example.BlogMapper">
  <select id="selectBlog" resultType="Blog">
    select * from Blog where id = #{id}
  </select>
</mapper>

命名空间作用:一个是利用更长的全限定名来将不同的语句隔离开来,同时也实现了你上面见到的接口绑定。长远来看,只要将命名空间置于合适的 Java 包命名空间之中,你的代码会变得更加整洁,也有利于你更方便地使用 MyBatis。

最后上面的文件还可以使用注释代替:

package org.mybatis.example;
public interface BlogMapper {
  @Select("SELECT * FROM blog WHERE id = #{id}")
  Blog selectBlog(int id);
}

作用域(Scope)和生命周期

SqlSessionFactoryBuilder

作用域:一旦创建了SqlSessionFactory就可以销毁了,所以应当是局部方法作用域

SqlSessionFactory

一旦创建,在应用运行期间就应该一直存在,没有任何理由抛弃它,所以应该是属于一种单例来看它。SqlSessionFactory 的最佳作用域是应用作用域

SqlSession

每个线程都应该有它自己的 SqlSession 实例,最佳的作用域是请求或方法作用域。绝对不能将 SqlSession 实例的引用放在一个类的静态域,甚至一个类的实例变量也不行。用后一定要关闭

映射器示例:getMapper()...

映射器实例应该在调用它们的方法中被获取,使用完毕之后即可丢弃。

1、Mybatis官方文档-入门

原文:https://www.cnblogs.com/lvgj/p/14178255.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!