MyBatis基本工作原理

简介: Application是程序员开发的Java代码,蓝色为MyBatis框架.API是MyBatis提供的增删改查等功能接口.老式SQL写法我们在Dao中写SQL: SELECT * FROM user WHERE user_name = ?;而在MyBatis中没有完全封装JDBC,还需要预...

Application是程序员开发的Java代码,蓝色为MyBatis框架.

API是MyBatis提供的增删改查等功能接口.

老式SQL写法我们在Dao中写SQL: SELECT * FROM user WHERE user_name = ?;

而在MyBatis中没有完全封装JDBC,还需要预先写一下SQL语句,不过不用像之前那样大篇幅以及多设置了:(进行了简化)

看一下老式的Dao层写法: 通过用户ID查询用户返回用户实例:

///// * 通过用户ID查询用户实例返回给showUser
    public Customers queryCustomerByID(long cid) throws ClassNotFoundException, SQLException {
        Customers customer = null;
        Connection conn = null;
        PreparedStatement ps = null;
        ResultSet rs = null;
        String sql = "select * from Customers where customer_id = ?";
        try {
            conn = JDBCUtil.getConnection();
            ps = conn.prepareStatement(sql);
            ps.setLong(1, cid);
            rs = ps.executeQuery();
            while (rs.next()) {

                if (customer == null) {
                    customer = new Customers(
                            rs.getLong(1), 
                            rs.getString(2),
                            rs.getString(3),
                            rs.getString(4),
                            rs.getString(5),
                            rs.getLong(6),
                            rs.getDouble(7));
                }
            }
        } finally {
            JDBCUtil.close(rs, ps, null);
        }

        return customer;

    }/////* End queryCustomerByID

是不是很繁琐,尽管使用了有些日子,有些怀念,但是这样的冗余代码既然可以使用框架封装简化,为什么不用呢?

下面是在MyBatis中同样根据用户ID查用户返回用户实例: (customers.xml)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org/DTD Mapper 3.0" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="CustomersDao"> 
    <!-- CIns为CustomerInstance缩写,即用户实例 -->
    <select id="queryCInsByCid" parameterType="long" resultType="com.ykmimi.mybatis.entity.Customers">
        select * from Customers where customer_id = #{cid}
    </select>
</mapper>

mapper为映射,namespace是命名空间,当我们调用时就像调用某个Dao一样.

而select的 id 为 queryCInsByCid ,接收类型为long, 返回类型为Customers实例 (resultType指向了实体包中的Customers实体类)

假如这个程序里还有其他Dao层(老式写法),如: FoodsDao, PriceDao,那么只是将这些Dao类给转换了模式,变为了 namespace .这样的话好理解!

而命名空间mapper中包含的select或其他标签的 id ,即像是这个"Dao类中存在的一个方法" ,只不过简化了.

看图片知道,MyBatis进行了老式Dao层写法返回Customers实例的封装.而我们需要设置:

namespace (相当于Dao层名),

及内里功能标签的 id (相当于方法名),

parameterType (相当于方法参数类型设置) ,

resultType (相当于方法返回类型,只不过是全类名写法).

 那么这个SQL语句设置好后,程序运行,就会加载到JDBC,从而可以对数据库进行操作.

两个xml文件(看图),可以自定义名称,含有SQL语句的映射配置文件需在MyBatis配置文件中进行注册.

<?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>
    <!-- <typeAliases> <package name="com.xm.bean"/> </typeAliases> <properties 
        resource=""></properties> -->
    <!-- 配置mybatis运行环境 -->

    <environments default="cybatis">
        <environment id="cybatis">
            <!-- type="JDBC" 代表使用JDBC的提交和回滚来管理事务 -->
            <transactionManager type="JDBC" />
            <!-- mybatis提供了3种数据源类型,分别是:POOLED,UNPOOLED,JNDI -->
            <!-- POOLED 表示支持JDBC数据源连接池 -->
            <!-- UNPOOLED 表示不支持数据源连接池 -->
            <!-- JNDI 表示支持外部数据源连接池 -->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver" />
                <property name="url"
                    value="jdbc:mysql://localhost:3306/ordersystem" />
                <property name="username" value="hr" />
                <property name="password" value="system" />
            </dataSource>
        </environment>

    </environments>

    <!-- 配置 mapper文件 -->
    <mappers>
        <mapper resource="com/ykmimi/mybatis/mapper/customers.xml" />
    </mappers>


</configuration>

最后,ORM表示Object, Relationship, Mapping

如图所示,

Application是Java程序代码,其中数据是对象类型

Relationship是关系型数据库/表

Mapping是框架的功能表示映射

那么,空口无凭,写一个小程序出来,看看MyBatis的作用吧!见下篇.

 

将编程看作是一门艺术,而不单单是个技术。 敲打的英文字符是我的黑白琴键, 思维图纸画出的是我编写的五线谱。 当美妙的华章响起,现实通往二进制的大门即将被打开。
相关文章
|
5月前
|
SQL XML Java
|
5月前
|
SQL XML Java
一文搞懂Mybatis执行原理
一文搞懂Mybatis执行原理
160 1
|
5月前
|
SQL Java 数据库连接
mybatis常见分页技术和自定义分页原理实战
mybatis常见分页技术和自定义分页原理实战
202 0
|
16天前
|
SQL XML Java
Mybatis的原理和MybaitsPlus
这篇文章对比分析了Mybatis和Mybatis Plus的特点与底层实现机制,探讨了两者之间的差异及各自的优势。
36 0
|
3月前
|
SQL Java 数据库连接
springboot~mybatis-pagehelper原理与使用
【7月更文挑战第15天】MyBatis-PageHelper是用于MyBatis的分页插件,基于MyBatis的拦截器机制实现。它通过在SQL执行前动态修改SQL语句添加LIMIT子句以支持分页。使用时需在`pom.xml`添加依赖并配置方言等参数。示例代码: PageHelper.startPage(2, 10); List&lt;User&gt; users = userMapper.getAllUsers(); PageInfo&lt;User&gt; pageInfo = new PageInfo&lt;&gt;(users); 这使得分页查询变得简单且能获取总记录数等信息。
|
4月前
|
SQL Java 数据库连接
深入探索MyBatis Dynamic SQL:发展、原理与应用
深入探索MyBatis Dynamic SQL:发展、原理与应用
|
3月前
|
SQL Java 数据库连接
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
64 0
|
4月前
|
Java 数据库连接 数据库
MyBatis TypeHandler详解:原理与自定义实践
MyBatis TypeHandler详解:原理与自定义实践
|
4月前
|
SQL Java 数据库连接
MyBatis插件深度解析:功能、原理、使用、应用场景与最佳实践
MyBatis插件深度解析:功能、原理、使用、应用场景与最佳实践
|
5月前
|
存储 缓存 Java
探秘MyBatis缓存原理:Cache接口与实现类源码分析
探秘MyBatis缓存原理:Cache接口与实现类源码分析
86 2
探秘MyBatis缓存原理:Cache接口与实现类源码分析