美文网首页
手写Mybatis

手写Mybatis

作者: Zeppelin421 | 来源:发表于2021-08-07 23:14 被阅读0次

JDBC问题分析

public static void main(String[] args) {
    Connection connection = null;
    PreparedStatement preparedStatement = null;
    ResultSet resultSet = null;
    try {
        // 加载数据库驱动
        Class.forName("com.mysql.jdbc.Driver");
        // 通过驱动管理类获取数据连接
        connection = DriverManager.getConnection(
"jdbc:mysql://local:3306/mybatis?characterEncoding=utf-8", "root", "root");
        // 定义sql语句 ?表示占位符
        String sql = "select * from user where username = ?";
        // 获取预处理statement
        preparedStatement = connection.prepareStatement(sql);
        // 设置参数,第一个参数为sql语句中参数的序号
        preparedStatement.setString(1, "tom");
        // 向数据库发出sql执行查询,查询出结果集
        resultSet = preparedStatement.executeQuery();
        // 遍历查询结果集
        while (resultSet.next()) {
            int id = resultSet.getInt("id");
            String username = resultSet.getString("username");
            
            user.setId(id);
            user.setUserName(username);
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        connection.close();
    }
}

自定义持久层框架设计思路

使用者(项目):引入自定义持久层框架的jar包

提供两部分配置信息

  • 数据配置信息
  • sql配置信息:sql语句、参数类型、返回值类型

使用配置文件来提供这两部分配置信息

  • sqlMapConfig.xml:存放数据库配置信息,存放mapper.xml的全路径
  • mapper.xml:存放sql配置信息

自定义持久层框架本身(工程):本质就是对JDBC代码进行了封装

加载配置文件
根据配置文件的路径,加载配置文件成字节输入流,存储在内存中
创建Resource类 InputStream getResourceAsString(String path)

创建容器对象
Configuration(核心配置类):存放sqlMapConfig.xml解析出来的内容
MappedStatement(映射配置类):存放mapper.xml解析出来的内容

解析配置文件
创建类 SqlSessionFactoryBuilder.build(InputStream in)
1、使用dom4j解析配置文件,将解析出来的内容封装到容器对象中
2、创建SqlSessionFactory对象,生成SqlSession会话对象(工厂模式)

创建SqlSessionFactory接口及实现类DefaultSqlSessionFactory
openSession()生产sqlSession

创建SqlSession接口及实现类DefaultSqlSession
定义对数据库的crud操作selectList()、selectOne()、update()、delete()

创建Executor接口及实现类SimpleExecutor
query(Configuration, MappedStatement, Object... params) 执行JDBC代码

源码地址:https://gitee.com/hooda/lagou-homework/tree/master/Stage-01/Module-01

相关文章

网友评论

      本文标题:手写Mybatis

      本文链接:https://www.haomeiwen.com/subject/jrbrmltx.html