Mybatis入门 案例—-基础搭建(一)

概念:mybatis主要完成定制化的sql,存储过程以及高级映射的优秀的持久层框架,通俗来讲就是与数据库进行交互的框架。

作用:1.封装jdbc操作 2.利用反射完成sql语句之间的相互转换

mybatis的配置文件:1.核心配置文件,一般命名为:mybatis-config.xml或者sqlconfig.xml

一、环境入门搭建

  • 目录截图

    1.首先创建一个maven项目,接着创建一张数据表,导入我们所需要的坐标

  junitjunit4.12testorg.mybatismybatis3.5.5test

2.创建一个放实体类的包,这个包为com.xxx.pojo

3.此外还要接着创建一个包,com.xxx.mapper(这个包可以用来放接口)

4.在resourses资源包下创建核心配置文件mybatis-config.xml

5.在resourses资源包下创建一个和接口同级目录的包用来存放接口映射文件GoodsMapper.xml

二、修改配置文件

因为我的配置文件都已经配置了模板,如果第一次配置的话最好去mybatis官网进行配置,因为粘贴的会容易导致版本错乱。

mybatis-confog.xml(这个文件主要是配置数据源,我们一般使用jdbc,这个可以一定程度上进行简化)

  • 这个是一个最基础的核心配置文件,不可缺少

GoodsMapper.xml (这个文件是接口的映射文件,这其中用到了反射的知识)

三、开始编码

1.编码可以从实体类开始,我一般习惯于从接口开始,报错的时候,缺什么补什么,但是作为mybatis入门案例,我们就从实体类开始

Goods.java

package com.ppf.pojo;
public class Goods {
    private Integer id;
    private String type;
    private Integer price;
    private String gName;
    private String description;

    public Goods() {
    }

    public Goods(Integer id, String type, Integer price, String gName, String description) {
        this.id = id;
        this.type = type;
        this.price = price;
        this.gName = gName;
        this.description = description;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public Integer getPrice() {
        return price;
    }

    public void setPrice(Integer price) {
        this.price = price;
    }

    public String getgName() {
        return gName;
    }

    public void setgName(String gName) {
        this.gName = gName;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    @Override
    public String toString() {
        return "Goods{" +
                "id=" + id +
                ", type='" + type + ''' +
                ", price=" + price +
                ", gName='" + gName + ''' +
                ", description='" + description + ''' +
                '}';
    }
}

2.提出一个需求:

    查询所有的数据(这是最简单也最容易上手的需求)

GoodsMapper.java

package com.ppf.mapper;
import com.ppf.pojo.Goods;
import java.util.List;
public interface GoodsMapper {
    List selectAll();
}
  • 注意:这里selectAll()这个方法会报错,不要紧,我们使用alt+回车键,就会在GoodsMapper中自动创建一个select标签,在里面写sql语句就可以
  • 注意:这里的goods会报红,你可以选择忽视,如果不能接受,你可以在idea的右侧菜单栏database中连接数据库,它就会恢复正常

3.接着我们来写一个测试类(可以在test下的java中创建一个Test.java)的测试类,然后在pom.xml中导入junit的坐标

TestDemo.java:测试类


import com.ppf.mapper.GoodsMapper;
import com.ppf.pojo.Goods;
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.Test;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

public class TestDemo {
    @Test
    public void selectAll() throws IOException {
        //1. 加载mybatis的核心配置文件,获取 SqlSessionFactory
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //2. 获取SqlSession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession();
//        3. 执行sql
        GoodsMapper mapper = sqlSession.getMapper(GoodsMapper.class);
        List goods = mapper.selectAll();
        System.out.println(goods);
        //4. 释放资源
        sqlSession.close();
    }
}
总结:这就是一个最基本的mybatis项目,其中没有用到起别名,也没用到包扫描,甚至没用到注解,但是作为入门更有利于大家的理解。

【信息由网络或者个人提供,如有涉及版权请联系COOY资源网邮箱处理】

© 版权声明
THE END
喜欢就支持一下吧
点赞11 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容