mybatis框架的配置

1)mybatis配置

            SqlMapConfig.xml,此文件作为mybatis的全局配置文件,配置了mybatis的运行环境等信息。(这个名字是随便取的)

            mapper.xml文件即sql映射文件,文件中配置了操作数据库的sql语句。此文件需要在SqlMapConfig.xml中加载。

2)通过mybatis环境等配置信息构造SqlSessionFactory即会话工厂

3)由会话工厂创建sqlSession即会话,操作数据库需要通过sqlSession进行。

4)mybatis底层自定义了Executor执行器接口操作数据库,Executor接口有两个实现,一个是基本执行器、一个是缓存执行器。

5)Mapped Statement也是mybatis一个底层封装对象,它包装了mybatis配置信息及sql映射信息等。mapper.xml文件中一个sql对应一个Mapped Statement对象,sql的id即是Mapped statement的id。

6)Mapped Statement对sql执行输入参数进行定义,包括HashMap、基本类型、pojo,Executor通过Mapped Statement在执行sql前将输入的java对象映射至sql中,输入参数映射就是jdbc编程中对preparedStatement设置参数。

7)Mapped Statement对sql执行输出结果进行定义,包括HashMap、基本类型、pojo,Executor通过Mapped Statement在执行sql后将输出结果映射至java对象中,输出结果映射过程相当于jdbc编程中对结果的解析处理过程。


SqlMapConfig.xml配置文件

a)配置内容:
    propertis(属性) 下边有例子

    settings(全局配置参数)   mybatis全局配置参数,全局参数将会影响mybatis的运行行为

    typeAliases(类型别名)     类型别名(mybatis支持别名和自定义别名)下边有例子

    typeHandlers(类型处理器)mybatis自带的类型处理器基本上满足日常需求,不需要单独定义(进行后台语言和数据库类型间的转换)

    objectFactory(对象工厂)

    plugins(插件)

    environments(环境集合属性对象)

             environment(环境子属性对象)

                       transactionManager(事物管理)

                       dataSource(数据源)

    mapper(映射器)下边有例子

b)各个配置内容具体使用

    SqlMapConfig.xml可以引用java属性文件中的配置信息如下:

    定义一个db.properties文件

   

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

sqlMapConfig.xml中引用它


<properties resource="db.properties"/>
	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC"/>
			<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>
		</environment>
	</environments>

 MyBatis 将按照下面的顺序来加载属性:

           在 properties素体内定义的属性首先被读取。

           然后会读取properties元素中resource或 url 加载的属性,它会覆盖已读取的同名属性。

           最后读取parameterType传递的属性,它会覆盖已读取的同名属性。

 

因此,通过parameterType传递的属性具有最高优先级,resource或 url 加载的属性次之,最低优先级的是 properties 元素体内定义的属性。

 

在SqlMapConfig.xml中配置别名

<typeAliases>
	<!-- 单个别名定义 -->
	<typeAlias alias="user" type="cn.itcast.mybatis.po.User"/>
	<!-- 批量别名定义,扫描整个包下的类,别名为类名(首字母大写或小写都可以) -->
	<package name="cn.itcast.mybatis.po"/>
	<package name="其它包"/>
</typeAliases>

mapper的配置

使用相对于类路径的资源
如:<mapper resource="sqlmap/User.xml" />

使用完全限定路径
如:<mapper url="file:///D:\workspace_spingmvc\mybatis_01\config\sqlmap\User.xml" />

注册指定包下的所有mapper接口
如:<package name="cn.itcast.mybatis.mapper"/>


使用mapper接口类路径
如:<mapper class="cn.itcast.mybatis.mapper.UserMapper"/>


2)mapper.xml


#{}和$()的区别
使用占位符#{}可以有效防止sql注入,在使用时不需要关心参数值的类型,mybatis会自动进行java类型和jdbc类型的转换。#{}可以接收简单类型值或pojo属性值,如果parameterType传输单个简单类型值,#{}括号中可以是value或其它名称。
${}和#{}不同,通过${}可以将parameterType 传入的内容拼接在sql中且不进行jdbc类型转换, ${}可以接收简单类型值或pojo属性值,如果parameterType传输单个简单类型值,${}括号中只能是value。使用${}不能防止sql注入,但是有时用${}会非常方便,


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值