首先是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
应该得到的答案:
文件:
<?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);
}
SqlSessionFactoryBuilder
作用域:一旦创建了SqlSessionFactory就可以销毁了,所以应当是局部方法作用域
SqlSessionFactory
一旦创建,在应用运行期间就应该一直存在,没有任何理由抛弃它,所以应该是属于一种单例来看它。SqlSessionFactory 的最佳作用域是应用作用域
SqlSession
每个线程都应该有它自己的 SqlSession 实例,最佳的作用域是请求或方法作用域。绝对不能将 SqlSession 实例的引用放在一个类的静态域,甚至一个类的实例变量也不行。用后一定要关闭
映射器示例:getMapper()...
映射器实例应该在调用它们的方法中被获取,使用完毕之后即可丢弃。
原文:https://www.cnblogs.com/lvgj/p/14178255.html