MyBatis配置优化

一·属性优化

可以建立一个db.properties,然后从外部引入文件

db.properties:

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=false&useUnicode=true&characterEncoding=UTF8
username=root
password=123456

从外部引入: 

<properties resource="db.properties"></properties>
<?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>
<!--从外部引入配置文件-->
    <properties resource="db.properties"></properties>

    <environments default="development">
        <environment id="development">
            <!--事务管理器-->
            <transactionManager type="JDBC"/>
            <!--连接池-->
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com/he/dao/userDao/userMapper.xml"></mapper>
    </mappers>

</configuration>

二·别名优化 

可以给实体类起别名,可以优化代码。

1.可以添加别名,将具体的com.**.**.**转化成别名,可以自定义别名。

2.可以通过包名导入全部实体类,如下:

<!--别名alias可以自定义-->
<!--    <typeAliases>-->
<!--        <typeAlias type="com.he.pojo.User" alias="User"></typeAlias>-->
<!--    </typeAliases>-->

<!--别名的包导入方式-->
<!--别名为小写或大写(一般小写)开头的类名-->
<!--可在实体类前添加注解@Alias()自定义别名-->
    <typeAliases>
        <package name="com.he.pojo"/>
    </typeAliases>

以后的xml配置文件就可以用别名代替:

<insert id="insertUser" parameterType="User">
        insert into mybatis.user(id, username, pwd) VALUES(#{id},#{username},#{pwd})
    </insert>

3.Mapper映射器配置

有三种方式,一般用resource,注意是路径,用 / 隔开,下面两种需要保证文件名相同并且在同一个包下。

 <mappers>
<!--        <mapper resource="com/he/dao/userDao/UserMapper.xml"></mapper>-->
<!--下面两种需要保证Mapper与配置文件名字一致且在同一个包下面-->
<!--        <package name="com.he.dao.userDao"/>-->
        <mapper class="com.he.dao.userDao.UserMapper"></mapper>
    </mappers>

4.生命周期和作用域

SqlSessionFactoryBuilder

这个类可以被实例化、使用和丢弃,一旦创建了 SqlSessionFactory,就不再需要它了。 因此 SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)。 你可以重用 SqlSessionFactoryBuilder 来创建多个 SqlSessionFactory 实例,但最好还是不要一直保留着它,以保证所有的 XML 解析资源可以被释放给更重要的事情。

SqlSessionFactory

SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。 使用 SqlSessionFactory 的最佳实践是在应用运行期间不要重复创建多次,多次重建 SqlSessionFactory 被视为一种代码“坏习惯”。因此 SqlSessionFactory 的最佳作用域是应用作用域。 有很多方法可以做到,最简单的就是使用单例模式或者静态单例模式

SqlSession

每个线程都应该有它自己的 SqlSession 实例。SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。 绝对不能将 SqlSession 实例的引用放在一个类的静态域,甚至一个类的实例变量也不行。 也绝不能将 SqlSession 实例的引用放在任何类型的托管作用域中,比如 Servlet 框架中的 HttpSession。 如果你现在正在使用一种 Web 框架,考虑将 SqlSession 放在一个和 HTTP 请求相似的作用域中。 换句话说,每次收到 HTTP 请求,就可以打开一个 SqlSession,返回一个响应后,就关闭它。 这个关闭操作很重要,为了确保每次都能执行关闭操作,你应该把这个关闭操作放到 finally 块中。 

5.resultMap 

用于解决数据库字段和实体类属性不对应的情况 

<!--简单结果集映射-->
    <resultMap id="userMap" type="User">
        <result column="pwd" property="password"></result>
    </resultMap>

 不再使用resulType,使用resultMap:

<select id="getUserList" resultMap ="userMap">
        select * from mybatis.user
    </select>

上面的数据库里的字段名为pwd,实体类为password。将pwd映射成password。

还有一种解决方案就是给数据库字段起别名:

select pwd as password from user

 如果世界总是这么简单就好了!复杂的SQL有更复杂的映射!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值