MyBatis01:第一个程序

文章目录


MyBatis简介

 

一、Mybatis是什么?

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

二、持久化

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

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

         JDBC就是一种持久化机制。文件IO也是一种持久化机制。

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

  2.为什么需要持久化服务呢?那是由于内存本身的缺陷引起的    

          存断电后数据会丢失,但有一些对象是无论如何都不能丢失的,比如银行账号等,遗憾的是,人们还无法保证内存永不掉电。

          内存过于昂贵,与硬盘、光盘等外存相比,内存的价格要高2~3个数量级,而且维持成本也高,至少需要一直供电吧。所以即使对象不需要永久保存,也会因为内存的容量限制不能一直呆在内存中,需要持久化来缓存到外存

三、持久层

      什么是持久层?      

           完成持久化工作的代码块 .  ---->  dao层 

          大多数情况下特别是企业级应用,数据持久化往往也就意味着将内存中的数据保存到磁盘上加以固化,而持久化的实现过程则大多通过各种关系数据库来完成。

四、为什么需要Mybatis        

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

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

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

         所有的事情,不用Mybatis依旧可以做到,只是用了它,所有实现会更加简单!技术没有高低之分,只有使用这个技术的人有高低之别


五、MyBatis的优点

      简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件就可以了,易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。

      灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。

     解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。

     提供xml标签,支持编写动态sql。
     最重要的一点,使用的人多!公司需要!

六、代码演示

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

  1.搭建实验数据库

     

2.打开IDEA,创建一个maven项目

 

3. 导入依赖的jar包

4.创建一个实体类Book

 

5.编写mapper映射文件(编写SQL)

 

6.编写数据源properties文件

 

7.编写全局配置文件(主要是配置数据源信息)

 8.编写dao类

 9.测试

import com.yhb.qy145.seventh.dao.BookDao;
import com.yhb.qy145.seventh.entity.Book_info;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;

import java.io.Reader;
import java.util.List;

public class BookTest {
    /**
     * @program:Mydati06
     *
     * @description:
     *
     *@author:
     *
     *@create:2021-12-0119:00
     **/
    private SqlSession session;
    @Before
    public void Before()throws Exception{
        Reader reader = Resources.getResourceAsReader("mybatis.xml");
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
        session = sessionFactory.openSession();
    }
  //id查询
    @Test
    public void test01(){
        BookDao bookDao = session.getMapper(BookDao.class);
        Book_info book_info = bookDao.selectById(1007);
        System.out.println(book_info);

    }
  //查询
    @Test
    public void test02(){
        BookDao bookDao =session.getMapper(BookDao.class);
        List<Book_info> list = bookDao.selectAll();
        System.out.println(list);
    }
  //增加
    @Test
    public void teat03(){
        BookDao  bookDao = session.getMapper(BookDao.class);
        Book_info b = new Book_info();
        b.setName("三国演义");
        b.setAuthor("施耐庵");
        b.setPrice(35);
        b.setPub("人民出版社");
        bookDao.insertBook(b);
        session.commit();
    }
  //删除
    @Test
    public void test04(){
        BookDao bookDao = session.getMapper(BookDao.class);
        bookDao.deleteBook(1011);
        session.commit();
    }
  //修改
    @Test
    public void test05(){
        BookDao bookDao = session.getMapper(BookDao.class);
        Book_info b = new Book_info();
        b.setId(1001);
        b.setName("水浒传");
        b.setAuthor("施耐庵");
        b.setPrice(88);
        b.setPub("人民出版社");
        bookDao.updateBook(b);
        session.commit();
    } 

总结

1.编写mapper.xml,书写SQL,并定义好SQL的输入参数,和输出参数
2.编写全局配置文件,配置数据源,以及要加载的mapper.xml文件
3.通过全局配置文件,创建SqlSessionFactory
4.每次进行CRUD时,通过SqlSessionFactory创建一个SqlSession
5.调用SqlSession上的selectOne,selectList,insert,delete,update等方法,传入mapper.xml中SQL标签的id,以及输入参数

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值