zoukankan      html  css  js  c++  java
  • SpringBoot整合MyBatis文件版

    1.pom配置

    <dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.4</version>
    </dependency>

    2.创建实体类

    package com.example.demo.entity;

    public class User {
      private Integer id;
      private String name;
      private String email;

      public Integer getId() {
        return id;
      }

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

      public String getName() {
        return name;
      }

      public void setName(String name) {
        this.name = name;
      }

      public String getEmail() {
        return email;
      }

      public void setEmail(String email) {
        this.email = email;
      }
    }

    3.mapper

    package com.example.demo.mapper;

    import com.example.demo.entity.Admin;
    import org.apache.ibatis.annotations.Options;
    import org.springframework.stereotype.Repository;

    import java.util.List;

    @Repository
    //@Mapper或者@MapperScan
    public interface AdminMapper {

      public List<Admin> getAdminList();

      public Admin getAdminById(Integer id);

      public int insertAdmin(Admin admin);

      public int updateAdmin(Admin admin);

      public Boolean deleteAdmin(Integer id);
    }

    4.MyBatis全局配置文件

    mybatis全局配置文件 放在resource.mybatis,根据需要进行修改

    具体配置查看https://mybatis.org/mybatis-3/zh/configuration.html#settings

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
    <settings>
         <!-- 开启驼峰命名自动映射 -->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
         <!-- 允许 JDBC 支持自动生成主键 -->
    <setting name="useGeneratedKeys" value="true"/>
         <!-- MyBatis会返回一个空实例 -->
    <setting name="returnInstanceForEmptyRow" value="true"/>
    </settings>
    </configuration>

    5.SQL映射文件

    <!-- SQL映射文件 放在resource.mybatis.mapper -->
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
      PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
      "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="com.example.demo.mapper.AdminMapper">
      <!-- id对应mapper中的方法名 resultType只有在有返回值的时候才写,路径是实体类路径 -->
      <select id="getAdminList" resultType="com.example.demo.entity.Admin">
        select * from admin
      </select>

      <select id="getAdminById" resultType="com.example.demo.entity.Admin">
        select * from admin where id = #{id}
      </select>

      <insert id="insertAdmin">
        insert into admin(name,password) values (#{name},#{password})
      </insert>

      <update id="updateAdmin">
        update admin set name = #{name},password = #{password} where id = #{id}
      </update>

      <delete id="deleteAdmin">
        delete from admin where id = #{id}
      </delete>
    </mapper>

    6.application.yml指定路径

    mybatis:
      #指定mybatis全局配置文件路径
      config-location: classpath:mybatis/mybatis-config.xml
      #指定SQL映射文件路径
      mapper-locations: classpath:mybatis/mapper/*.xml

    7.测试

    package com.example.demo.controller;

    import com.example.demo.entity.Admin;
    import com.example.demo.mapper.AdminMapper;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.PathVariable;
    import org.springframework.web.bind.annotation.RestController;

    import java.util.List;

    @RestController
    public class AdminController {
      @Autowired
      AdminMapper adminMapper;

      @GetMapping("/admin")
      public List<Admin> getAdminList(){
        return adminMapper.getAdminList();
      }

      @GetMapping("/admin/{id}")
      public Admin getAdminById(@PathVariable("id") Integer id){
        return adminMapper.getAdminById(id);
      }

      @GetMapping("/insert")
      public Admin insertAdmin(Admin admin){
        adminMapper.insertAdmin(admin);
        return admin;
      }

      @GetMapping("/edit")
      public Admin updateAdmin(Admin admin){
        adminMapper.updateAdmin(admin);
        return admin;
      }

      @GetMapping("/delete/{id}")
      public Boolean deleteAdmin(@PathVariable("id") Integer id){
        try {
          adminMapper.deleteAdmin(id);
        }catch (Exception e){
          e.printStackTrace();
          return false;
        }
        return true;
      }
    }

  • 相关阅读:
    线程状态
    JVM的运行
    HBase与Protobuf
    HBase Java API
    HBase全分布式部署
    HBase 伪分布式搭建
    HBase架构
    mysql存储引擎中InnoDB与Myisam的区别及应用场景
    mysql5.6 主从配置
    Mongodb3.4安装
  • 原文地址:https://www.cnblogs.com/ljkltt/p/14225232.html
Copyright © 2011-2022 走看看