大家好,又见面了,我是你们的朋友全栈君。
使用SpringBoot连接MySQL数据库,快速上手@TOC
0 环境配置
- IDE Ultimate最新版
- Maven 3.6.0
- Java JDK 8( 也即1.8)
- MySQL server version :8.0.15
学习Springboot包括学习springboot连接数据库,下面将简单介绍如何利用springboot简单建立与MySQL数据的连接并且从中读取数据。
1 建立MySQL数据库
这里使用了Navicat for MySQL来建立数据库,方便快捷。 如下图,在localhost用户里面创建了test数据库,数据库里包含一个user表单,用来记录user信息,有id,email,name,共两条数据信息。
2 使用Spring Initializer快速搭建springboot项目
如下图,点击Spring Initializer选好SDK,这里选择java JDK8,即JDK1.8,其他保持默认设置,点击next。
接下来设置好group 和artifact,version,三个属性可以唯一确定在maven依赖仓库的项目依赖。JDK跟之前选择保持一致。点击next。
接下来选择实现预期功能所需要的依赖,这里选择了web中的web(方便后面观察是否读取到数据库数据),SQL中的MySQL和JDBC。依赖后面也可以手动添加。点击next。
3 配置pom.xml文件
选好project name 和project location(一般不用改)就行,点击Finish。 项目创建好后的目录结构如下:
打开pom.xml可以看到所需的三个依赖已经自动创建好了,如果没有,可以手动添加上去:
pom.xml
代码语言:javascript复制<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>cn.mark</groupId>
<artifactId>demo-mysql</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo-mysql</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
4 配置application.yml文件
接下来删除application.properties在相同目录下新建application.yml文件,在srcmainjresource目录,配置连接数据库相关信息。数据库test建于root用户下,密码 123456,其中url中的3306为mysql server 的端口。
application.yml
代码语言:javascript复制spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/test
username: root
password: 123456
5 编写HelloController.java文件
在cn.mark.demomysql package下新建web package,web里面新建HelloController.java文件如图:
建立HelloController的目的是为了检测springboot后台是否能成功被访问。 HelloController.java
代码语言:javascript复制package cn.mark.demomysql.web;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
@RequestMapping(value="/hello",method = RequestMethod.GET)
@ResponseBody
public String sayHello(){
return "Hello, World!";
}
}
然后点击idea左下角,选择maven,最后在lifecycle里双击install,运行成功后再点击右上角的绿三角,运行成功后,再浏览器输入http://127.0.0.0:8080/hello,若有Hello, World!字样,则说明后台能被访问。
maven—-install
run DemoMysqlApplication 绿色小三角
访问成功!
6 编写UserController.java文件
UserController.java
代码语言:javascript复制package cn.mark.demomysql.web;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.List;
import java.util.Map;
@Controller
public class UserController {
@Autowired
private JdbcTemplate jdbcTemplate;
@RequestMapping(value = "/getUsers",method = RequestMethod.GET)
@ResponseBody
/*
* List 里的对象是Map对象,而Map对象是
* 由一个String类型的键和Object类型的值组成
* */
public List<Map<String,Object>> getUsers(){
String sql="select * from user";//SQL查询语句
List<Map<String,Object>> list=jdbcTemplate.queryForList(sql);
return list;
}
}
再次点击install然后点击绿色小三角,若成功运行,在浏览器中输入 http://127.0.0.1:8080/getUsers http://localhost:8080/getUsers 即可看到数据表中两条用户信息:
参考文章:
- https://blog.csdn.net/qq_33129625/article/details/79299535
- https://www.bysocket.com/archives/2119
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/152845.html原文链接:https://javaforall.cn