Mybatis01-创建一个简单的mybatis项目
1.新建项目#
- 新建一个普通的maven项目
- 删除src目录(作为父工程)
- 导入maven依赖
<dependencies>
<!--mysql驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.27</version>
</dependency>
<!--mybatis-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.9</version>
</dependency>
<!--junit-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.2</version>
</dependency>
</dependencies>
2.创建mybatis核心配置文件#
<?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="com.mysql.cj.jdbc.Driver"/><!--环境-->
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT"/>
<property name="username" value="root"/>
<property name="password" value="6113081"/>
</dataSource>
</environment>
</environments>
<!--映射mapper接口-->
<mappers>
<mapper resource="com/zhang/mapper/UserMapper.xml"></mapper>
</mappers>
</configuration>
3.编写一个mybatis工具类(类似于jducUtil工具类)#
public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory;
/**
* 每个基于 MyBatis 的应用都是以一个 SqlSessionFactory 的实例为核心的。
* SqlSessionFactory 的实例可以通过 SqlSessionFactoryBuilder 获得。
* 而 SqlSessionFactoryBuilder 则可以从 XML 配置文件或一个预先配置的 Configuration 实例来构建出 SqlSessionFactory 实例。
*/
static {
String resource = "mybatis-config.xml";
try {
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* SqlSession 完全包含了面向数据库执行sql命令所需的所有方法
* @return
*/
public static SqlSession getSqlSession() {
return sqlSessionFactory.openSession();
}
}
4.编写mapper接口(原Dao层接口,提供方法)#
public interface UserMapper {
List<User> getUserList();
}
5.创建包含mapper接口映射关系的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">
<!--namespace绑定了一个对应的Dao/mapper接口-->
<!--此处的mapper配置相当于转换了原先Dao中的接口实现类,相当于此xml文件实现了Mapper接口中的方法-->
<mapper namespace="com.zhang.dao.UserDao">
<!--select查询方法,id表示为mapper接口的实现方法,resultType表示该方法返回类型-->
<select id="getUserList" resultType="com.zhang.pojo.User"><!--返回结果集类型,可以单写返回类型但不推荐-->
select * from user ;
</select>
</mapper>
6.对应的实体类创建(略)#
7.编写测试方法#
public class UserDaoTest {
@Test
public void test(){
//1.获取sqlsession对象
SqlSession sqlSession01 = MybatisUtils.getSqlSession();
//2.方式一:getMapper(执行sql)
UserDao mapper = sqlSession01.getMapper(UserDao.class);
List<User> userList = mapper.getUserList();
for (User user : userList) {
System.out.println(user.toString());
}
sqlSession01.close();
//3.方式二:(不推荐)
SqlSession sqlSession02 = MybatisUtils.getSqlSession();
List<User> users= sqlSession02.selectList("com.zhang.dao.UserDao.getUserList");
for (User user : users) {
System.out.println(user.toString());
}
sqlSession02.close();
}
}
8.结果#
User{id=1, name='zhangsan', pwd='123456'}
User{id=2, name='lisi', pwd='123456'}
User{id=3, name='wangwu', pwd='123456'}
User{id=1, name='zhangsan', pwd='123456'}
User{id=2, name='lisi', pwd='123456'}
User{id=3, name='wangwu', pwd='123456'}
9.总结#
核心要素4点
-
1.SqlSessionFactoryBuilder
这个类可以被实例化、使用和丢弃,一旦创建了 SqlSessionFactory,就不再需要它了。 因此 SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)。 你可以重用 SqlSessionFactoryBuilder 来创建多个 SqlSessionFactory 实例,但最好还是不要一直保留着它,以保证所有的 XML 解析资源可以被释放给更重要的事情。 -
2.SqlSessionFactory
SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。 使用 SqlSessionFactory 的最佳实践是在应用运行期间不要重复创建多次,多次重建 SqlSessionFactory 被视为一种代码“坏习惯”。因此 SqlSessionFactory 的最佳作用域是应用作用域。 有很多方法可以做到,最简单的就是使用单例模式或者静态单例模式。 -
3.SqlSession
每个线程都应该有它自己的 SqlSession 实例。SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。 绝对不能将 SqlSession 实例的引用放在一个类的静态域,甚至一个类的实例变量也不行。 也绝不能将 SqlSession 实例的引用放在任何类型的托管作用域中,比如 Servlet 框架中的 HttpSession。 如果你现在正在使用一种 Web 框架,考虑将 SqlSession 放在一个和 HTTP 请求相似的作用域中。 换句话说,每次收到 HTTP 请求,就可以打开一个 SqlSession,返回一个响应后,就关闭它。 这个关闭操作很重要,为了确保每次都能执行关闭操作,你应该把这个关闭操作放到 finally 块中。 -
4.映射器实例
映射器是一些绑定映射语句的接口。映射器接口的实例是从 SqlSession 中获得的。虽然从技术层面上来讲,任何映射器实例的最大作用域与请求它们的 SqlSession 相同。但方法作用域才是映射器实例的最合适的作用域。 也就是说,映射器实例应该在调用它们的方法中被获取,使用完毕之后即可丢弃。 映射器实例并不需要被显式地关闭。尽管在整个请求作用域保留映射器实例不会有什么问题,但是你很快会发现,在这个作用域上管理太多像 SqlSession 的资源会让你忙不过来。 因此,最好将映射器放在方法作用域内。
作者:Cn_FallTime
出处:https://www.cnblogs.com/CnFallTime/p/16018597.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY