You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

README.md 3.9 kB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. # spring-boot-demo-jpa
  2. 依赖 [spring-boot-demo-parent](../spring-boot-demo-parent)、`spring-boot-starter-data-jpa`、`druid-spring-boot-starter`
  3. ### pom.xml
  4. ```xml
  5. <?xml version="1.0" encoding="UTF-8"?>
  6. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  7. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  8. <modelVersion>4.0.0</modelVersion>
  9. <artifactId>spring-boot-demo-orm-jpa</artifactId>
  10. <version>0.0.1-SNAPSHOT</version>
  11. <packaging>jar</packaging>
  12. <name>spring-boot-demo-orm-jpa</name>
  13. <description>Demo project for Spring Boot</description>
  14. <parent>
  15. <groupId>com.xkcoding</groupId>
  16. <artifactId>spring-boot-demo-parent</artifactId>
  17. <version>0.0.1-SNAPSHOT</version>
  18. <relativePath>../spring-boot-demo-parent</relativePath>
  19. </parent>
  20. <properties>
  21. <druid.starter.version>1.1.5</druid.starter.version>
  22. </properties>
  23. <dependencies>
  24. <dependency>
  25. <groupId>org.springframework.boot</groupId>
  26. <artifactId>spring-boot-starter-data-jpa</artifactId>
  27. </dependency>
  28. <dependency>
  29. <groupId>com.alibaba</groupId>
  30. <artifactId>druid-spring-boot-starter</artifactId>
  31. <version>${druid.starter.version}</version>
  32. </dependency>
  33. </dependencies>
  34. <build>
  35. <finalName>spring-boot-demo-orm-jpa</finalName>
  36. </build>
  37. </project>
  38. ```
  39. ### application.yml
  40. ```yaml
  41. server:
  42. port: 8080
  43. context-path: /demo
  44. spring:
  45. datasource:
  46. continue-on-error: true
  47. druid:
  48. url: jdbc:mysql://localhost:3306/spring-boot-demo?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false
  49. username: root
  50. password: root
  51. driver-class-name: com.mysql.jdbc.Driver
  52. # 连接池配置
  53. # 初始化大小,最小,最大
  54. initialSize: 5
  55. minIdle: 5
  56. maxActive: 20
  57. # 配置获取连接等待超时的时间
  58. maxWait: 60000
  59. # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
  60. timeBetweenEvictionRunsMillis: 60000
  61. # 配置一个连接在池中最小生存的时间,单位是毫秒
  62. minEvictableIdleTimeMillis: 300000
  63. validationQuery: SELECT 1 FROM DUAL
  64. testWhileIdle: true
  65. testOnBorrow: false
  66. testOnReturn: false
  67. # 打开PSCache,并且指定每个连接上PSCache的大小
  68. poolPreparedStatements: true
  69. maxPoolPreparedStatementPerConnectionSize: 20
  70. # 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
  71. filters: stat,wall,log4j
  72. # 监控配置
  73. web-stat-filter:
  74. enabled: true
  75. url-pattern: /*
  76. exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"
  77. stat-view-servlet:
  78. enabled: true
  79. url-pattern: /sys/druid/*
  80. reset-enable: fasle
  81. login-username: xkcoding
  82. login-password: 123456
  83. filter:
  84. stat:
  85. log-slow-sql: true
  86. slow-sql-millis: 5000
  87. merge-sql: true
  88. jpa:
  89. hibernate:
  90. ddl-auto: create-drop
  91. show-sql: true
  92. ```
  93. ### JpaUser.java
  94. ```java
  95. @Entity
  96. @Data
  97. @DynamicUpdate
  98. public class JpaUser {
  99. @Id
  100. @GeneratedValue(strategy = GenerationType.IDENTITY)
  101. private Long id;
  102. @Column(name = "name")
  103. private String name;
  104. @Column(name = "create_time")
  105. private Date createTime;
  106. }
  107. ```
  108. ### JpaUserRepository.java
  109. ```java
  110. public interface JpaUserRepository extends JpaRepository<JpaUser, Long> {
  111. /**
  112. * 自定义一个查询,HQL,根据姓名查询
  113. *
  114. * @param name 名称
  115. * @return JpaUser
  116. */
  117. @Query("from JpaUser u where u.name like :name")
  118. JpaUser findJpaUser(@Param("name") String name);
  119. JpaUser findJpaUserByName(String name);
  120. List<JpaUser> findJpaUsersByIdIn(List<Long> ids);
  121. }
  122. ```
  123. ### 其余代码
  124. 详情请参见本demo。

一个用来深度学习并实战 spring boot 的项目,目前总共包含 66 个集成demo,已经完成 55 个。

Contributors (1)