SpringBoot + Mybatis增删改查实战记录

简介

SpringBoot和Mybatis是啥请自行百度,作者这里也是花了几天时间入门了这个框架用来完成任务,并且也算符合要求的完成了任务,期间也各种百度但是没找到自己想要的那种简单易懂的教程,所以踩了很多坑,写这个博客的目的就是为了让大家少踩一点坑,开始。

创建一个SpringBoot项目https://start.spring.io/

点开这个网站,创建一个Springboot项目,如下图,这里用的是2.1.5,学技术嘛,就是要学新的。

选择依赖,点击左下角的Dependencies

  1. Web 我们这次开发的是web应用所以选择web
  2. Thymeleaf 一款模板引擎,能够比较方便的展现后台传来的数据
  3. MySQL 我们这次使用Mysql数据库
  4. JDBC Java 数据库连接 Java Database Connectivity,简称JDBC
  5. MyBatis 请看第一段

最后点击左下角的Generate Project,将会开始下载一个以你项目名称开头的zip文件,下载完成后解压到你的工作目录。

打开这个项目

这里使用的是IDEA,别的啥也行比如eclipse,这里只讲解IDEA的操作,安装破解IDEA百度一大堆,安装好之后打开IDEA(发现IDEA有个问题,有的时候自动import包好用,有的时候不好用,坑!),然后选择左上角的File->Open,找到你刚刚解压的项目文件里的pom.xml点击ok如下图

目录结构

增加修改目录结构为下图

开始编写

这里我们就编写一个人员信息的增删改查

配置数据库数据库创建

打开mysql数据库创建一个叫test的数据库之后创建person表,这里使用的是Navicat百度有破解版,会命令用命令行也行,如下图,记得设置主键自增,然后随便加几个数据以便之后查询。

application.yml

路径:/resources/application.yml

server:
 port: 8080

spring:
 datasource:
 name:
 url: jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=UTC
 username: root
 password: root

mybatis:
 mapper-locations: classpath:mapper/*.xml

Person类

路径/model/Person.java

package com.ljsh.test.model;

public class Person {
 /*
 {id} 自增主键
 {name} 人员姓名
 {mobile} 人员电话
  */
 private int id;
 private String name;
 private String mobile;

 // 右键 Generate -> Setter and Getter -> Shift全选 -> ok 生成如下代码

 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 getMobile() {
  return mobile;
 }

 public void setMobile(String mobile) {
  this.mobile = mobile;
 }

 // 右键 Generate -> toString() -> 全选 -> ok 生成如下代码

 @Override
 public String toString() {
  return "Person{" +
    "id=" + id +
    ", name='" + name + '\'' +
    ", mobile='" + mobile + '\'' +
    '}';
 }
}

PersonDao

路径:/dao/PersonDao.java

package com.ljsh.test.dao;

import com.ljsh.test.model.Person;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;

@Mapper
public interface PersonDao {
  /*
  查所有
  return List<Person>
   */
  List<Person> getAll();

  /*
  根据ID查询
  {id} 要查询人员的 id
   */
  Person getPersonByID(int id);

  /*
  删除
  {id} 要删除人员的 id
   */
  void delete(int id);

  /*
  更新
  {p} 要更新的Person实例
   */
  void update(Person p);

  /*
  增加
  {p} 要新增的Person实例
   */
  void newp(Person p);
}

PersonDao.xml

路径:/mapper/PersonDao.xml

<?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" >
<!-- 这里填写对应的Dao文件所在的路径 -->
<mapper namespace="com.ljsh.test.dao.PersonDao"  >
  <!-- 填写数据库里实例Person对应的表的表名 -->
  <!-- 这里是作为一个变量使用 -->
  <sql id="table">person</sql>

  <!-- id属性填写Dao文件里的函数名称 xxType是参数或是结果的类型根据情况填写 -->
  <!-- 查询所有  -->
  <select id="getAll" resultType="com.ljsh.test.model.Person">
    SELECT
    *
    FROM
    <include refid="table" />
  </select>

  <!-- 根据id查询 -->
  <select id="getPersonById" resultType="com.ljsh.test.model.Person">
    SELECT
    *
    FROM
    <include refid="table"/>
    WHERE
    id = #{id}
  </select>

  <!-- 增 -->
  <insert id="newp" parameterType="com.ljsh.test.model.Person">
    INSERT INTO
    <include refid="table"/>
    (name,phone)
    VALUES
    (#{name},#{phone})
  </insert>

  <!-- 改 -->
  <update id="update" parameterType="com.ljsh.test.model.Person">
    UPDATE
    <include refid="table"/>
    SET
    <!--<if test="name != null">name = #{name}</if>-->
    name = #{name},phone = #{phone},status = #{status}
    WHERE
    id = #{id}
  </update>

  <!-- 删 -->
  <delete id="delete" parameterType="com.ljsh.test.model.Person">
    DELETE FROM
    <include refid="table"/>
    WHERE
    id = #{id}
  </delete>
</mapper>

PersonService

路径:/service/PersonService.java

package com.ljsh.test.service;
import com.ljsh.test.dao.PersonDao;
import com.ljsh.test.model.Person;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

@Service
public class PersonService {
  @Autowired
  PersonDao personDao;

  /*
    Service层介于controller和dao之间作为服务层进行一些逻辑处理,
    这里逻辑太简单所以知识单纯调用dao所以不做注释
   */
  public List<Person> getAll(){
    return personDao.getAll();
  }

  public Person getPersonByID(int id){
    return personDao.getPersonByID(id);
  }

  public void delete(int id){
    personDao.delete(id);
  }

  public void update(Person p){
    personDao.update(p);
  }

  public void newp(Person p){
    personDao.newp(p);
  }
}

PersonController

路径:/controller/PersonController.java

package com.ljsh.test.controller;

import com.ljsh.test.model.Person;
import com.ljsh.test.service.PersonService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import java.util.List;

@Controller
public class PersonController {

  @Autowired
  PersonService personService;

  // 设置访问路由值为路径
  @RequestMapping("/")
  public ModelAndView index(){
    // 顾名思义 实体和数据 同时返回页面模板和数据
    ModelAndView mav = new ModelAndView("index");
    List<Person> list = personService.getAll();
    mav.addObject("list",list);
    return mav;
  }
}

前端页面

路径:/templates/index.html

<!DOCTYPE html>
<html lang="en">
<!-- -->
<!-- 使用thymeleaf需引入 -->
<html xmlns:th="http://www.thymeleaf.org">
<head>
</head>
<body>
<div id="tableP">
    <table>
      <caption>人员信息</caption>
      <tr>
        <th>Name</th>
        <th>Phone</th>
      </tr>
      <!-- 通过th命令使用一些操作 -->
      <!-- 通过${} 使用变量 -->
      <tr th:each="item: ${list}">
        <td th:text="${{item.name}}">还没有任何人员信息哦</td>
        <td th:text="${{item.mobile}}">你是不是想独吞奖品</td>
      </tr>
    </table>
  </div>
</div>
</body>
</html>

右上角运行

要是没有这个可以右侧选择TestApplication右键Run,结果图如下

未完待续

熄灯睡觉了,写的有点慢,删改查还没来及写,如果需求留言,我会继续更新。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。

(0)

相关推荐

  • springboot与mybatis整合实例详解(完美融合)

    简介 从 Spring Boot 项目名称中的 Boot 可以看出来,Spring Boot 的作用在于创建和启动新的基于 Spring 框架的项目.它的目的是帮助开发人员很容易的创建出独立运行和产品级别的基于 Spring 框架的应用.Spring Boot 会选择最适合的 Spring 子项目和第三方开源库进行整合.大部分 Spring Boot 应用只需要非常少的配置就可以快速运行起来. Spring Boot 包含的特性如下: 创建可以独立运行的 Spring 应用. 直接嵌入 Tomc

  • Spring boot + mybatis + Vue.js + ElementUI 实现数据的增删改查实例代码(一)

    环境搭建 spring boot的简介 以往我们开发时用到spring总是避免不了繁琐的配置,例如我们要配置一个数据库连接,可能需要以下几步: 1.编写jdbc.properties配置文件: 2.创建spring的配置文件,加入spring配置文件前缀.配置数据库连接信息以及sqlsessionFactory等等: 3.还要在web.xml文件中加入spring的监听. springboot的出现大大简化了项目的搭建过程(spring配置以及maven配置),让我们专注于应用功能的开发,而不是

  • Spring Boot 与 mybatis配置方法

    1.首先,spring boot 配置mybatis需要的全部依赖如下: <!-- Spring Boot 启动父依赖 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.1.RELEASE</version> </

  • SpringBoot整合MyBatis逆向工程及 MyBatis通用Mapper实例详解

    一.添加所需依赖,当前完整的pom文件如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd&q

  • Spring Boot 集成Mybatis实现主从(多数据源)分离方案示例

    本文将介绍使用Spring Boot集成Mybatis并实现主从库分离的实现(同样适用于多数据源).延续之前的Spring Boot 集成MyBatis.项目还将集成分页插件PageHelper.通用Mapper以及Druid. 新建一个Maven项目,最终项目结构如下: 多数据源注入到sqlSessionFactory POM增加如下依赖: <!--JSON--> <dependency> <groupId>com.fasterxml.jackson.core<

  • SpringBoot Mybatis Plus公共字段自动填充功能

    一.应用场景 平时在建对象表的时候都会有最后修改时间,最后修改人这两个字段,对于这些大部分表都有的字段,每次在新增和修改的时候都要考虑到这几个字段有没有传进去,很麻烦.mybatisPlus有一个很好的解决方案.也就是公共字段自动填充的功能.一般满足下面条件的字段就可以使用此功能: 这个字段是大部分表都会有的. 这个字段的值是固定的,或则字段值是可以在后台动态获取的. 常用的就是last_update_time,last_update_name这两个字段. 二.配置MybatisPlus 导包:

  • Spring boot + mybatis + Vue.js + ElementUI 实现数据的增删改查实例代码(二)

    在上篇文章给大家介绍了Spring boot + mybatis + Vue.js + ElementUI 实现数据的增删改查实例代码(一),接下来我们添加分页相关的依赖,时间紧张,直接上代码了,贴上我的pom文件 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=

  • Spring Boot MyBatis 连接数据库配置示例

    最近比较忙,没来得及抽时间把MyBatis的集成发出来,其实mybatis官网在2015年11月底就已经发布了对SpringBoot集成的Release版本,示例代码:spring-boot_jb51.rar 前面对JPA和JDBC连接数据库做了说明,本文也是参考官方的代码做个总结. 先说个题外话,SpringBoot默认使用 org.apache.tomcat.jdbc.pool.DataSource 现在有个叫 HikariCP 的JDBC连接池组件,据说其性能比常用的 c3p0.tomca

  • springboot+springmvc+mybatis项目整合

    介绍: 上篇给大家介绍了ssm多模块项目的搭建,在搭建过程中spring整合springmvc和mybatis时会有很多的东西需要我们进行配置,这样不仅浪费了时间,也比较容易出错,由于这样问题的产生,Pivotal团队提供了一款全新的框架,该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者. 特点: 1. 创建独立的Spring应用

  • 详解spring boot mybatis全注解化

    本文重点给大家介绍spring boot mybatis 注解化的实例代码,具体内容大家参考下本文: pom.xml <!-- 引入mybatis --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.0</version

随机推荐