MyBatis的使用(一)

首先,在没有学习mybatis之前,我们的操作数据库的代码基本上都是写在dao层(数据持久层),步骤如下:

1、加载数据库驱动
2、创建并获取数据库链接
3、创建jdbc statement对象
4、设置sql语句
5、设置sql语句中的参数(使用preparedStatement)
6、通过statement执行sql并获取结果
7、对sql执行结果进行解析处理
8、释放资源(resultSet、preparedstatement、connection)

jdbc问题总结:
1、数据库链接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库链接池可解决此问题。
2、Sql语句在代码中硬编码,造成代码不易维护,实际应用sql变化的可能较大,sql变动需要改变java代码。
3、使用preparedStatement向占位符号传参数存在硬编码,因为sql语句的where条件不一定,可能多也可能少,修改sql还要修改代码,系统不易维护。
4、对结果集解析存在硬编码(查询列名),sql变化导致解析代码变化,系统不易维护,如果能将数据库记录封装成pojo对象解析比较方便。

MyBatis介绍

MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis,实质上Mybatis对ibatis进行一些改进。
MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动、创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。
Mybatis通过xml或注解的方式将要执行的各种statement(statement、preparedStatemnt、CallableStatement)配置起来,并通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射成java对象并返回。

那么使用mybatis前,先要去下载地址下载mybatis;

下载包内容

mybatis-3.2.7.jar—-mybatis的核心包
lib—-mybatis的依赖包
mybatis-3.2.7.pdf—-mybatis使用手册

实例开发过程

第一步:创建java工程
使用myeclipse创建java工程。
第二步:加入jar包
加入mybatis核心包、依赖包、数据驱动包。
第三步:SqlMapConfig.xml
在classpath下的config目录下创建SqlMapConfig.xml
第四步:创建UserInfo.xml
classpath下的mapper目录下创建sql映射文件UserInfo.xml
第五步:加载映射文件
将UserInfo.xml添加在SqlMapConfig.xml中

<!--SqlMapConfig.xml配置信息-->

<?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>
    <!-- 和spring整合后 environments配置将废除-->
    <environments default="development">
        <environment id="development">
        <!-- 使用jdbc事务管理-->
            <transactionManager type="JDBC" />
        <!-- 数据库连接池-->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver" />
                <property name="url" value="jdbc:mysql://localhost:3306/bbs?characterEncoding=utf-8" />
                <property name="username" value="root" />
                <property name="password" value="1234" />
            </dataSource>
        </environment>
    </environments>
    <!--加载映射文件-->
    <mappers>
        <mapper resource="mapper/UserInfo.xml"/>
</mappers>


</configuration>
<!--UserInfo.xml配置信息-->
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
<mapper namespace="dao.UserDao">
    <select id="findUser" parameterType="entity.UserInfo" resultType="entity.UserInfo">
        select * from userinfo where loginName = #{loginName}
    </select>

</mapper>

原来的dao层接口实现类就被UserInfo.xml给代替了,但是有几处要注意:
1.定义mapper映射文件UserInfo.xml,需要修改namespace的值为 UserDao接口路径(如:dao.UserDao(包名.类名));
2.UserInfo.xml中id要和接口UserDao中对应的方法名相同,parameterType参数类型也要一致,resultType返回类型(如果返回是集合,那么用对象也能表示),而且也要是entity.UserInfo(包名.类名);
当然也可以在SqlMapConfig.xml中用typeAliases(类型别名)自定义别名,只需加入如下配置信息

<typeAliases>
    <!-- 批量别名定义,扫描整个包下的类,别名为类名(首字母大写或小写都可以) -->
    <package name="entity"/>
</typeAliases>

如果这样的话,UserInfo.xml中的配置信息就可以更改为

<!--UserInfo.xml配置信息-->
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
<mapper namespace="dao.UserDao">
    <select id="findUser" parameterType="userinfo" resultType="userinfo">
        select * from userinfo where loginName = #{loginName}
    </select>

</mapper>

3.service(服务层)如何实例化一个dao层对象

String resource="SqlMapConfig.xml";
InputStream i= Resources.getResourceAsStream(resource);
SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(is);
SqlSession session=factory.openSession();
//获取dao接口的代理对象
UserDao userdao=session.getMapper(UserDao.class);//注意此处要写接口类
userinfo=userdao.findUser(user.getLoginName());
session.close();

4.配置properties(属性)来优化mybatis
更改之后的SqlMapConfig.xml

<!--SqlMapConfig.xml配置信息-->

<?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="database.properties"/>
<typeAliases>
    <!-- 批量别名定义,扫描整个包下的类,别名为类名(首字母大写或小写都可以) -->
    <package name="entity"/>
</typeAliases>

    <!-- 和spring整合后 environments配置将废除-->
    <environments default="development">
        <environment id="development">
        <!-- 使用jdbc事务管理-->
            <transactionManager type="JDBC" />
        <!-- 数据库连接池-->
            <dataSource type="POOLED">
                <property name="driver" value="${database.driver}" />
                <property name="url" value="${database.url}" />
                <property name="username" value="${database.username}" />
                <property name="password" value="${database.password}" />
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="mapper/UserInfo.xml"/>
</mappers>


</configuration>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值