SpringBoot底层统一采用SpringData处理数据库,这一章主要来讲一下SpringBoot整合jdbc、durid、mybatis的方式。
(一)整合jdbc
整合jdbc主要有三步: 1.引入依赖 2.配置数据源 3.访问 引入springdata启动器和mysql连接包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency>
在application.yaml或者application.properties中配置spring datasource数据源。在新版本的spring-boot-starter-jdbc,mysql驱动由原先的com.mysql.jdbc.Driver变为了com.mysql.cj.jdbc.Driver
spring: datasource: url: jdbc:mysql://localhost:3306/testsql?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8 username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver
通过jdbc模板访问
publicclassJdbcController { privateJdbcTemplatejdbcTemplate; "/jdbc") (publicList<Map<String, Object>>query(){ Stringsql="select * from user"; List<Map<String, Object>>maps=jdbcTemplate.queryForList(sql); returnmaps; } }
(二)整合druid
druid是阿里巴巴公司开发的数据库连接池,它的官网称Druid是Java语言中最好的数据库连接池。Druid能够提供强大的监控和扩展功能。 druid的使用首先也是引入依赖
<!-- https://mvnrepository.com/artifact/com.alibaba/druid --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.23</version> </dependency>
com.alibaba.druid.pool.DruidDataSource 基本配置参数如下:
Spring Boot 2.0 以上默认使用 com.zaxxer.hikari.HikariDataSource 数据源,但可以通过 spring.datasource.type 指定数据源。我们将type修改为druid。
设置完数据源后,就可以设置数据源连接初始化大小、最大连接数、等待时间、最小连接数 等设置项
spring: datasource: url: jdbc:mysql://localhost:3306/myssh?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8 username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver type: com.alibaba.druid.pool.DruidDataSource #连接池属性 #Spring Boot 默认是不注入这些属性值的,需要自己绑定 #druid 数据源专有配置 initialSize: 5 minIdle: 5 maxActive: 20 maxWait: 60000 timeBetweenEvictionRunsMillis: 60000 minEvictableIdleTimeMillis: 300000 validationQuery: SELECT 1 FROM DUAL testWhileIdle: true testOnBorrow: false testOnReturn: false poolPreparedStatements: true #配置监控统计拦截的filters,stat:监控统计、log4j:日志记录、wall:防御sql注入 #如果允许时报错 java.lang.ClassNotFoundException: org.apache.log4j.Priority #则导入 log4j 依赖即可,Maven 地址:https://mvnrepository.com/artifact/log4j/log4j filters: stat,wall,log4j maxPoolPreparedStatementPerConnectionSize: 20 useGlobalDataSourceStat: true connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
因为在配置文件中使用了log4j,因此我们也需要引入log4j的依赖。
最后编写配置类,ConfigurationProperties注解大家都很熟悉了,从配置文件的spring.datasource下读取配置。statViewServlet方法配置后台监控功能,主要设置ip黑白名单,用户名密码等。statFilter用于配置过滤器等消息。
publicclassDruidConfig { "spring.datasource") (publicDataSourcedruidDataSource(){ returnnewDruidDataSource(); } //后台监控//因为SpringBoot内置了servlet容器,所以没有web.xml,替代方法:ServletRegisterationBeanpublicServletRegistrationBeanstatViewServlet(){ //创建servlet注册实体ServletRegistrationBeanservletRegistrationBean=newServletRegistrationBean(newStatViewServlet(),"/druid/*"); //设置ip白名单servletRegistrationBean.addInitParameter("allow","127.0.0.1"); //设置ip黑名单,如果allow与deny共同存在时,deny优先于allowservletRegistrationBean.addInitParameter("deny","192.168.0.19"); //设置控制台管理用户servletRegistrationBean.addInitParameter("loginUsername","druid"); servletRegistrationBean.addInitParameter("loginPassword","123456"); //是否可以重置数据servletRegistrationBean.addInitParameter("resetEnable","false"); returnservletRegistrationBean; } publicFilterRegistrationBeanstatFilter(){ //创建过滤器FilterRegistrationBeanfilterRegistrationBean=newFilterRegistrationBean(newWebStatFilter()); //设置过滤器过滤路径filterRegistrationBean.addUrlPatterns("/*"); //忽略过滤的形式filterRegistrationBean.addInitParameter("exclusions","*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"); returnfilterRegistrationBean; } }
最后输入
druid所提供的强大功能。关于druid更多的内容可以从
(三)整合Mybatis
在项目中基本上不会使用jdbc直接连接数据库,对数据库的操作往往会通过一些持久层的框架,下面来讲讲Mybatis的整合,Mybatis的整合分为以下几步:
1.导入包
2.配置文件
3.mybatis配置
4.编写sql
5.调用
整合包 mybatis-spring-boot-starter
<!-- https://mvnrepository.com/artifact/org.mybatis.spring.boot/mybatis-spring-boot-starter --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.3</version> </dependency>
配置mybatis,这里主要配置了type-aliases-package和mapper-locations
spring: datasource: url: jdbc:mysql://localhost:3306/myssh?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8 username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver mybatis: type-aliases-package: com.javayz.springbootdemo.pojo mapper-locations: classpath:mybatis/mapper/*.xml
编写Mapper接口,到这里都属于Mybatis的基础操作,就不做介绍了
publicinterfaceUserSelectMapper { List<User>queryUserList(); }
mapper.xml配置文件编写sql语句
<mappernamespace="com.javayz.springbootdemo.mapper.UserSelectMapper"><selectid="queryUserList"resultType="User"> select * from user </select></mapper>
(四)总结
在这篇文章中我主要介绍了SpringBoot中jdbc、durid、mybatis的整合,SpringBoot的整合步骤基本都一致,引入依赖、配置文件、调用。