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 7.0 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. # spring-boot-demo-orm-mybatis
  2. 依赖 [spring-boot-demo-parent](../spring-boot-demo-parent)、`mybatis-spring-boot-starter`、`druid-spring-boot-starter`、`mapper-spring-boot-starter`(通用Mapper)、`pagehelper-spring-boot-starter`(分页插件PageHelper)
  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-mybatis</artifactId>
  10. <version>0.0.1-SNAPSHOT</version>
  11. <packaging>jar</packaging>
  12. <name>spring-boot-demo-orm-mybatis</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/pom.xml</relativePath>
  19. </parent>
  20. <properties>
  21. <mybatis.starter.version>1.3.1</mybatis.starter.version>
  22. <druid.starter.version>1.1.5</druid.starter.version>
  23. <mapper.version>1.1.1</mapper.version>
  24. <pagehelper.version>1.1.0</pagehelper.version>
  25. </properties>
  26. <dependencies>
  27. <!--mybatis-->
  28. <dependency>
  29. <groupId>org.mybatis.spring.boot</groupId>
  30. <artifactId>mybatis-spring-boot-starter</artifactId>
  31. <version>${mybatis.starter.version}</version>
  32. </dependency>
  33. <!--druid-->
  34. <dependency>
  35. <groupId>com.alibaba</groupId>
  36. <artifactId>druid-spring-boot-starter</artifactId>
  37. <version>${druid.starter.version}</version>
  38. </dependency>
  39. <!--通用 Mapper-->
  40. <dependency>
  41. <groupId>tk.mybatis</groupId>
  42. <artifactId>mapper-spring-boot-starter</artifactId>
  43. <version>${mapper.version}</version>
  44. </dependency>
  45. <!--PageHelper-->
  46. <dependency>
  47. <groupId>com.github.pagehelper</groupId>
  48. <artifactId>pagehelper-spring-boot-starter</artifactId>
  49. <version>${pagehelper.version}</version>
  50. </dependency>
  51. </dependencies>
  52. <build>
  53. <finalName>spring-boot-demo-orm-mybatis</finalName>
  54. </build>
  55. </project>
  56. ```
  57. ### application.yml
  58. ```yaml
  59. server:
  60. port: 8080
  61. context-path: /demo
  62. spring:
  63. # json 转化移除 null 字段
  64. # jackson:
  65. # default-property-inclusion: non_null
  66. datasource:
  67. # 启动时自动运行的 SQL 文件
  68. schema: classpath:init-sql/schema.sql
  69. continue-on-error: true
  70. druid:
  71. url: jdbc:mysql://localhost:3306/spring-boot-demo?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false
  72. username: root
  73. password: root
  74. driver-class-name: com.mysql.jdbc.Driver
  75. # 连接池配置
  76. # 初始化大小,最小,最大
  77. initialSize: 5
  78. minIdle: 5
  79. maxActive: 20
  80. # 配置获取连接等待超时的时间
  81. maxWait: 60000
  82. # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
  83. timeBetweenEvictionRunsMillis: 60000
  84. # 配置一个连接在池中最小生存的时间,单位是毫秒
  85. minEvictableIdleTimeMillis: 300000
  86. validationQuery: SELECT 1 FROM DUAL
  87. testWhileIdle: true
  88. testOnBorrow: false
  89. testOnReturn: false
  90. # 打开PSCache,并且指定每个连接上PSCache的大小
  91. poolPreparedStatements: true
  92. maxPoolPreparedStatementPerConnectionSize: 20
  93. # 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
  94. filters: stat,wall,log4j
  95. # 监控配置
  96. web-stat-filter:
  97. enabled: true
  98. url-pattern: /*
  99. exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"
  100. stat-view-servlet:
  101. enabled: true
  102. url-pattern: /sys/druid/*
  103. reset-enable: fasle
  104. login-username: xkcoding
  105. login-password: 123456
  106. filter:
  107. stat:
  108. log-slow-sql: true
  109. slow-sql-millis: 5000
  110. merge-sql: true
  111. # mybatis 配置
  112. mybatis:
  113. type-aliases-package: com.xkcoding.springbootdemoormmybatistis.model
  114. mapper-locations: classpath:mapper/*.xml
  115. # 配置项:开启下划线到驼峰的自动转换. 作用:将数据库字段根据驼峰规则自动注入到对象属性
  116. configuration:
  117. map-underscore-to-camel-case: true
  118. # 通用 Mapper 配置
  119. mapper:
  120. not-empty: false
  121. identity: MYSQL
  122. mappers: com.xkcoding.springbootdemoormmybatistis.util.MyMapper
  123. # PageHelper 配置
  124. pagehelper:
  125. helper-dialect: mysql
  126. reasonable: true
  127. support-methods-arguments: true
  128. params: count=countSql
  129. ```
  130. ### schema.sql
  131. ```mysql
  132. SET FOREIGN_KEY_CHECKS=0;
  133. -- ----------------------------
  134. -- Table structure for `boot_user`
  135. -- ----------------------------
  136. DROP TABLE IF EXISTS `mybatis_user`;
  137. CREATE TABLE `mybatis_user` (
  138. `id` int(11) NOT NULL AUTO_INCREMENT,
  139. `name` varchar(32) DEFAULT NULL,
  140. `tel` varchar(11) DEFAULT NULL,
  141. `create_time` datetime DEFAULT NULL,
  142. PRIMARY KEY (`id`)
  143. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  144. -- ----------------------------
  145. -- Records of boot_user
  146. -- ----------------------------
  147. INSERT INTO `mybatis_user` VALUES (1, 'klay', '13799008800', '2017-11-13 16:04:39');
  148. INSERT INTO `mybatis_user` VALUES (2, 'Tome', '18988991234', '2017-11-13 16:13:28');
  149. ```
  150. ### SpringBootDemoOrmMybatisApplication.java
  151. ```java
  152. @SpringBootApplication
  153. @MapperScan(basePackages = {"com.xkcoding.springbootdemoormmybatis.mapper"})
  154. public class SpringBootDemoOrmMybatisApplication {
  155. public static void main(String[] args) {
  156. SpringApplication.run(SpringBootDemoOrmMybatisApplication.class, args);
  157. }
  158. }
  159. ```
  160. ### MybatisUser.java
  161. ```java
  162. @Getter
  163. @Setter
  164. @NoArgsConstructor
  165. @AllArgsConstructor
  166. @ToString
  167. @Table(name = "mybatis_user")
  168. public class MybatisUser {
  169. @Id
  170. @GeneratedValue(strategy = GenerationType.IDENTITY,generator = "JDBC")
  171. private Long id;
  172. @Column(name = "name")
  173. private String name;
  174. @Column(name = "tel")
  175. private String tel;
  176. @Column(name = "create_time")
  177. private Date createTime;
  178. }
  179. ```
  180. ### MyMapper.java
  181. ```java
  182. public interface MyMapper<T> extends Mapper<T>, MySqlMapper<T> {
  183. }
  184. ```
  185. ### MybatisUserMapper.java
  186. ```java
  187. @Component
  188. public interface MybatisUserMapper extends MyMapper<MybatisUser> {
  189. MybatisUser findByName(@Param("name") String name);
  190. }
  191. ```
  192. ### MybatisUserMapper.xml
  193. ```xml
  194. <?xml version="1.0" encoding="UTF-8"?>
  195. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  196. <mapper namespace="com.xkcoding.springbootdemoormmybatis.mapper.MybatisUserMapper">
  197. <resultMap id="mybatisUserMap" type="com.xkcoding.springbootdemoormmybatis.model.MybatisUser">
  198. <id property="id" column="id"/>
  199. <result property="name" column="name"/>
  200. <result property="tel" column="tel"/>
  201. <result property="createTime" column="create_time" jdbcType="TIMESTAMP"/>
  202. </resultMap>
  203. <select id="findByName" resultMap="mybatisUserMap">
  204. SELECT * FROM mybatis_user WHERE name LIKE #{name}
  205. </select>
  206. </mapper>
  207. ```
  208. ### 其余代码
  209. 详情请参见本demo。

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

Contributors (1)