实现效果:用Mybatis连接MySQL数据库,使用SpringBoot框架,搭建起MVC结构项目,在前端展示数据。
过程及问题:
创建maven项目
idea版本:2018.3.4,jdk版本:1.8
生成maven项目,过程可能卡在Generating project in Batch mode
原因是下载一个文件,等待
若时间过长可考虑网上教程,提前下好文件,修改配置读取本地
idea右下角提示 maven project need to be imported
选择了 Enable Auto-Import
以后更改pom文件后就会自动下载依赖包了
Maven项目创建成功
更换maven源,提升下载速度
参考 https://blog.youkuaiyun.com/yuanxiang01/article/details/80795360
出现提示This file is indented with tabs instead of 4 spaces
this file is indented with 2 spaces instead of 4 spaces
格式问题,选择4 spaces
配置SpringBoot
将Java文件夹设置为sources root
test文件夹设置为 test sources root
创建并设置resources文件夹为resources root
springboot 官方搭建文档 https://spring.io/guides/gs/rest-service/
pom文件增加两个依赖
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.2</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
自动拉取所需包
编写APP,测试SpringBoot是否配置成功
声明@EnableAutoConfiguration
自动载入应用程序所需的所有Bean
@EnableAutoConfiguration
@RestController
public class App {
@RequestMapping("/")
public String home(){
return "Hello World";
}
public static void main( String[] args ) {
System.out.println( "Hello World!" );
SpringApplication.run(App.class,args);
}
}
启动,项目可顺利运行
在web端可访问
resources目录下创建applications.properties文件配置文件
可以改变springboot配置
配置Mybatis,连接数据库
<dependencies>
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version></version>
</dependency>
</dependencies>
增加mybatis插件配置
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.5</version>
<dependencies>
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.30</version>
</dependency>
</dependencies>
<executions>
<execution>
<id>mybatis generator</id>
<phase>package</phase>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
<configuration>
<!--允许移动生成的文件-->
<verbose>true</verbose>
<!--允许自动覆盖的文件-->
<overwrite>true</overwrite>
<configurationFile>
src/main/resources/mybatis-generator.xml
</configurationFile>
</configuration>
</plugin>
报错:dependency org.mybatis.generator:mybatis-generator-core:1.3.5 not found
mybatis generator包无法自动加载
去掉
57行/133行
去掉后开始加载包,加载完成后再将标签补上
编写mybatis-generator.xml文件
内容框架可复制后修改:
http://mybatis.org/generator/configreference/xmlconfig.html
https://blog.youkuaiyun.com/qq_42254198/article/details/88984250
问题:文件中javaModelGenerator 等标签的targetProject总是标红,尝试各种格式,改斜杠
,改相对路径绝对路径都不可以。
尝试直接启动mybatis generator提示报错,查找原因未果
在启动idea时经常报一个 Mybatis Plugin An error occurred, code ‘25’.
怀疑是plugin插件出了问题,查资料说mybatis plugin是付费的,怀疑过期,于是下载了Free Mybatis Plugin,但在重启时仍报错。
最后在插件中只勾选启用Free Mybatis Plugin,不勾选Mybatis Plugin,再次重启,mybatis plugin插件错误提示消失,路径不报错不标红。故综上考虑的结果是Mybatis Plugin插件出现错误,非配置问题。
执行 mybatis geneator
报错:version can neither be null, empty nor blank java.lang.IllegalArgumentException: version can neither be null, empty nor blank
提示没有版本号,在pom文件中,mysql-connector-java版本号写了,是5.1.6,但是报错,修改为5.1.30,仍然报错
dependency和 plugin 中有两次引用,两次的版本号都要有且一致
两个地方都加上后不报版本错误
报错:Failed to execute goal org.mybatis.generator:mybatis-generator-maven-plugin:1.3.5:generate (default-cli) on project dataproject: Access denied for user 'root'@'localhost'
刷新了一下maven依赖,仔细查看报错,提示拒绝了用户root的访问,猜测是MySQL数据库密码错误,修改用户名密码,连接成功
mybatis-generator.xml添加,简化查询
enableCountByExample="false"
enableUpdateByExample="false" enableDeleteByExample="false"
enableSelectByExample="false" selectByExampleQueryId="false"
配置 application.properties 添加
spring.datasource.name=dataproject
spring.datasource.url=dbc:mysql://127.0.0.1:3306/dataproject
spring.datasource.username=root
spring.datasource.password=root
#使用druid数据源
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
修改APP类 APP.java,做测试,读取数据库信息并显示
@SpringBootApplication(scanBasePackages = {"com.dataproject"})
@RestController
@MapperScan("com.dataproject.dao")
public class App {
@Autowired
private UserDOMapper userDOMapper;
@RequestMapping("/")
public String home(){
UserDO userDO = userDOMapper.selectByPrimaryKey(1);
if(userDO == null){
return "不存在";
}else{
return userDO.getName();
}
}
public static void main( String[] args ) {
System.out.println( "Hello World!" );
SpringApplication.run(App.class,args);
}
}
插入数据后
创建SpringMVC格式
创建controller层,service层,VO层
快捷键
Alt + Insert 快速生成getset函数
Ctrl+Shift+t 快速跳转文件、类等
MVC结构数据(从下至上)
- 通过Mybatis实现与数据库表内数据结构的映射,至dataobject层,对应的类名在mybatis-generator.xml文件中声明
- dao层声明了对表内数据的处理函数接口,eg: selectByPrimerkey,函数的实现在mapping下的xml文件内,与数据库的交互逻辑在xml内实现
- service层对表内的数据进行提取、实例化。Impl声明获取表内数据的函数接口,并实例化,函数返回的数据写入Model类中。
- controller层调用service层返回给前端。VO为想传输到前端的数据,即把service中的Model->VO,VO->前端
未使用VO
使用VO
MVC结构
MVC是一种软件设计模式,Model-View-Controller,
模型层,封装了数据和方法;
视图层,接受输入,传递给控制层;展示数据;
控制层,接受视图层的请求,分析并选择对应的模型
便于更新维护,分工,提高代码可重用性