<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-data-jdbcartifactId>
dependency>

导入了 HikariCP 数据源,jdbc,tx 事务。
为什么没有导入数据库驱动?
<properties>
<java.version>1.8java.version>
<mysql.version>5.1.49mysql.version>
properties>
<dependency>
<groupId>mysqlgroupId>
<artifactId>mysql-connector-javaartifactId>
dependency>
DataSourceAutoConfiguration 数据源自动配置
spring.datasourceDataSourceTransactionManagerAutoConfiguration 事务管理器的自动配置JdbcTemplateAutoConfiguration JDBC 模板的自动配置,可以用来对数据库进行 CRUD
spring.jdbcXADataSourceAutoConfiguration 分布式事务的自动配置spring:
datasource:
url: jdbc:mysql://localhost:3306/todos
username: root
password: secret
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.jdbc.Driver
jdbc:
template:
query-timeout: 3 # 查询超时
测试:
@Slf4j
@SpringBootTest
class SpringbootReviewRecordsApplicationTests {
@Autowired
JdbcTemplate jdbcTemplate;
@Test
void contextLoads() {
Integer count = jdbcTemplate.queryForObject("select count(*) from user", Integer.class);
// jdbcTemplate.queryForList("select count(*) from user");
log.info("记录总数: {}", count);
}
}
<dependency>
<groupId>com.alibabagroupId>
<artifactId>druid-spring-boot-starterartifactId>
<version>1.2.11version>
dependency>
private static final String FILTER_STAT_PREFIX = "spring.datasource.druid.filter.stat"; private static final String FILTER_CONFIG_PREFIX = "spring.datasource.druid.filter.config";
private static final String FILTER_ENCODING_PREFIX = "spring.datasource.druid.filter.encoding";
private static final String FILTER_SLF4J_PREFIX = "spring.datasource.druid.filter.slf4j";
private static final String FILTER_LOG4J_PREFIX = "spring.datasource.druid.filter.log4j"; private static final String FILTER_LOG4J2_PREFIX = "spring.datasource.druid.filter.log4j2";
private static final String FILTER_COMMONS_LOG_PREFIX = "spring.datasource.druid.filter.commons-log";
private static final String FILTER_WALL_PREFIX = "spring.datasource.druid.filter.wall";
spring:
datasource:
url: jdbc:mysql://10.1.1.128:3306/todos?useSSL=false
username: root
password: secret
druid:
aop-patterns: com.xz.* # 监控 Spring Bean
filters: stat, wall # 开启功能 stat (SQL), wall(防火墙)
stat-view-servlet: # 监控页功能
enabled: true
login-username: admin
login-password: admin
reset-enable: false # 重置按钮
web-stat-filter: # 监控 web 应用
enabled: true
url-pattern: /*
# exclusions:
filter: # 对上面 filters 详细配置
stat:
slow-sql-millis: 1000 # 慢查询时间(ms)
log-slow-sql: true
wall:
enabled: true
config:
delete-allow: false # 是否允许删除 SQL
<dependency>
<groupId>org.mybatis.spring.bootgroupId>
<artifactId>mybatis-spring-boot-starterartifactId>
<version>2.2.2version>
dependency>
mybatis-config.xml 中开启驼峰命名:
<settings>
<setting name="mapUnderscoreToCamelCase" value="true"/>
settings>
或者配置 yaml:
mybatis:
configuration:
map-underscore-to-camel-case: true
写 userMapper 代码 @Mapper
=》
写 userMapper.xml
=》
写 userService 代码 @Service
=》
写 Controller @Controller
<insert id="insertXXX" useGeneratedKeys="true" keyProperty="id">
...
insert>
https://github.com/mybatis/spring-boot-starter/wiki/Quick-Start
在 Mapper 中写语句。@Select 等注解放在对应方法上即可。
若插入需要自增 id,加上 @Options 注解配置即可。
若表中没有一个字段,实体类中可以使用 TableField(exist=False) 注解。
@TableName 可以放在类上,指明类的方法。