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" /> <!– 是否生成注释代时间戳–>-->
</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