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、
元素
是一个配置属性的元素,它通过外部配置来动态替换内部定义的属性。例如,数据库的连接等属性,具体方式如下:
(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 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、
元素
元素主要用于改变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、
元素
元素用于在配置文件中对环境进行配置。MyBatis的环境配置实际上就是数据源的配置,可以通过元素配置多种数据源,即配置多种数据库。
对于数据源的配置,MyBatis框架提供了UNPOOLED、POOLED和JNDI三种数据源类型。
元素<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框架中十分重要的文件,在映射文件中,
元素是映射文件的根元素,其他元素都是它的子元素。
1、元素
用于映射查询语句,它用于从数据库中读取出数据,并组装数据给业务开发人员。
<select id="findUserById" parameterType="Integer" resultType="com.ssm.po.User">
select * from t_user where id=#{id}
</select>
上述语句中的唯一标识为findUserById,它接收一个 Integer类型的参数,并返回一个User类型的对象。
2、
元素
用于映射插入语句,在执行完元素中定义的SQL语句后,会返回一个表示插入记录数的整数。
<!--//添加用户 -->
<insert id="addUser" parameterType="com.ssm.po.User">
insert into t_user(username,jobs,phone) values(#{username},#{jobs},#{phone})
</insert>
3、
元素
<!--//更新用户 -->
<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代码片段,然后在其他语句中引用这一代码片段。
例如,定义一个包含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、
元素
用于实际开发时,数据库表中的列和需要返回的对象的属性不完全一致时,mybatis不会自动的赋值,用
进行处理。
元素表示结果映射集,它的主要作是定义映射规则、级联更新以及定义类型转化器等。
元素中包含了一些子元素,它的元素结构如下所示。
<!-- 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用于处理一个单独数据库查询返回很多不同数据类型结果集的情况。