Mybatis 1

1.Mybatis是什么?
MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动、创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。
Mybatis通过xml或注解的方式将要执行的各种statement(statement、preparedStatemnt、CallableStatement)配置起来,并通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射成java对象并返回。

2 Jdbc问题总结
1、数据库连接频繁开启和关闭,会严重影响数据库的性能。
2、代码中存在硬编码,分别是数据库部分的硬编码和SQL执行部分的硬编码。

Mybatis框架原理(核心)
3.1框架图
在这里插入图片描述
3.2分析结论

  1. mybatis配置文件,包括:Mybatis全局配置文件和Mybatis映射文件.
    全局配置文件配置了数据源、事务等信息;
    映射文件配置了SQL执行相关的 信息。
  2. mybatis通过读取配置文件信息(全局配置文件和映射文件),构造出SqlSessionFactory,即会话工厂。
  3. SqlSessionFactory,可以创建SqlSession即会话。Mybatis是通过SqlSession来操作数据库的。
  4. SqlSession本身不能直接操作数据库,它是通过底层的Executor执行器接口来操作数据库的。Executor接口有两个实现类,一个是普通执行器,一个是缓存执行器(默认)。
  5. Executor执行器要处理的SQL信息是封装到一个底层对象MappedStatement中。
    该对象包括:SQL语句、输入参数映射信息、输出结果集映射信息。
    输入参数和输出结果的映射类型包括java的简单类型、HashMap集合对象、POJO对象类型。

使用main配置文件方式运行

 public static void main(String[] args) throws IOException
    {
//        1.读取配置文件
        InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
//        2.创建sqlSession工厂
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        SqlSessionFactory sessionFactory = builder.build(in);
//        3.创建 sqlSession
        SqlSession sqlSession = sessionFactory.openSession();
//        4.使用 sqlSession 创建dao代理类
        UserDao userDao = sqlSession.getMapper(UserDao.class);
//        5.使用代理对象执行方法
        List<User> userList = userDao.findAll();
        for (User user : userList)
        {
            System.out.println(user);
        }
//        6.释放资源
        sqlSession.close();
        in.close();


    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值