范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

SpringBoot数据库操作的应用

  1.JDBC+HikariDataSource
  在SpringBoot 2.x项目中,默认使用Hikari连接池管理数据源。相比于传统的 C3P0 、DBCP、Tomcat jdbc 等连接池更加优秀。
  当项目pom.xml引入spring-boot-starter-jdbc启动器依赖后,即可自动导入Hikari,该启动器不但依赖它,还会对其自动配置并创建数据源。我们以MySQL数据库为例,介绍如何使用Hikari。
  数据源是啥?为什么要用?怎么用? 1.1应用实例
  演示SpringBoot如何通过 JDBC+HikariDataSource 完成对Mysql操作。
  (1)数据库和表  -- 创建数据库DROP DATABASE IF EXISTS spring_boot;CREATE DATABASE spring_boot;USE spring_boot; -- 创建表CREATE TABLE furn(`id` INT(11) PRIMARY KEY AUTO_INCREMENT, #id`name` VARCHAR(64) NOT NULL, #家居名`maker` VARCHAR(64) NOT NULL, #厂商`price` DECIMAL(11,2) NOT NULL, #价格`sales` INT(11) NOT NULL, #销量`stock` INT(11) NOT NULL, #库存`img_path` VARCHAR(256) NOT NULL #照片路径); -- 初始化家居数据INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , "北欧风格小桌子" , "熊猫家居" , 180 , 666 , 7 , "assets/images/product-image/6.jpg"); INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , "简约风格小椅子" , "熊猫家居" , 180 , 666 , 7 , "assets/images/product-image/4.jpg"); INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , "典雅风格小台灯" , "蚂蚁家居" , 180 , 666 , 7 , "assets/images/product-image/14.jpg"); INSERT INTO furn(`id` , `name` , `maker` , `price` , `sales` , `stock` , `img_path`) VALUES(NULL , "温馨风格盆景架" , "蚂蚁家居" , 180 , 666 , 7 , "assets/images/product-image/16.jpg"); SELECT * FROM furn;
  (2)进行数据库开发,首先要在pom.xml文件中引入spring-boot-starter-data-jdbc。SpringBoot不知道项目要操作Mysql还是Oracle,因此还需要导入数据库驱动,并指定对应版本。      org.springframework.boot    spring-boot-starter-data-jdbc     mysql    mysql-connector-java    5.1.49
  (3)在application.yml配置操作数据源的信息  spring:  datasource: #配置数据源    #说明:如果没有配置useSSL=true,启动项目会报红警告,但不影响使用    url: jdbc:mysql://localhost:3306/spring_boot?useSSL=true&useUnicode=true&characterEncoding=UTF-8    username: root    password: 123456    driver-class-name: com.mysql.jdbc.Driver
  (4)创建Javabean--Furn.java  package com.li.thymeleaf.bean; import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor; import java.math.BigDecimal; /** * @author 李 * @version 1.0 */@Data@NoArgsConstructor@AllArgsConstructorpublic class Furn {    private Integer id;    private String name;    private String maker;    private BigDecimal price;    private Integer sales;    private Integer stock;    private String imgPath;}
  (5)测试类ApplicationTests.java  package com.li.thymeleaf; import com.li.thymeleaf.bean.Furn;import org.junit.jupiter.api.Test;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.jdbc.core.BeanPropertyRowMapper;import org.springframework.jdbc.core.JdbcTemplate; import javax.annotation.Resource;import java.util.List; /** * @author 李 * @version 1.0 * 演示如何在SpringBoot中开发测试类 */@SpringBootTestpublic class ApplicationTests {    //这里使用spring的JDBCTemplate    @Resource    private JdbcTemplate jdbcTemplate;     @Test    public void contextLoads() {        //使用RowMapper接口来对返回的数据进行封装(底层是反射->setter)        BeanPropertyRowMapper rowMapper =                new BeanPropertyRowMapper<>(Furn.class);        List furns = jdbcTemplate.query("select * from furn", rowMapper);        for (Furn furn : furns) {            System.out.println("furn=" + furn);        }        //查看底层使用的是什么数据源        System.out.println(jdbcTemplate.getDataSource().getClass());    }}
  测试结果:
  <dependency> <groupId>org.springframework.bootgroupId> <artifactId>spring-boot-starter-testartifactId>dependency>2.整合Druid到SpringBoot2.1Druid介绍alibaba/druid: 为监控而生的数据库连接池 (github.com)
  官方使用文档 · alibaba/druid Wiki (github.com)
  Druid数据库连接池性能优秀,它除了提供性能卓越的数据池功能外,还继承了SQL监控,黑名单拦截等功能。强大的监控特性,通过Druid提供的监控功能,可以清楚知道连接池和SQL的工作情况,所以根据项目需要,我们也要掌握Druid和SpringBoot的整合。
  整合Druid到SpringBoot的方式:  自定义方式  引入starter  2.2Druid基本使用
  (1)修改pom.xml,引入druid依赖      com.alibaba    druid    1.1.17
  (2)创建配置类 DruidDataSourceConfig.java,将DruidDataSource注入容器  package com.li.thymeleaf.config; import com.alibaba.druid.pool.DruidDataSource;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; /** * @author 李 * @version 1.0 * 配置类 */@Configurationpublic class DruidDataSourceConfig {    //注入DruidDataSource        //通过@ConfigurationProperties指定读取application.yml文件的数据    //我们就不需要调用DruidDataSource的setXxx方法来配置(不推荐)    @ConfigurationProperties("spring.datasource")    @Bean    public DataSource dataSource() {        return new DruidDataSource();    }}
  (3)测试类ApplicationTests.java(略,同上)
  测试结果:
  2.2.1一个问题
  问题:为什么我们注入了自己的数据源,默认的HikariDataSource就失效了?
  先来弄明白,默认的HikariDataSource 是如何配置的:
  SpringBoot通过DataSourceAutoConfiguration.java来进行数据源的配置,在进行默认的配置之前,如果检测到容器中已经有DataSource Bean,就不会注入默认的HikariDataSource。
  因此,如果你注入了自己的数据源,就不会注入默认的HikariDataSource。
  DataSourceAutoConfiguration.java:
  2.3Druid监控功能2.3.1开启内置监控页
  怎样使用Druid的内置监控页面  :内置监控页面是一个Servlet,具体配置看这里
  (1)在配置类中,启用druid的监控页功能:
  在web项目中使用web.xml配置,若在SpringBoot中,有两种方法注入Servlet---注解和RegistrationBean,这里使用RegistrationBean
  DruidDataSourceConfig.java:  package com.li.thymeleaf.config; import com.alibaba.druid.pool.DruidDataSource;import com.alibaba.druid.support.http.StatViewServlet;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.boot.web.servlet.ServletRegistrationBean;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; /** * @author 李 * @version 1.0 * 配置类 */@Configurationpublic class DruidDataSourceConfig {    //注入DruidDataSource    //通过@ConfigurationProperties指定读取yml文件的前缀的数据    @ConfigurationProperties("spring.datasource")    @Bean    public DataSource dataSource() {        return new DruidDataSource();    }     //配置Druid的监控页功能    @Bean    public ServletRegistrationBean statViewServlet() {        //创建StatViewServlet        ServletRegistrationBean registrationBean                = new ServletRegistrationBean<>(new StatViewServlet(), "/druid/*");        //设置初始化参数-用户名和密码-根据官方配置文件设置        registrationBean.addInitParameter("loginUsername", "olien");        registrationBean.addInitParameter("loginPassword", "123456");        return registrationBean;    }}
  (2)启动项目,浏览器中访问  http://项目ip:项目端口/项目名称/druid/index.html  ,输入配置的用户名和密码,即可访问到内置的监控页面:
  2.3.2SQL监控
  配置_StatFilter · alibaba/druid Wiki (github.com)
  除了文档中的配置方式,也可在配置类中直接对数据源进行设置。
  修改DruidDataSourceConfig.java:
  启用SQL监控功能之后,在监控页中可以查看到所有对数据库发出的SQL语句:
  2.3.3-Web关联监控
  Web关联监控配置
  Spring关联监控配置
  修改DruidDataSourceConfig.java:注入webStatFilter  //配置WebStatFilter,用于采集web-jdbc关联的监控数据@Beanpublic FilterRegistrationBean webStatFilter() {    //创建过滤器webStatFilter    WebStatFilter webStatFilter = new WebStatFilter();    FilterRegistrationBean filterRegistrationBean =            new FilterRegistrationBean<>(webStatFilter);    //设置webStatFilter的监控url    filterRegistrationBean.setUrlPatterns(Arrays.asList("/*"));    //根据官方文档设置webStatFilter排除的url    filterRegistrationBean.addInitParameter("exclusions",            "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");    return filterRegistrationBean;}
  启用URI监控功能之后,在监控页中可以查看到所有的Web应用情况和URI请求情况:
  2.3.4SQL防火墙
  Druid提供了WallFilter,它是基于SQL语义分析来实现防御SQL注入攻击的。具体配置看这里
  修改DruidDataSourceConfig.java:
  启用SQL防火墙之后,在监控页中可以查看到所有的SQL情况:
  2.3.5Session监控
  注意:这里的Session不包括Druid后台监控系统产生的Session
  Druid的Session监控不需要配置,在开启了内置监控功能后就可以使用了。
  2.4Druid-Starter
  整合Druid到SpringBoot的方式有两种:自定义方式和引入starter。
  2.3中的所有例子中我们使用的是自己引入druid+配置类方式整合druid和监控。此外,还可以引入Druid Srping Boot Starter,让程序员在SpringBoot项目中更加轻松集成Druid和监控。
  演示使用Druid-Starter(演示之前,删除之前所有的自定义方式操作)
  (1)pom.xml引入druid-spring-boot-starter      com.alibaba    druid-spring-boot-starter    1.1.17
  (2)在application.yml文件中配置druid和监控功能  spring:  datasource: #配置数据源    #如果没有配置useSSL=true,启动项目会报红警告,但不影响使用    url: jdbc:mysql://localhost:3306/spring_boot?useSSL=true&useUnicode=true&characterEncoding=UTF-8    username: root    password: 123456    driver-class-name: com.mysql.jdbc.Driver    #配置druid和监控功能    druid:      stat-view-servlet: #(1)开启监控页        enabled: true        login-username: jack        login-password: 1234        reset-enable: false      web-stat-filter: #(2)启用web监控功能        enabled: true        url-pattern: /*        exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"      filter:        stat: #(3)启用sql监控功能          slow-sql-millis: 1000 #单位ms          log-slow-sql: true #启用慢查询的sql日志          enabled: true        wall: #(4)启用sql防火墙功能          enabled: true          config:            drop-table-allow: false #是否允许进行删除表的操作            select-all-column-allow: false #是否允许查询所有字段的操作3.练习
  将异常处理、注入Servlet、Filter、Listener,Tomcat切换,数据库操作(HikariDataSource&DruidDataSource)相关代码和案例写一遍

你在人际交往中悟出了哪些极品真理你在人际交往中悟出了哪些极品真理来看看网友的分享哒咩话说委婉见人说人话见鬼说鬼话吐舌猪猪非常饿当你想不通一件事往利益上想准能想通Marchchangan不要把秘密告诉朋友因为朋友也莲叶田田在清早的冷浸浸里醒来,还带着梦里的一丝恍惚,窗户投来外面的天光,虫子在鸣叫,老婆在熟睡,老大老二也在熟睡,带上手机上厕所,瓷板的冰凉让人一颤,什么时候该加垫子了,冲水的声音突兀又刺时隔40年再看7080后语文课本插图,网友是童年回忆,看完泪奔了曾经年少的我们,现在都过不惑之年,翻开儿时的课本,一幕幕往事在眼前出现,不觉眼睛湿润模糊了起来,真的很想回到过去,回到那个无忧无虑的艰苦年代,因为那个时候除了生活苦,剩下的的都是欢一轮千古月,银辉洒向人间都是情一轮千古沧桑月,伴着嫦娥游广宇,氤氲银辉满天地,飘飘洒洒都是情。看那海上生明月,天涯共此时。看那长安一片月,万户捣衣声。说那但愿人长久,千里共婵娟,说那今夜月明人尽望,还有月儿弯弯关键时刻拆拜登的台,印度反悔要退出美国主导的IPEF没好处众所周知,自从美国将战略目标转向亚太地区后,拜登虽然嘴上承诺不与中国进行新冷战,但在私底下,拜登政府却在不断拉拢盟友,欲在经济军事等领域全方位围堵中国。日前,由美国主导的新经济圈构知柏地黄丸精巧搭配还能治这4种病让它作用翻倍大家好,我是屈医生。知柏地黄丸不仅能够滋阴降火,给它精巧搭配还能治疗这4种病,让你家里的知柏地黄丸作用翻倍。第一种,知柏地黄丸搭配右归丸,如果你平时手脚心发热,心胸燥热,还有盗汗等绿衫军完成签约,火箭迎来好消息,保罗被起诉,湖人三方交易受阻头条创作挑战赛北京时间9月13日,NBA休赛期正在进行,联盟仍然不平静。贝弗利认为,篮网应该留下欧文,因为他们找不到比欧文更好的球员。NBA记者Windhorst宣称,博格达诺维奇哈维的诺言要实现了,巴萨正逐渐回到和拜仁同一水平巴萨主帅哈维。2比0,安联球场没有见证逆袭,拜仁成为了第一支在欧战中连续5次战胜巴萨的球队,横亘长达七年。但相比于记忆中那些曾经的骇人数字,哈维的球队这一回几乎浮出了水面,如果不是中超积分榜山东泰山11逼平无缘缩小分差,最大黑马强势领跑9月14日19点30分,中超第18轮比赛进行,武汉三镇过招山东泰山,比赛难度不小。目前积分榜上,山东泰山尚且落后少赛一轮的武汉多达4分。作为升班马,武汉三镇如此表现可谓现象级。这场国足换帅刻不容缓!2位资深土帅成热门人选,陈戌源将如何选择?在今年的东亚杯结束后,国足已经淡出了球迷们的视野有很长一段时间了。近日,来自某北京媒体的报道称,国足临时主帅李霄鹏下课已成定局,足协方面已经有了新的国足主帅人选。这个消息一经传出,CBA辽篮遇麻烦,莫兰德暂不归队,郭艾伦表态,杨鸣争冠节外生枝众所周知,最近辽宁队正在备战新赛季的比赛。对辽宁队而言他们毕竟是上个赛季的冠军,所以背负着这样的责任和压力,本赛季务必要争取获得更好的成绩,甚至继续向冠军发起冲击,才能够确保自己不
无冕之王荷兰队公布世界杯大名单,三进决赛却从未夺冠的郁金香近日荷兰队公布了2022卡塔尔世界杯的出征人员,根据荷兰队公布世界杯大名单看得出来阵容还是十分豪华的,荷兰队在世界杯历史上非常悲催,曾三次进入过决赛可是最终都是无缘于冠军没有机会捧杜锋下课之后,男篮中方教练谁敢上?三人有戏,杨鸣机会最大带完世界杯之后,杜锋也正式卸任了。新任教练是来自欧洲的名帅乔尔杰维奇。值得一提的是,这次换回欧洲教练,并不是全权都交出,而是重启十年前的洋土结合,也就是主教练是外国教练,助理教练是杜锋战胜了国外的对手,却输给了国内的球迷杜锋这三年,直如下了趟地狱!然而,三年前,他却是雄心勃勃,意气风发!在2019年世界杯之前,杜锋输给了李楠,后者成为中国男篮的主教练,随后李楠兵败如山倒,中国男篮丢掉了奥运会门票,乌西克赛事推广人只关心和富里的拳王统一战,不在乎赫尔戈维奇虽然IBF官方在近期下达了要求现任IBFWBA超级WBOIBO重量级世界拳王奥列克桑德尔乌西克(OleksandrUsyk)和克罗地亚重量级拳手菲利普赫尔戈维奇进行IBF重量级世界翻译骑士能摆脱最近的颓势吗Wereonlyonemonthintotheseason,buttheClevelandCavaliershavebeenonquitetherollercoasterride。恭喜郑智!新保利尼奥火线驰援恒大,足协杯首次亮相就独造三球日前,恒大在本赛季足协杯淘汰赛首次亮相,就给球迷带来了惊喜。恒大主帅郑智在比赛中派出了清一色的青年军出战,跟中甲球队四川九牛死磕。四川九牛队坐拥赵旭日邹正赵石等中超级名将,而且还有五百天后得分上双,西蒙斯得到赛季最高分,杜兰特向状元示好西蒙斯上一次在常规赛得分上双还是五百天之前,今天,他得到十一分,是其本赛季的最高得分。一名处在当打之年的状元,得到两位数的分数就可以成为一篇报道,有如此待遇的可能只有他一人了。目前意大利将打造超巨型游艇可容纳6万名乘客环球时报综合报道据英国太阳报14日报道,意大利一家设计工作室正众筹建造一艘可容纳6万名乘客的超巨型游艇。如果顺利建成,它将成为全世界最大的漂浮建筑。这艘名为Pangeos的巨型游艇尬住!俄罗斯外长称戴的是华为手表不是苹果手表CNMO新闻近日,俄罗斯方面发布该国外长拉夫罗夫在印尼巴厘岛的视频,接着俄罗斯外长戴苹果手表的消息一传十十传百。华为智能手表不过,拉夫罗夫本人回应称,自己用的并不是苹果手表,而是华不是俄罗斯炸的,更不是自导自演!波兰导弹事件,仅仅是一场意外波兰外交部指责俄制导弹在波兰爆炸当地时间11月15日,就在乌克兰第N次传言俄罗斯的导弹已经耗尽之际,俄罗斯空天军战略轰炸机里海舰队小型导弹舰部队等,对乌克兰发起了自开战以来规模最大润星科技高端数控机床及智能制造解决方案润星科技第一印象印象润星民族的世界的润星科技(股票代码002685)始终致力于提供高端数控机床及智能制造解决方案润星科技是一家什么样的公司?润星科技是一家专注于高端装备研发制造销售