[mybatis]快速搭建一个mybatis程序,实现对数据的增删改查

  • MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。
  • MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。
  • MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
  • MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github

持久层

  • 持久化是转换处于持久化状态的程序数据的过程
    [En]

    persistence is the process of transforming the data of a program in a persistent state*

  • 内存,断电即逝

为什么需要mybatis

  • 帮助程序员将数据存储在数据库中。
    [En]

    help programmers store data in the database.*

  • 方便
  • 传统的jdbc代码太复杂了,简化,框架,自动化
  • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件。
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰。sql和代码的分离,提高了可维护性。
  • 提供映射标签,支持对象与数据库的orm字段关系映射。
  • 提供对象关系映射标签,支持对象关系构建和维护。
    [En]

    provide object-relational mapping tags to support object-relational construction and maintenance.*

  • 提供xml标签,支持编写动态sql。

一个mybatis程序

1.创建一个数据库

2.在maven项目的pom.xml文件中导入依赖文件


        mysql
        mysql-connector-java
        8.0.29

        junit
        junit
        4.13.1

    org.mybatis
    mybatis
    3.5.9

3.在资源文件夹下命名一个mybatis_config.xml的核心配置文件


4.编写操作数据库要用的SQLSession对象并且封装成一个工具类

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 java.io.IOException;
import java.io.InputStream;

/**
 * @author panglili
 * @create 2022-07-21-14:49
 */
public class MybatisUtil {
    static SqlSessionFactory build;
    static {
        String resource="mybatis-config.xml";
        InputStream inputStream = null;
        try {
            inputStream = Resources.getResourceAsStream(resource);

            build = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }

    }

    //通过sqlSessionFactoryBuild创建拿到了工厂,由这个工厂就可以拿到sqlSession了
    //sqlSession中封装了所有操作数据库的代码
    public static SqlSession getSqlSession(){
        SqlSession sqlSession = build.openSession();

        return sqlSession;
    }
}

5.与数据库对应的实体类

package pojo;

import java.util.Date;

/**
 * @author panglili
 * @create 2022-07-21-15:01
 */
public class perple {
    private int id;
    private String name;
    private int age;
    private Date birth;

    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 int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public Date getBirth() {
        return birth;
    }

    public void setBirth(Date birth) {
        this.birth = birth;
    }

    @Override
    public String toString() {
        return "perple{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", birth=" + birth +
                '}';
    }
}

6.接口与接口的配置操作数据库文件,尽量命名为相同

package mapper;

import pojo.perple;

import java.util.List;

/**
 * @author panglili
 * @create 2022-07-21-15:07
 */
public interface perpleMapper {

    //查询所有信息
    List perples();

    //通过id查询某个用户
    perple queryById();
}

        select * from perple;

7.注册到mybatis配置文件


8.测试

package mapper;
import org.apache.ibatis.session.SqlSession;
import pojo.perple;
import util.MybatisUtil;
import java.util.List;
/**
 * @author panglili
 * @create 2022-07-21-15:16
 */
public class perpleTest {
    public void test(){
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        perpleMapper mapper = sqlSession.getMapper(perpleMapper.class);
        List perples = mapper.();
        for(int i=0;i

最后可能会遇到静态资源过滤的问题需要在pom配置文件加上处理


            src/main/resources

                **/*.properties
                **/*.xml

            true

            src/main/java

                **/*.properties
                **/*.xml

            true

完整的增删改查

package mapper;

import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import pojo.perple;
import util.MybatisUtil;

import javax.print.attribute.standard.DateTimeAtCompleted;
import java.util.Date;
import java.util.List;

/**
 * @author panglili
 * @create 2022-07-21-15:16
 */
public class perpleTest {
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    perpleMapper mapper = sqlSession.getMapper(perpleMapper.class);

    @Test
    public void test(){
         List perples = mapper.queryAll();
        for(int i=0;i

一定要记得开启事务!!!

Original: https://www.cnblogs.com/lumanmanqixiuyuanxi/p/16512525.html
Author: 路漫漫qixiuyuanxi
Title: [mybatis]快速搭建一个mybatis程序,实现对数据的增删改查

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/505170/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 笔记-docker学习-1

    一、docker安装 1、CentOS Docker安装 安装命令如下: curl -fsSL https://get.docker.com | bash -s docker –…

    数据库 2023年6月9日
    058
  • 没有发生GC也进入了安全点?这段关于安全点的JVM源码有点意思!

    文末 JVM 思维导图,有需要的可以自取 熟知并发编程的你认为下面这段代码的执行结果是怎么样的? 我如果说,执行流程是: t1 线程和 t2 线程一直执行 num 的累加操作 主线…

    数据库 2023年6月16日
    099
  • 使用Ant从零开始搭建tomcat源码环境

    使用Ant从零开始搭建tomcat源码环境 视频教程 准备工作 编辑 Idea,且装上Checkstyle插件(或者其他开发工具) 编译依赖的Jar包. 开始搭建 搭建编译环境 安…

    数据库 2023年6月11日
    0102
  • InnoDB 中不同SQL语句设置的锁

    锁定读、UPDATE 或 DELETE 通常会给在SQL语句处理过程扫描到的每个索引记录上设置记录锁。语句中是否存在排除该行的WHERE条件并不重要。InnoDB不记得确切的WHE…

    数据库 2023年5月24日
    082
  • 高并发组件了解

    消息队列 A服务和多个服务耦合,内部维护对多个服务发送数据的接口,那么这些接口如果有的挂了,有的不需要了,那么还得修改A内部的代码,如果使用MQ,A发送消息就好,不必考虑那么多事情…

    数据库 2023年6月16日
    067
  • Matplotlib(基本用法)

    Matplotlib 是数据分析绘图的常见模块,可以算是 2D-绘图(Python)领域使用最广泛的套件,可以将数据图形化,并且提供多样化的输出格式,利于数据的显示并分析。 接下来…

    数据库 2023年6月16日
    097
  • mysql绿色版在windows系统中的启动

    Original: https://www.cnblogs.com/java265/p/15597871.htmlAuthor: java265Title: mysql绿色版在wi…

    数据库 2023年5月24日
    090
  • Hosts映射

    Hosts映射 思考:如何通过主机名能够找到(ping)某个linux系统? 前言 Hosts:是一个文本文件,用来记录IP和Hostname的映射关系 DNS:是互联网上作为域名…

    数据库 2023年6月11日
    098
  • Oracle扩展表空间

    Oracle扩展表空间 前言: Oracle表空间扩展最大为32G,目前我还未找到可以打破限制的办法。 一、查看表空间信息和使用情况 查看表空间的名字及文件所在位置 — &amp…

    数据库 2023年6月16日
    0108
  • Dubbo源码(三)-服务导出(生产者)

    前言 本文基于Dubbo2.6.x版本,中文注释版源码已上传github:xiaoguyu/dubbo 在了解了Dubbo SPI后,我们来了解下Dubbo服务导出的过程。 Dub…

    数据库 2023年6月11日
    090
  • mysql开启二进制日志

    打开xhell进入系统 进入mysql配置文件目录 执行 cd /etc/mysql 首先找到my.cnf这个配置文件,然后使用vim进入文件编辑 放开我标记的地方。 注意我标记的…

    数据库 2023年6月6日
    0122
  • Java压缩图片

    压缩图片 一、压缩原理 一张原始图像(1920×1080),如果每个像素32bit表示(RGBA),那么,图像需要的内存大小1920x1080x4 = 8294400 B…

    数据库 2023年6月6日
    091
  • 时序数据库InfluxDB的基本语法

    一 了解InfluxDB的必要性 Time series data is a series of data points each associated with a specif…

    数据库 2023年6月16日
    097
  • vue部署在nginx后刷新404,nginx.conf一行代码解决掉

    直接 vim conf/nginx.conf文件 server {listen 8081;server_name localhost; charset koi8-r; access…

    数据库 2023年6月14日
    0104
  • jdbc-使用工具类

    package com.cqust; import com.cqust.utils.JDBCUtil; import java.sql.Connection;import java…

    数据库 2023年6月11日
    069
  • springboot~关于打包时记录当前git信息

    Maven打包发布版本可能会遇到自己的提交不起作用的情况,排查比较困难,可能需要拉下服务器上包,反编译查看是否包含自己的提交记录。如果使用的是GIT作为SCM,可以使用 git-c…

    数据库 2023年6月6日
    091
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球