В этой статье я покажу вам, как подключить базу данных MySQL к вашему приложению Spring Boot.
Инструменты, используемые в этой статье, включают в себя:
- Spring Boot 1.5.6 Release
- MySQL 5.7.X
- специалист
- Java 8
- Spring Data JPA
1 — Структура проекта
Структура проекта — типичная структура Maven.
2 — Зависимости проекта
Обратите внимание, что родитель должен быть объявлен. Если вы используете Spring Tool Suite, вы можете нажать новый «Spring Starter Project», и он заполнит его для вас.
pom.xml
|
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
<?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" <modelVersion>4.0.0</modelVersion> <groupId>com.michaelcgood</groupId> <artifactId>mysql-jdbc</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>mysql-jdbc-driver</name> <description>mysql jdbc driver example</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.6.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <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> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build></project> |
3 — Модель
Для этого примера приложения наше приложение будет «отслеживать» последний аудит безопасности систем в сети. Поскольку это примерное приложение должно быть простым, для модели будут минимальные поля.
Обратите внимание, что в библиотеке Java есть встроенный класс System. По этой причине я бы не использовал System.java в качестве имени класса для реального приложения.
System.java
|
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
package com.michaelcgood.model;import java.util.Date;import javax.persistence.Column;import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.GenerationType;import javax.persistence.Id;@Entitypublic class System { private String name; private Date lastaudit; public Date getLastaudit() { return lastaudit; } public void setLastaudit(Date lastaudit) { this.lastaudit = lastaudit; } @Id @GeneratedValue(strategy = GenerationType.AUTO) @Column(name="id") private long id; public long getId() { return id; } public void setId(long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String toString(){ return id+" | " + name+ " | "+ lastaudit; } } |
4 — Репозиторий
Это простой CrudRepository, представляющий собой интерфейс, который позволяет нам выполнять операции CRUD (создание, чтение, обновление, удаление).
SystemRepository.java
|
01
02
03
04
05
06
07
08
09
10
11
|
package com.michaelcgood.dao;import org.springframework.data.repository.CrudRepository;import org.springframework.stereotype.Repository;import com.michaelcgood.model.System;@Repositorypublic interface SystemRepository extends CrudRepository<System,Long> { } |
5 — Инициализация базы данных
Spring Boot включает инициализатор dataSource по умолчанию и загружает сценарии SQL (schema.sql и data.sql) из корня пути к классам.
5,1
Здесь мы создаем файл SQL, который наше приложение будет использовать для схемы таблиц.
schema.sql
|
1
2
3
4
5
6
|
DROP TABLE IF EXISTS system;CREATE TABLE system ( id INT NOT NULL AUTO_INCREMENT, name VARCHAR(100) NOT NULL, lastaudit DATE NOT NULL, PRIMARY KEY (id)); |
5,2
Мы вставляем примеры значений в нашу базу данных.
data.sql
|
1
2
3
|
INSERT INTO system(name,lastaudit)VALUES('Windows Server 2012 R2 ','2017-08-11');INSERT INTO system(name,lastaudit)VALUES('RHEL 7','2017-07-21');INSERT INTO system(name,lastaudit)VALUES('Solaris 11','2017-08-13'); |
5,3
Этот XML-файл используется для настройки нашего ведения журнала.
logback.xml
|
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
<?xml version="1.0" encoding="UTF-8"?><configuration> <statusListener class="ch.qos.logback.core.status.NopStatusListener" /> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <layout class="ch.qos.logback.classic.PatternLayout"> <Pattern> %d{yyyy-MM-dd HH:mm:ss} %-5level %logger{36} - %msg%n </Pattern> </layout> </appender> <logger name="org.springframework.jdbc" level="error" additivity="false"> <appender-ref ref="STDOUT"/> </logger> <logger name="com.michaelcgood" level="error" additivity="false"> <appender-ref ref="STDOUT"/> </logger> <root level="error"> <appender-ref ref="STDOUT"/> </root></configuration> |
6 — Конфигурация
Мы настраиваем наш источник данных и настройки JPA.
application.properties
|
1
2
3
4
5
6
7
|
#==== connect to mysql ======#spring.jpa.hibernate.ddl-auto=updatespring.datasource.url=jdbc:mysql://localhost:3306/mysqltutorial?useSSL=falsespring.datasource.username=rootspring.datasource.password=spring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect |
7 — @SpringBootApplication
CommandLineRunner реализован для выполнения аргументов командной строки для этого примера.
|
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
package com.michaelcgood.app;import javax.sql.DataSource;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.CommandLineRunner;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.boot.autoconfigure.domain.EntityScan;import org.springframework.data.jpa.repository.config.EnableJpaRepositories;import com.michaelcgood.dao.SystemRepository;@SpringBootApplication@EnableJpaRepositories("com.michaelcgood.dao")@EntityScan("com.michaelcgood.model")public class MysqlJdbcDriverApplication implements CommandLineRunner { @Autowired DataSource dataSource; @Autowired SystemRepository systemRepository; public static void main(String[] args) { SpringApplication.run(MysqlJdbcDriverApplication.class, args); } @Override public void run(String... args) throws Exception { System.out.println("Our DataSource is = " + dataSource); Iterable<com.michaelcgood.model.System> systemlist = systemRepository.findAll(); for(com.michaelcgood.model.System systemmodel:systemlist){ System.out.println("Here is a system: " + systemmodel.toString()); } }} |
8 — Демо
|
01
02
03
04
05
06
07
08
09
10
11
12
|
. ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/[32m :: Spring Boot :: [39m [2m (v1.5.6.RELEASE)[0;39mOur DataSource is = org.apache.tomcat.jdbc.pool.DataSource@40f70521{ConnectionPool[defaultAutoCommit=null; defaultReadOnly=null; defaultTransactionIsolation=-1; defaultCatalog=null; driverClassName=com.mysql.jdbc.Driver; maxActive=100; maxIdle=100; minIdle=10; initialSize=10; maxWait=30000; testOnBorrow=true; testOnReturn=false; timeBetweenEvictionRunsMillis=5000; numTestsPerEvictionRun=0; minEvictableIdleTimeMillis=60000; testWhileIdle=false; testOnConnect=false; password=********; url=jdbc:mysql://localhost:3306/mysqltutorial?useSSL=false; username=root; validationQuery=SELECT 1; validationQueryTimeout=-1; validatorClassName=null; validationInterval=3000; accessToUnderlyingConnectionAllowed=true; removeAbandoned=false; removeAbandonedTimeout=60; logAbandoned=false; connectionProperties=null; initSQL=null; jdbcInterceptors=null; jmxEnabled=true; fairQueue=true; useEquals=true; abandonWhenPercentageFull=0; maxAge=0; useLock=false; dataSource=null; dataSourceJNDI=null; suspectTimeout=0; alternateUsernameAllowed=false; commitOnReturn=false; rollbackOnReturn=false; useDisposableConnectionFacade=true; logValidationErrors=false; propagateInterruptState=false; ignoreExceptionOnPreLoad=false; useStatementFacade=true; }Here is a system: 1 | Windows Server 2012 R2 | 2017-08-11 00:00:00.0Here is a system: 2 | RHEL 7 | 2017-07-21 00:00:00.0Here is a system: 3 | Solaris 11 | 2017-08-13 00:00:00.0 |
Полный код на Github
| Опубликовано на Java Code Geeks с разрешения Майкла Гуда, партнера нашей программы JCG . Смотреть оригинальную статью здесь: Использование драйвера JDBC MySQL с Spring Boot
Мнения, высказанные участниками Java Code Geeks, являются их собственными. |
