idea实现Springboot2.6.1版本+mybatis简单WEB项目

1.使用idea选择相应的模块进行项目初始化

设置jdk版本,包名,项目名

在这里插入图片描述

选择springboot版本以及项目所需的模块

在这里插入图片描述

点击完成,项目结构如下,红线项目可以删除

在这里插入图片描述

pom.xml文件如下

<?xml version="1.0" encoding="UTF-8"?>
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <!-- 继承Spring Boot的默认值,并声明一个“启动器”的依赖关系。-->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.6.1</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <!--项目基本信息,打包后的目录架构和版本号 :创建项目的时候自定义的-->
    <groupId>com.demo</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>

    <!--项目描述和项目名称:创建项目的时候自定义的-->
    <name>demo</name>
    <description>demo</description>

    <!--配置字符编码格式和Java jdk版本-->
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <!--为Web应用程序添加典型的依赖关系-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!--为Mybaits持久化操作添加依赖关系-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.0</version>
        </dependency>

        <!--Mysql驱动包-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

        <!--SpringBoot测试包-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <!--maven插件,运行打包成可执行的jar文件-->
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>



</project>

项目架构说明

1.初始化的项目中生成了一些无用的文件(.mvn、mvnw、mvnw.cmd)可以删除。
2.在main目录下的SpringbootApplication是项目的服务启动文件,后面我们的springboot项目启动可以 通过这个文件来完成,而不再是传统的把项目打war包,在部署到tomcat中,这个步骤,springboot已经我们完成了。
3.在resources目录下的static目录,用于存放静态资源(images,js,css…)这是springboot默认存放的目录,当然也可以通过核心配置文件,自己指定
4.在resources目录下的templates目录,用于存放模板文件,springboot会进行渲染,当然也可以存储html,jsp等文件。
test目录下的SpringbootApplicationTests是用于数据测试的。和传统的junit测试类似。
————————————————
版权声明:本文为CSDN博主「崔大洪-CDHong.it」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u010158540/article/details/79986760

2.使用MyBatis逆向工程生成需要的model,接口和xml映射文件

在pom.xml文件中的【plugins】下,添加mybatis逆向工程插件,用于逆向生成代码。

 <!-- mybatis-generator自动生成代码插件 -->
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.7</version>
                <configuration>
                    <verbose>true</verbose><!-- 打印创建info信息 -->
                    <overwrite>true</overwrite><!-- 重写生成的代码,除了mapper.xml文件是在最后追加sql语句 -->
                </configuration>
            </plugin>

添加完成后,在idea右侧maven插件中看到如图所示,即为配置成功

在这里插入图片描述

接下来使用navicat创建一张名为tbl_dept的表,如图

在这里插入图片描述

接下来在src/main/resources目录下创建一个mybatis逆向工程的核心配置文件(generatorConfig.xml),用于指定生成文件所在目录,以及要涉及的数据库表指定。内容如下: 注意文件的名称需要保持一致,这样maven插件才能找到

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>

    <!-- 指定数据连接驱动jar地址 -->
    <classPathEntry location="D:\\DevelopmentTool\\apache-maven-3.8.4\\localRepository\\mysql-connector-java-5.1.46.jar" />

    <!-- 一个数据库一个context -->
    <!-- targetRuntime之后加上simple可以生成简单版 -->
    <context id="infoGuardian" targetRuntime="MyBatis3">
        <!-- 生成的pojo,将implements Serializable -->
        <plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin>
        <!-- 注释 -->
        <commentGenerator >
            <property name="suppressAllComments" value="true"/><!-- 是否取消注释 -->
            <!--<property name="suppressDate" value="true" /> &lt;!&ndash; 是否生成注释代时间戳&ndash;&gt;-->
        </commentGenerator>

        <!-- jdbc连接 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql://localhost:3306/springboot"
                        userId="root"
                        password="****" />

        <!-- 类型转换 -->
        <javaTypeResolver>
            <!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) -->
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

        <!-- 生成实体类地址 -->
        <javaModelGenerator targetPackage="com.example.model"
                            targetProject="src/main/java" >
            <!-- 是否在当前路径下新加一层schema -->
            <property name="enableSubPackages" value="false"/>
            <!-- 是否针对string类型的字段在set的时候进行trim调用 -->
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>

        <!-- 生成mapxml文件 -->
        <sqlMapGenerator targetPackage="mybatis/mappers"
                         targetProject="src/main/resources" >
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>

        <!-- 生成mapxml对应client,也就是接口dao -->
        <javaClientGenerator targetPackage="com.example.mapper"  targetProject="src/main/java" type="XMLMAPPER" >
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>

        <!--数据库表-->
        <table tableName="tbl_dept" domainObjectName="Dept" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false">
            <!--开启驼峰命名方式-->
            <property name="useActualColumnNames" value="false" />
        </table>
    </context>
</generatorConfiguration>

接下来,在右侧-maven-插件,mybatis-generator里找到generate,点击生成逆向工程文件

在这里插入图片描述

可以看到构建成功,但是有一条警告,直接百度,修改如下。
在这里插入图片描述
问题解决详情

在这里插入图片描述

项目结构说明
1.自动生成了DeptMapper接口、Dept、DeptMapper.xml.
2.在DeptMapper.xml文件里是数据库操作具体语句。

3.配置SpringBoot核心配置文件完成数据源(datasource)和mybatis整合信息

在mybatis文件夹下添加mybatis-config.xml文件,主要用于后续mybatis和spring的信息分离,文件信息如下:

<?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" />
        <setting name="jdbcTypeForNull" value="NULL" />
    </settings>

</configuration>

在resources文件下的application.properties文件配置服务器信息,数据源以及mybatis

#服务配置
#Tomcat端口号,默认8080
server.port = 80
#dispatcherServlet的映射路径,默认是/,方便用restful 风格操作
spring.mvc.servlet.path = /

#数据源配置
spring.datasource.driver-class-name = com.mysql.cj.jdbc.Driver
spring.datasource.url = jdbc:mysql://localhost:3306/springboot
spring.datasource.username = root
spring.datasource.password = ***

#mybatis框架配置
#核心配置文件路径
mybatis.config-location = classpath:mybatis/mybatis-config.xml
#Mapper映射文件路径
mybatis.mapper-locations = classpath:mybatis/mappers/*Mapper.xml
#别名配置
mybatis.type-aliases-package = com.example.entity

配置完毕后找到启动文件,运行在这里插入图片描述

在这里插入图片描述

可以看到有警告,没扫描到Mapper,回到启动文件添加@MapperScan(“com.example.mapper”),即可
还可以直接将启动文件放到最外层,推荐最外层这种做法

将启动文件移出后运行,报警告

在这里插入图片描述

在这里只需要在相应的Mapper接口上添加一个@Mapper的注解即可,或则在启动文件上添加一个@MapperScan(“com.zt.mapper”)注解,指定Mapper的扫描地址也行,本次项目中使用@Mapper完成。

在这里插入图片描述

成功

4.整合Web模块,编写Controller控制器,Html视图完成测试

在example包下新增controller包,编写DeptController类

在这里插入图片描述

package com.example.controller;

import com.example.mapper.DeptMapper;
import com.example.model.Dept;
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.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * DescriptionTODO
 *
 * @Date 2021/12/21 18:14
 * Version 1.0
 **/
@RestController   //该注解是一个组合注解(@Controller+@ResponseBody)
@RequestMapping("/dept")
public class DeptController {
    /**
     * 注入deptMapper对象
     */
    @Autowired
    private DeptMapper deptMapper;

    /**
     * 该注解是一个简写注解 @RequestMapping(value = "/add",method = RequestMethod.GET)
     */
    @GetMapping("/add/{dname}")
    public String add(@PathVariable("dname") String dname){
        Dept dept = new Dept();
        dept.setDname(dname);
        dept.setLoc("测试");
        return deptMapper.insert(dept)>0?"添加成功!":"添加失败";
    }

    @GetMapping("/findById/{id}")
    public Dept findById(@PathVariable("id") Integer id){
        return  deptMapper.selectByPrimaryKey(id);
    }

}

重新启动文件,在浏览器输入localhost/dept/add/测试
在这里插入图片描述

添加成功,接着在调用查询方法输入地址:localhost/dept/findById/1,完成查询操作, 执行完毕后,在浏览器上可以看到如下信息:
在这里插入图片描述
完毕!

5.特别感谢

本文是对这篇18年文章的再更新,这个博主是当年实训的老师。
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/u010158540/article/details/79986760
————————————————
版权声明:本文为CSDN博主「崔大洪-CDHong.it」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u010158540/article/details/79986760

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值