博客
关于我
MyBatis(五):MyBatis简介及基本使用
阅读量:759 次
发布时间:2019-03-23

本文共 4461 字,大约阅读时间需要 14 分钟。

  1. MyBatist简介

    ​ MyBatis是一款优秀的基于ORM的半自动轻量级持久层框架,它支持定制化SQL、存储过程以及高级映

    射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的

    XML或注解来配置和映射原生类型、接口和Java的POJO (Plain Old Java Objects,普通老式Java对 象)

    为数据库中的记录。

  2. MyBatis的优点

    ​ 半自动化的持久层框架,对开发人员开说,核心sql还是需要自己进行优化,sql和java编码进行分离,功能边界清晰,一个专注业务,一个专注数据。

  3. MyBatis基本使用

  • 引入依赖

    mysql
    mysql-connector-java
    8.0.23
    org.mybatis
    mybatis
    3.4.6
    junit
    junit
    4.13.1
  • 编写实体类

    package com.rangers.entity;/** * @Author Rangers * @Description * @Date 2021-03-04 **/public class User {    private int id;    private String name;    private String address;    @Override    public String toString() {        return "com.rangers.entity.User{" +                "id=" + id +                ", name='" + name + '\'' +                ", address='" + address + '\'' +                '}';    }    public int getId() {        return id;    }    public void setId(int id) {        this.id = id;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public String getAddress() {        return address;    }    public void setAddress(String address) {        this.address = address;    }}
  • 编写核心配置文件SqlMapConfig.xml

  • 编写接口方法类及映射文件XxMapper.xml

    package com.rangers.dao;import com.rangers.entity.User;import java.util.List;/** * @Author Rangers * @Description * @Date 2021-03-10 **/public interface IUserDao {    List
    findAll(); User findOne(User user); int insertUser(User user); int updateUser(User user); int deleteUser(User user);}
    insert into user(id,name,address) values(#{id},#{name},#{address})
    update user set name=#{name},address=#{address} where id=#{id}
    delete from user where id = #{id}
  • 编写测试类

package com.rangers;import com.rangers.dao.IUserDao;import com.rangers.entity.User;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.After;import org.junit.Before;import java.io.IOException;import java.io.InputStream;import java.util.List;/** * @Author Rangers * @Description * @Date 2021-03-10 **/public class Test {    private IUserDao userDao;    SqlSession sqlSession ;    @Before    public void before() throws IOException {        InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);        sqlSession = sqlSessionFactory.openSession();        userDao = sqlSession.getMapper(IUserDao.class);    }    @org.junit.Test    public void testFindAll(){        List
users = userDao.findAll(); System.out.println(users); } @org.junit.Test public void testFindOne(){ User param = new User(); param.setId(1); User user = userDao.findOne(param); System.out.println(user); } @org.junit.Test public void testInsert(){ User param = new User(); param.setId(3); param.setName("bug"); param.setAddress("北京"); boolean flag = userDao.insertUser(param)>0; System.out.println("新增结果:"+flag); } @org.junit.Test public void testUpdate(){ User param = new User(); param.setId(3); param.setName("虫子"); param.setAddress("北京"); boolean flag = userDao.updateUser(param)>0; System.out.println("修改结果:"+flag); } @org.junit.Test public void testDelete(){ User param = new User(); param.setId(3); boolean flag = userDao.deleteUser(param)>0; System.out.println("删除结果:"+flag); } @After public void close(){ System.out.println("关闭连接"); // 提交事务 sqlSession.commit(); // 关闭连接 sqlSession.close(); }}

转载地址:http://bwmzk.baihongyu.com/

你可能感兴趣的文章
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_使用NIFI表达式语言_来获取自定义属性中的数据_NIFI表达式使用体验---大数据之Nifi工作笔记0024
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_内嵌ZK模式集群2_实际操作搭建NIFI内嵌模式集群---大数据之Nifi工作笔记0016
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>