016-Spring Boot JDBC

一、数据源装配

通过查看代码可知,默认已装配了数据源和JdbcTemplate

System.out.println(context.getBean(DataSource.class));
System.out.println(context.getBean(JdbcTemplate.class));

1.1、环境搭建

主要是pom引用:spring-boot-starter-jdbc、增加数据库驱动

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.lhx.spring</groupId><artifactId>springboot-web</artifactId><version>0.0.1-SNAPSHOT</version><packaging>jar</packaging><name>springboot-web</name><url>http://maven.apache.org</url><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.target>1.8</maven.compiler.target><maven.compiler.source>1.8</maven.compiler.source></properties><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>1.5.9.RELEASE</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency></dependencies>
</project>
View Code

查看spring-boot-autoconfigure-1.5.9.RELEASE.jar包下的org.springframework.boot.autoconfigure.jdbc下的DataSourceProperties其实所有的都是类似的配置

@ConfigurationProperties(prefix = "spring.datasource")
public class DataSourcePropertiesimplements BeanClassLoaderAware, EnvironmentAware, InitializingBean {

可以看到默认读取spring.datasource开头的配置。

1.2、配置

spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springboot
spring.datasource.username=root
spring.datasource.password=root

1.3、使用

    public static void main(String[] args) throws SQLException {ConfigurableApplicationContext context = SpringApplication.run(App.class, args);dataSource = context.getBean(DataSource.class);Connection connection = dataSource.getConnection();System.out.println(connection.getCatalog());}

二、JdbcTemplate

在配置好基本配置后,JdbcTemplate就可以使用了

@Repository
public class ProductDao {@Autowiredprivate JdbcTemplate jdbcTemplate;public void addProdcut(String value) {String sql = "insert into product(pname) values('" + value + "')";jdbcTemplate.execute(sql);}
}
View Code

调用

public class App {public static void main(String[] args) throws SQLException {ConfigurableApplicationContext context = SpringApplication.run(App.class, args);context.getBean(ProductDao.class).addProdcut("mp3");connection.close();}
}
View Code

三、切换数据源

System.out.println(context.getBean(DataSource.class));

查看到使用的是默认提供的:org.apache.tomcat.jdbc.pool.DataSource数据源

方式一、排除添加切换

1》排除掉tomcat-jdbc

        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId><exclusions><exclusion><groupId>org.apache.tomcat</groupId><artifactId>tomcat-jdbc</artifactId></exclusion></exclusions></dependency>
View Code

2》添加新的数据源

        <dependency><groupId>com.zaxxer</groupId><artifactId>HikariCP</artifactId></dependency>
View Code

方式二、type配置数据源切换

3.2.1、原理查看

查看spring-boot-autoconfigure-1.5.9.RELEASE.jar包下的org.springframework.boot.autoconfigure.jdbc下的DataSourceProperties的配置

使用type指定【private Class<? extends DataSource> type;】在application.properties中

spring.datasource.type=com.zaxxer.hikari.HikariDataSource

默认支持以下几种数据源类型,查看spring-boot-autoconfigure-1.5.9.RELEASE.jar包下的org.springframework.boot.autoconfigure.jdbc下的DataSourceAutoConfiguration

DataSourceConfiguration.Tomcat.class
DataSourceConfiguration.Hikari.class
DataSourceConfiguration.Dbcp.class
DataSourceConfiguration.Dbcp2.class
DataSourceConfiguration.Generic.class

3.2.2、具体步骤

1》添加对应数据源pom

        <dependency><groupId>com.zaxxer</groupId><artifactId>HikariCP</artifactId></dependency>
View Code

2》使用配置

spring.datasource.type=com.zaxxer.hikari.HikariDataSource

3.3、配置自定义数据源

1》添加POM依赖

        <dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.6</version></dependency>

2》、增加DBConfiguration配置类

package com.lhx.spring.springboot_web;import javax.sql.DataSource;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringBootConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.core.env.Environment;import com.alibaba.druid.pool.DruidDataSource;@SpringBootConfiguration
public class DBConfiguration {@Autowiredprivate Environment env;@Beanpublic DataSource createDataSource() {DruidDataSource source = new DruidDataSource();source.setUrl(env.getProperty("spring.datasource.url"));source.setUsername(env.getProperty("spring.datasource.username"));source.setPassword(env.getProperty("spring.datasource.password"));source.setDriverClassName(env.getProperty("spring.datasource.driverClassName"));return source;}
}
View Code

四、事务

4.1、配置开启

1、在入口app增加注解

@EnableTransactionManagement

2、在需要事务的公有方法上添加注解

@Transactional

示例

    @Transactionalpublic void addProdcutBatch(String... names) throws Exception {for (String name : names) {String sql = "insert into product(pname) values('" + name + "')";jdbcTemplate.execute(sql);if ("".equals("")) {throw new NullPointerException();}}}

注意:spring事务,默认支持运行时异常,即RunTimeException,非运行时异常不会回滚

4.2、设置针对哪些异常使用事务

默认是运行时

设置所有异常

@Transactional(rollbackFor=Exception.class)

设置哪些异常不回滚

@Transactional(noRollbackFor=NullPointerException.class)

 

注意点:

1、要想使用事务生效,被调用的方法必须有Transactional 注解,对于内部调用方法有无注解无影响

2、需要数据库支持事务。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/283684.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

分库分表和 NewSQL 到底怎么选?

文章来源&#xff1a;【公众号&#xff1a;CoderW】 目录 背景 分表 分库 分库分表的成本 NewSQL NewSQL 平滑接入方案 NewSQL 真的有那么好吗&#xff1f; NewSQL 的应用 分库分表和 NewSQL 到底怎么选&#xff1f; 背景 曾几何时&#xff0c;“并发高就分库&#xff…

JsonPath基本使用

概述在.Net开发中&#xff0c;一般操作Json都是使用Newtonsoft.Json包&#xff0c;下面我们来使用该包以类似xpath的方式JsonPath操作Json。介绍JsonPath是xpath在json中的应用&#xff0c;是参照xpath表达式来解析xml文档的方式&#xff0c;用一个抽象的名字$来表示最外层的对…

jQuery/javascript实现简单网页计算器

1 <html>2 <head>3 <meta charset"utf-8">4 <title>jQuery实现</title>5 <script src"jquery.js"></script>6 7 <style type"text/css">8 table{background-color:pink;width:300px;height…

AC日记——Paint Pearls hdu 5009

Paint Pearls 思路&#xff1a; 离散化dp剪枝&#xff1b; dp是个n方的做法&#xff1b; 重要就在剪枝&#xff1b; 如果一个长度为n的区间&#xff0c;有大于根号n种颜色&#xff0c;还不如一个一个涂&#xff1b; 来&#xff0c;上代码&#xff1a; #include <cstdio> …

CSS缩写总结

1、16进制的色彩值&#xff0c;如果每两位的值相同&#xff0c;可以缩写一半。如&#xff1a; color: #ffffff > color: #fffcolor: #aabbcc > color: #abc2、边框语法糖 边框&#xff1a; border: width style color; > border: (边宽) (样式) (颜色); 如&#xff1a…

雷军招人反被3句话问懵:当我在面试牛人的时候,牛人也在面试我

来 源&#xff5c;环球人力资源智库&#xff08;GHRlib&#xff09; 作 者&#xff5c;Black “你做过手机吗&#xff1f;” “没做过。” “你认识中移动老总王建宙吗&#xff1f;” “不认识。” “你认识富士康老板郭台铭吗&#xff1f;” “我认识他&#xff0c;他不认识我…

【jQuery系列之插件】jQuery插件---exselect实现联动

<!DOCTYPE HTML> <html> <head><meta charset"utf-8"><title>cxSelect 联动下拉菜单 </title><style>body{background:#ddd;font:14px/1.7 tahoma,\5fae\8f6f\96c5\9ed1,sans-serif;}fieldset{margin:2em 0;}fieldset leg…

C# 11 中的 required members

C# 11 中的 required membersIntro在 C# 11 中引入了一个新的特性 —— Required Members&#xff0c;引入了一个新的 required 关键词&#xff0c;可以用来表示字段或者属性在类型初始化的时候必须要进行初始化&#xff0c;这一特性也进一步的改进了可空引用类型的用法。Sampl…

架构师速成4.6-软技能和硬技能

架构师速成4.6-软技能和硬技能 在投职和面试的过程中。雇主一般会查看求职者的两种技能&#xff1a;硬技能与软技能。 硬技能就是可以通过培训或可以easy量化的技能。硬技能包含以下这些&#xff1a; 熟练的外语能力文凭或证书打字速度计算机程序编写能力而软技能。则是较难量化…

Netty1:初识Netty

为什么使用Netty Netty是业界最流行的NIO框架之一&#xff0c;它的健壮性、功能、性能、可定制性、可扩展性在同类框架中都是首屈一指的&#xff0c;它已经得到了成百上千的商用项目的证明。对于为什么使用Netty这个话题&#xff0c;我们先看一下使用原生的NIO有什么缺点&#…

互联网大佬简史:马云/雷军/罗永浩/刘强东...

燃财经&#xff08;ID:rancaijing&#xff09;原创 作者 | 杜枫 编辑 | 魏佳中国互联网的发展&#xff0c;是一部由大佬撑起的奋斗史&#xff0c;也是一部由大佬主演的打脸史。和传统行业不同&#xff0c;互联网行业日新月异&#xff0c;从业者趋于年轻。马云唱起了摇滚&#x…

Windows 11 新版 22621.575 和 22622.575 推送:照片、URL、文件资源管理器

面向 Beta 频道的 Windows 预览体验成员&#xff0c;微软推送了 Windows 11 预览版 Build 22621.575 和 22622.575。 目前 Beta 频道 Windows 11 预览版分为两组进行测试&#xff0c;通过两组 Windows 预览体验成员的使用数据和反馈&#xff0c;以更好的测试新功能的可靠性。Wi…

linux mysql5.6 安装

2019独角兽企业重金招聘Python工程师标准>>> 1、gcc yum install gcc gcc-c ncurses-devel perl 2、cmake安装 wget http://www.cmake.org/files/v2.8/cmake-2.8.10.2.tar.gz tar -xzvf cmake-2.8.10.2.tar.gz cd cmake-2.8.10.2 ./bootstrap ; make ; make insta…

学习进度条第十周

第十周 所花时间 15小时 代码量 500行左右 博客量 1 了解到的知识点 学习安卓开发的环境配置&#xff0c;进行简单的开发。重行复习了数据结构的部分算法转载于:https://www.cnblogs.com/liulitianxia/p/6822919.html

基于DeepConvLSTM的传感器信号分类

随机智能手机的普及&#xff0c;在日常生活中&#xff0c;大多数人在做任何事情的时候&#xff0c;都会随身携带手机。如果开启手机中的传感器&#xff0c;当用户运动时&#xff0c;就可以采集大量的用户信息&#xff0c;根据这些信息&#xff0c;就可以判断当前用户的运动模式…

Python常用的12个GUI框架

Graphical User Interface&#xff0c;简称 GUI&#xff0c;又称图形化用户接口&#xff0c;所谓的GUI编程&#xff0c;指的是用户不需要输入代码指令&#xff0c;只通过图形界面的交互就可以操作软件功能。 1.Tkinter 一个轻量级的跨平台图形用户界面&#xff08;GUI&#xff…

PHP下操作Linux消息队列完成进程间通信的方法

2019独角兽企业重金招聘Python工程师标准>>> 来源:http://www.jb51.net/article/24353.htm 关于Linux系统进程通信的概念及实现可查看&#xff1a;http://www.ibm.com/developerworks/cn/linux/l-ipc/   关于Linux系统消息队列的概念及实现可查看&#xff1a;htt…

.NET 7 发布的最后一个预览版Preview 7, 下个月发布RC

微软在2022年8月9日 发布了.NET 7 Preview 7[1]&#xff0c;这是它在11月10日 RTM 之前进入发布候选阶段之前的最后预览版。预览版 7 已在 Visual Studio 17.4 预览版 1 中进行了测试&#xff0c;该预览版也于也与 VS 2022 v17.3 版本一起发布。对于预览版7&#xff0c;开发团队…

2022年全球职业教育行业发展报告

职业教育丨研究报告 核心摘要&#xff1a; 职业教育是职业学校教育与职业培训组成的有机整体&#xff0c;行业参与者除教育培训机构与受训学生外&#xff0c;还涉及企业雇主、行业协会、政府等多方&#xff0c;各群体共同构成密不可分的产业生态。 宏观而言&#xff0c;职业…

C++中STL的一些用法的补充

1 清空vector中的所有元素并释放内存&#xff1a; 1 vector<int*> xx; 2 for(int it0;it!xx.size();it) 3 { 4 delete xx[it]; 5 } 6 xx.clear(); 转载于:https://www.cnblogs.com/jinzhipeng/p/6825585.html