В этой статье я покажу вам, как подключить базу данных 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; @Entity public 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; @Repository public 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=update spring.datasource.url=jdbc:mysql: //localhost:3306/mysqltutorial?useSSL=false spring.datasource.username=root spring.datasource.password= spring.datasource.driver- class -name=com.mysql.jdbc.Driver spring.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 ;39m Our 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.0 Here is a system: 2 | RHEL 7 | 2017 - 07 - 21 00 : 00 : 00.0 Here 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, являются их собственными. |