初步了解MyBatis的相关配置

一、什么是MyBatis?

MyBatis是一个持久层框架,属于JDBC的替代方案之一,他的前身是iBatis。同时也是ORM关系型映射。

那什么又是ORM关系型映射?

ORM(O/R - Mapping 对象关系映射),是一种把内存中的对象保存到关系型数据库的技术。用它封装数据库访问的细节。采用元数据(XML)的方式来描述对象-关系(数据库表)的映射细节,可以使得ORM充当任何一个Java应用业务层到数据库之间的桥梁。

二、MyBatis的三个要素

1.核心接口和类(SqlSessionFactory 和 SqlSession)

2.核心(主)配置文件 mybatis.cfg.xml

3.SQL映射文件(mapper.xml)

三、SqlSessionFactory和SqlSession

SqlSessionFactory

SqlSessionFactory 是MyBatis中的核心对象,是数据库映射关系经过编译之后的内存镜像,而它的作用就是用来创建SqlSession。

SqlSessionFactory 可以根据上层对象SqlSessionFactoryBuilder对象来进行创建。

SqlSessionFactoryBuilder则可以通过核心(主)配置文件 或者Java代码定义好的配置类来构建。

SqlSessionFactory ,是线程安全的,它一旦被创建,在应用的运行期间都会存在,如果我们多次创建同一个数据库的SqlSessionFactory,会导致数据库资源被消耗殆尽。因此通常情况下,同一个数据库都只会对应一个SqlSessionFactory ,所以在构建SqlSessionFactory 实例时通常会使用单例模式。

SqlSession

SqlSession对象是另一个核心对象,他是应用程序和持久层之间执行交互操作的单线程对象–其作用主要是执行持久化操作。

每一个线程都应拥有一个自己的SqlSession实例,并且该实例是不共享的,同时也是线程不安全的,SqlSession它的使用范围最好限制在一次请求或者一个方法中。绝对不能够把其放在一个类的静态字段(属性),注意使用SqlSession对象后,要注意关闭资源。

通常finally关闭或者 try-with-reasoue。

四、搭建MyBatis项目

1.创建Maven项目,在pom.xml导入依赖

<!-- mybatis核心  -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.9</version>
        </dependency>
<!-- mybatis支持JDK8新类型的拓展包 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-typehandlers-jsr310</artifactId>
            <version>1.0.2</version>
        </dependency>

<!-- mysql驱动包 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.29</version>
        </dependency>

2.在resources目录中导入mybaits.cfg.xml-主配置文件,并完成一系列配置

2.1 日志

	<settings>
		<!-- 设置  执行mybatis方法时,显示日志信息。比如:SQL语句方法参数等 -->
		<setting name="logImpl" value="STDOUT_LOGGING" />
	</settings>

2.2 实体类别名

	<typeAliases>
		<!-- 别名配置,允许使用指定包中的类名做为实体类的类型 -->
		<package name="com.project.bean"/>
	</typeAliases>

2.3 数据源配置,设置连接信息

   <environments default="dev">
        <environment id="dev">
<!--			指定事务管理器类型  此时指定为JDBC 使用JDBC的提交和回滚设置 -->
            <transactionManager type="JDBC"></transactionManager>
<!--		 dataSource 设置数据源  type=POOLED指使用JDBC的POOLED数据源连接池的实现对象	-->
            <dataSource type="POOLED">
<!--				数据库驱动  mysql5 - com.mysql.jdbc.Driver
			                  mysql8 - com.mysql.cj.jdbc.Driver
				-->
				<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
				<property name="url" value="jdbc:mysql://localhost:端口号/数据库名称?characterEncoding=utf-8&amp;allowMultiQueries=true"/>
				<property name="username" value="root"/>
				<property name="password" value="密码"/>
            </dataSource>
        </environment>
    </environments> 

2.4 链接映射文件

<!--  映射文件的所在位置	-->
	<mappers>
        <!-- 扫描指定包下的映射文件 -->
		<package name="com.project.dao"/>
	</mappers>

3.在resources目录下去创建映射文件和持久接口同名的层级目录,并完成映射文件名称的修改(和持久接口同名)

<mapper namespace="com.project.dao.接口文件"> 

</mapper>

随后就可在其中通过标签书写sql语句

 <insert id="addMan">  标签的id名称,需要和对应的方法同名
        <!-- addMan意味着持久接口中有同名方法addMan() -->
 </insert>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值