SSM【Mybatis篇-mybatis核心配置】

一、核心对象

1、SqlSessionFactory

SqlSessionFactory是单个数据库映射关系经过编译后的内存镜像,用于创建 SqlSession。 SqlSessionFactory对象的实例通过SqlSessionFactoryBuilder对象来构建,它通过XML配置文件或一个预先定义好的 Configuration实例构建出SqlSessionFactory的实例。
通过XML配置文件构建出SqlSessionFactory实例的实现代码如下:

//读取配置文件
InputStream inputStream = Resources.getResourceAsStream("配置文件位置");
根据配置文件构建 sqlSessionFactory
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

2、SqlSession
SqlSession是应用程序与持久层之间执行交互操作的一个单线程对象,其主要作用是执行持久化操作。SqlSession对象包含了数据库中所有执行SQL操作的方法,它底层封装了JDBC连接,所以可以直接使用其实例来执行已映射的SQL语句。使用完 SqISession对象之后,要及时将它关闭(使用close()方法).

二·、常用配置文件元素

1、<properties>元素
是一个配置属性的元素,它通过外部配置来动态替换内部定义的属性。例如,数据库的连接等属性,具体方式如下:
(1)在项目的src目录下,创建一个名称为 db.properties的配置文件;

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/db_mybatis
jdbc.username=root
jdbc.password=root

(2)在MyBatis配置文件mybatis-config.xml中配置<properties/>属性;

<properties resource="db.properties" />

(3)修改配置文件中数据库连接的信息

 <!-- 动态替换SQL配置 -->
		<dataSource type="POOLED">
			<property name="driver" value="${jdbc.driver}" />
			<property name="url" value="${jdbc.url}" />
			<property name="username" value="${jdbc.username}" />
			<property name="password" value="${jdbc.password}" />
		</dataSource>

2、<setting>元素
<settings>元素主要用于改变MyBatis运行时的行为,例如开启二级缓存、开启延迟加载等。

<!--设置-->
<settings>
	<setting name="cacheEnabled" value="true" />
	<setting name="lazyLoadingEnabled" value="true" />
	<setting name="multipleResultsetsEnable d" value="true" />
	<setting name="useColumnLabel" value="true" />
	<setting name="useGeneratedKeys" value="false"/>
	<setting name="autoMappingBehavior" value="PARTIAL"/>
	……
</settings>

3、<envoronments>元素
元素用于在配置文件中对环境进行配置。MyBatis的环境配置实际上就是数据源的配置,可以通过元素配置多种数据源,即配置多种数据库。
对于数据源的配置,MyBatis框架提供了UNPOOLED、POOLED和JNDI三种数据源类型。

  1. UNPOOLED
    配置此数据源类型后,在每次被请求时会打开和关闭连接。它对没有性能要求的简单应用程一个很好的选择。
  2. POOLED
    此数据源利用“池”的概念将JDBC连接对象组织起来,避免了在创建新的连接实例时所需要初始化和认证的时间。这种方式使得并发Web应用可以快速地响应请求,是当前流行的处理方式。
  3. JNDI
    此数据源可以在EJB或应用服务器等容器中使用。容器可以集中或在外部配置数据源,然后放置一个JNDI上下文的引用。
    4、<mapper>元素
    在配置文件中,元素用于指定MyBatis映射文件的位置,一般可以使用以下4种方法引入映射器文件,具体如下所示。
    1.使用类路径引入
<mappers>
	<mapper resource="com/ssm/mapper/UserMapper.xmI"/>
</mappers>

2.使用本地文件路径引入

<mappers>
	<mapper url=file: ///D:/com/ssm/mapper/UserMapper.xml"/>
</mappers>

3.使用接口类引入

<mappers>
	<mapper class="com. ssm.mapper.UserMapper"/>
</mappers>

4.使用包名引入

<mappers>
	<package name=""com. ssm. mapper"/>
</mappers>

三、映射文件

映射文件是 MyBatis框架中十分重要的文件,在映射文件中,<mapper>元素是映射文件的根元素,其他元素都是它的子元素。
1、<select>元素
用于映射查询语句,它用于从数据库中读取出数据,并组装数据给业务开发人员。

<select id="findUserById" parameterType="Integer" resultType="com.ssm.po.User">
select * from t_user where id=#{id}
</select>

上述语句中的唯一标识为findUserById,它接收一个 Integer类型的参数,并返回一个User类型的对象。
2、<insert>元素
用于映射插入语句,在执行完元素中定义的SQL语句后,会返回一个表示插入记录数的整数。

<!--//添加用户  -->
<insert id="addUser" parameterType="com.ssm.po.User">
insert into t_user(username,jobs,phone) values(#{username},#{jobs},#{phone})
</insert>

3、<update>、<delete>元素

<!--//更新用户  -->
<update id="updateUser" parameterType="com.ssm.po.User">
update t_user set username=#{username},jobs=#{jobs},phone=#{phone} where id=#{id}
</update>
<!--//删除用户  -->
<delete id="deleteUser" parameterType="Integer">
delete  from t_user where id=#{id}
</delete>

4、<sql>元素
元素的作用就是定义可重用的SQL代码片段,然后在其他语句中引用这一代码片段。
例如,定义一个包含id、username、jobs和 phone字段的代码片段如下。

<sql id="userColumns">id,username,Jobs, phone</sql>
<select id="findUserById" parameterType="Integer" resultType="com.ssm.po.User">
<!--select * from t_user where id=#{id}  -->
<!-- 使用include元素的refid属性引用自定义的代码片段,属性值为自定义的代码片段id -->
select <include refid="userColumns" />
from t_user
where id=#{id}
</select>

5、<resultMap>元素
<resultMap>用于实际开发时,数据库表中的列和需要返回的对象的属性不完全一致时,mybatis不会自动的赋值,用<resultMap>进行处理。
<resultMap>元素表示结果映射集,它的主要作是定义映射规则、级联更新以及定义类型转化器等。
<resultMap>元素中包含了一些子元素,它的元素结构如下所示。

<!-- resultMap的元素结构-->
<resultMap type="" id="">
<constructor>   <!--类在实例化时,用来注入结果到构造方法中-->
<idArg />    <!--ID参数;标记结果作为ID-->
<arg />      <!--注入到构造方法的一个普通结果-->
</constructor>
<id />           <!--用于表示哪个列是主键-->
<result />        <!--注入到字段或Javabean属性的普通结果-->
<association property="" />    <!--用于一对一关联-->
<collection property="" />      <!--用于一对多关联-->
<discriminator javaType="">   <!--使用结果值来决定使用哪个结果映射-->
<case value="" />       <!--基于某些值的结果映射-->
</discriminator>
</resultMap>

type属性为需要映射的POJO,id为这个resultMap的唯一标识。
constructor用于配置构造方法,当未定义无参构造方法时,可用constructor元素进行配置。
result表示POJO和数据表中普通列的映射关系。
discriminator用于处理一个单独数据库查询返回很多不同数据类型结果集的情况。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

点份炸鸡778

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值