mybatis01---初识

1简介

1.1上面是Mybatis

  • MyBatis 是一款优秀的持久层框架

  • 它支持自定义 SQL、存储过程以及高级映射

  • MyBatis 免除了几乎所有的 JDBC 代码以及设置参数获取****结果集的工作

  • MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录

  • MyBatis 本是apache的一个开源项目ibatis, 2010年这个项目由apache 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到github

  • Mybatis官方文档 : http://www.mybatis.org/mybatis-3/zh/index.html

GitHub : https://github.com/mybatis/mybatis-3

https://github.com/mybatis/mybatis-3/releases可以看到源码和不同版本的mybatis

maven仓库https://mvnrepository.com/在里面搜mybatis,找到想用的版本点进去,复制框框里面的话也就是依赖到pom.xml。

1.2持久化

数据持久化

持久化是将程序数据在持久状态和瞬时状态间转换的机制。

内存的特点是:断电即失,而数据库jdbc和io文件是持久化机制。

在生活中 : 将鲜肉冷藏,吃的时候再解冻的方法也是。将水果做成罐头的方法也是这样。

即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的对象存储在数据库中,或者存储在磁盘文件中、XML数据文件中等等。

*为什么需要持久化?*由于内存本身的缺陷引起的

  1. 内存断电后数据会丢失,但有一些对象是无论如何都不能丢失的,比如银行账号等,遗憾的是,人们还无法保证内存永不掉电。
  2. 内存过于昂贵,与硬盘、光盘等外存相比,内存的价格要高2~3个数量级,而且维持成本也高,至少需要一直供电吧。所以即使对象不需要永久保存,也会因为内存的容量限制不能一直呆在内存中,需要持久化来缓存到外存。

1.3持久层

持久化是一个动作,持久层是完成持久化工作的代码块。dao层 【DAO (Data Access Object) 数据访问对象】

Dao层,Service层,Controller层。。。

  • 大多数情况下特别是企业级应用,数据持久化往往也就意味着将内存中的数据保存到磁盘上加以固化,而持久化的实现过程则大多通过各种关系数据库来完成。
  • 层界限十分明显
  • 我们的系统架构中,应该有一个相对独立的逻辑层面,专注于数据持久化逻辑的实现。与系统其他部分相对而言,这个层面应该具有一个较为清晰和严格的逻辑边界。【说白了就是用来**操作数据库**存在的!】

1.4为什么需要mybatis

Mybatis就是帮助程序猿将数据存入数据库中 , 和从数据库中取数据

传统的jdbc操作 , 有很多重复代码块 .比如 : 数据取出时的封装 , 数据库的建立连接等等… , 通过框架可以减少重复代码,提高开发效率 .

不用mybatis依旧可以做到,只是用了会更加简单。

MyBatis 是一个半自动化的ORM框架 (Object Relationship Mapping) -->对象关系映射

优点:

  • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件就可以了,易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
  • 提供xml标签,支持编写动态sql。
  • 最重要的一点,使用的人多!公司需要!

2Mybatis第一个程序

思路流程:搭建环境–>导入Mybatis—>编写代码—>测试

2.1搭建环境–实验数据库

在猫里面创建数据库mybatis(名字而已),数据库里创建表,表里面插入数据;

2.2导入mybatis

步骤:

  1. 首先创建一个普通的maven项目

  2. 删除src文件夹(目录),这样写的就是一个父工程了

  3. 在这个工程的pom.xml导入依赖

    1. 数据库的mysql驱动

      
          mysql
          mysql-connector-java
          5.1.47
      
      

      mybatis的

      
          org.mybatis
          mybatis
          3.5.2
      
      

      junit的

      
          junit
          junit
          4.12
      
      
  4. 在这个工程下面新建一个module,这样的话这个模块的父就是这个工程,在工程导入的东西不需要再给模块导了。

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T1o02kTV-1620379896903)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20210507105845293.png)]

    父工程出现模块

    
    com.kuang
    Mybatis-Study
    pom
    1.0-SNAPSHOT
    
        mybatis-01
    
    

    同时模块的pom.xml,可看到他的父和自己的名字

    
        Mybatis-Study
        com.kuang
        1.0-SNAPSHOT
    
    4.0.0
    
    mybatis-01
    

    4.1编写mybatis的核心配置文件

    • 模块的src/main/resources下新建一个xml文件mybatis-config.xml

      官方示例

      
      
      <configuration>
        <environments default="development">
          <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
              <property name="driver" value="${driver}"/>
              <property name=

你可能感兴趣的:(框架,mybatis)