【Spring Boot 25】JdbcTemplate配置类 + 事务控制 + API简介

@Value(“${url}”)

private String url;

@Value(“${duridUserName}”)

private String username;

@Value(“${password}”)

private String password;

@Value(“${filters}”)

private String filters;

@Value(“${initialSize}”)

private int initialSize;

@Value(“${maxActive}”)

private int maxActive;

@Value(“${minIdle}”)

private int minIdle;

@Value(“${maxWait}”)

private int maxWait;

@Value(“${validationQuery}”)

private String validationQuery;

@Value(“${testWhileIdle}”)

private boolean testWhileIdle;

@Value(“${testOnBorrow}”)

private boolean testOnBorrow;

@Value(“${testOnReturn}”)

private boolean testOnReturn;

@Value(“${maxPoolPreparedStatementPerConnectionSize}”)

private int maxPoolPreparedStatementPerConnectionSize;

@Value(“${removeAbandoned}”)

private boolean removeAbandoned;

@Value(“${removeAbandonedTimeout}”)

private int removeAbandonedTimeout;

@Value(“${timeBetweenEvictionRunsMillis}”)

private int timeBetweenEvictionRunsMillis;

@Value(“${minEvictableIdleTimeMillis}”)

private int minEvictableIdleTimeMillis;

@Bean(initMethod=“init”,destroyMethod=“close”)

public DruidDataSource dataSource(){

DruidDataSource dataSource=new DruidDataSource();

try {

dataSource.setUrl(url);

dataSource.setDriverClassName(driverClassName);

dataSource.setUsername(username);

dataSource.setPassword(password);

dataSource.setFilters(filters);

dataSource.setInitialSize(initialSize);

dataSource.setMaxActive(maxActive);

dataSource.setMinIdle(minIdle);

dataSource.setMaxWait(maxWait);

dataSource.setValidationQuery(validationQuery);

dataSource.setTestWhileIdle(testWhileIdle);

dataSource.setTestOnBorrow(testOnBorrow);

dataSource.setTestOnReturn(testOnReturn);

dataSource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize);

dataSource.setRemoveAbandoned(removeAbandoned);

dataSource.setRemoveAbandonedTimeout(removeAbandonedTimeout);

dataSource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);

dataSource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);

System.out.println(“连接池启动成功”);

} catch (SQLException e) {

e.printStackTrace();

}

return dataSource;

}

}

5、事务的使用

@Service

public class UserServiceImpl implements UserService {

@Autowired

private JdbcTemplate jdbcTemplate;

@Override

@Transactional

public void insertUser(User user) {

String sql = “insert into user(id, name) values(?,?)”;

jdbcTemplate.update(sql, user.getId(), user.getName());

//int num = 1/0; //放开测试事务。预期结果为添加失败,库中无数据。测试结果与预期一致

}

}

【Spring Boot 23】MyBatis事务管理

6、dao层代码简介

@Repository(“userDao”)

public class UserDaoImpl implements UserDao {

@Autowired

private JdbcTemplate jdbcTemplate;

//判断用户是否登录成功

public boolean isLogin(UserEntity paramUser) {

boolean flag=false;

String sqlStr=“select * from user where userName=? and passWord=?”;

List userList=jdbcTemplate.query(sqlStr,

new Object[]{paramUser.getUserName(),paramUser.getPassWord()},

new BeanPropertyRowMapper(UserEntity.class));

if(userList!=null && userList.size()>0){

flag=true;

}

return flag;

}

}

四、API介绍


1、执行DDL语句

(1)API简介

//一般用于执行DDL语句

public int execute(final String sql)

(2)代码实例

public class Test01 {

public static void main(String[] args) {

// 创建表的SQL语句

String sql = “CREATE TABLE product(”

  • “pid INT PRIMARY KEY AUTO_INCREMENT,”

  • “pname VARCHAR(20),”

  • “price DOUBLE”

  • “);”;

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

jdbcTemplate.execute(sql);

}

}

2、JdbcTemplate实现增删改

(1)API简介

//用于执行INSERT、UPDATE、DELETE等DML语句

public int update(String sql)

(2)代码实例

public class Test {

public static void main(String[] args) throws Exception {

insertTest();

updateTest();

deleteTest();

}

// JDBCTemplate插入

public static void insertTest() throws Exception {

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

String sql = “INSERT INTO user(id,name,age) VALUES (?, ?, ?)”;

jdbcTemplate.update(sql, 1, “素小暖”, 18);

}

// JDBCTemplate更新

public static void updateTest() throws Exception {

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

String sql = “UPDATE user SET age= ?, address = ? WHERE name=?”;

int i = jdbcTemplate.update(sql, 19, “大连市高新园区”, “素小暖”);

System.out.println("影响的行数: " + i);

}

// JDBCTemplate删除

public static void deleteTest() throws Exception {

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

String sql = “DELETE FROM user WHERE id=?”;

int i = jdbcTemplate.update(sql, 1);

System.out.println("影响的行数: " + i);

}

}

3、JdbcTemplate查询-queryForInt返回一个int整数

(1)API简介

//执行查询语句,返回一个int类型的值

public int queryForInt(String sql)

(2)代码实例

// queryForInt返回一个整数

public static void test01() throws Exception {

// String sql = “SELECT COUNT(*) FROM user”;

String sql = “SELECT name FROM user WHERE id= ?”;

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

int forInt = jdbcTemplate.queryForInt(sql, 2);

}

4、JdbcTemplate查询-queryForLong返回一个long整数

(1)API简介

//执行查询语句,返回一个long类型的数据

public long queryForLong(String sql)

(2)代码实例

// queryForLong 返回一个long类型整数

public static void test02() throws Exception {

String sql = “SELECT COUNT(1) FROM user”;

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

long forLong = jdbcTemplate.queryForLong(sql);

}

5、JdbcTemplate查询-queryForObject返回String

(1)API简介

//执行查询语句,返回一个指定类型的数据

public T queryForObject(String sql, Class requiredType)

(2)代码实例

public static void test03() throws Exception {

String sql = “SELECT name FROM user WHERE id= ?”;

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

String str = jdbcTemplate.queryForObject(sql, 1, String.class);

}

6、JdbcTemplate查询-queryForMap返回一个Map集合

(1)API简介

//执行查询语句,将一条记录放到一个Map中

public Map<String, Object> queryForMap(String sql)

(2)代码实例

public static void test04() throws Exception {

String sql = "SELECT * FROM user WHERE id= ? ";

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

Map<String, Object> map = jdbcTemplate.queryForMap(sql, 1);

}

7、JdbcTemplate查询-queryForList返回一个List集合

(1)API简介

//执行查询语句,返回一个List集合,List中存放的是Map类型的数据

public List<Map<String, Object>> queryForList(String sql)

(2)代码实例

public static void test05() throws Exception {

String sql = “SELECT * FROM user WHERE id< ?”;

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

List<Map<String, Object>> list = jdbcTemplate.queryForList(sql, 10);

for (Map<String, Object> map : list) {

System.out.println(map);

}

}

8、JdbcTemplate查询-RowMapper返回自定义对象

(1)API简介

//执行查询语句,返回一个List集合,List中存放的是RowMapper指定类型的数据

public List query(String sql, RowMapper rowMapper)

(2)使用步骤

  1. 定义Product类

  2. 创建JdbcTemplate对象

  3. 编写查询的SQL语句

  4. 使用JdbcTemplate对象的query方法,并传入RowMapper匿名内部类

  5. 在匿名内部类中将结果集中的一行记录转成一个Product对象

(3)代码实例

// query使用rowMap做映射返回一个对象

public static void test06() throws Exception {

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

// 查询数据的SQL语句

String sql = “SELECT * FROM user”;

/**

  • 使用JdbcTemplate对象的query方法,并传入RowMapper匿名内部类

  • 在匿名内部类中将结果集中的一行记录转成一个User对象

*/

List list = jdbcTemplate.query(sql, new RowMapper() {

@Override

public Product mapRow(ResultSet arg0, int arg1) throws SQLException {

User user = new User();

user.setId(arg0.getInt(“id”));

user.setName(arg0.getString(“name”));

user.setAge(arg0.getInt(“age”));

return p;

}

});

for (User user : list) {

System.out.println(user);

}

}

9、JdbcTemplate查询-BeanPropertyRowMapper返回自定义对象

(1)API简介

//执行查询语句,返回一个List集合,List中存放的是RowMapper指定类型的数据

public List query(String sql, RowMapper rowMapper)

//BeanPropertyRowMapper类实现了RowMapper接口

public class BeanPropertyRowMapper implements RowMapper

(2)使用步骤

  1. 定义Product类

  2. 创建JdbcTemplate对象

  3. 编写查询的SQL语句

  4. 使用JdbcTemplate对象的query方法,并传入BeanPropertyRowMapper对象

(3)代码实例

// query使用BeanPropertyRowMapper做映射返回对象

public static void test07() throws Exception {

JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSourceUtils.getDataSource());

// 查询数据的SQL语句

String sql = “SELECT * FROM user”;

List list = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class));

for (User user : list) {

System.out.println(user);

}

}

10、批量插入

(1)API简介

//批量插入

jdbcTemplate.batchUpdate(String sql, List<Object[]> paramList);

(2)代码实例

String sql = “INSERT INTO login (user_name, pass_word) VALUES (?, ?)”;

List<Object[]> list = new ArrayList<>();

for (int i = 0; i < 10; i++) {

String[] arr = new String[3];

arr[0] = “username” + i;

arr[1] = “password” + i;

list.add(arr);

}

jdbcTemplate.batchUpdate(sql, list);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

小编在这里分享些我自己平时的学习资料,由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

程序员代码面试指南 IT名企算法与数据结构题目最优解

这是” 本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现。针对当前程序员面试缺乏权威题目汇总这一-痛点, 本书选取将近200道真实出现过的经典代码面试题,帮助广“大程序员的面试准备做到万无一失。 “刷”完本书后,你就是“题王”!

image.png

《TCP-IP协议组(第4版)》

本书是介绍TCP/IP协议族的经典图书的最新版本。本书自第1版出版以来,就广受读者欢迎。

本书最新版进行」护元,以体境计算机网络技不的最新发展,全书古有七大部分共30草和7个附录:第一部分介绍一些基本概念和基础底层技术:第二部分介绍网络层协议:第三部分介绍运输层协议;第四部分介绍应用层协议:第五部分介绍下一代协议,即IPv6协议:第六部分介绍网络安全问题:第七部分给出了7个附录。

image.png

Java开发手册(嵩山版)

这个不用多说了,阿里的开发手册,每次更新我都会看,这是8月初最新更新的**(嵩山版)**

image.png

MySQL 8从入门到精通

本书主要内容包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与还原、MySQL 日志、性能优化、MySQL Repl ication、MySQL Workbench、 MySQL Utilities、 MySQL Proxy、PHP操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。

image.png

Spring5高级编程(第5版)

本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。

本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。

image.png

JAVA核心知识点+1000道 互联网Java工程师面试题

image.png

image.png

企业IT架构转型之道 阿里巴巴中台战略思想与架构实战

本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。

image.png
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
ySQL Workbench、 MySQL Utilities、 MySQL Proxy、PHP操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。

[外链图片转存中…(img-aoANQSB0-1713536342195)]

Spring5高级编程(第5版)

本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。

本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。

[外链图片转存中…(img-Ll1hkj9u-1713536342198)]

JAVA核心知识点+1000道 互联网Java工程师面试题

[外链图片转存中…(img-EVrpa2qi-1713536342201)]

[外链图片转存中…(img-udqmwPfb-1713536342203)]

企业IT架构转型之道 阿里巴巴中台战略思想与架构实战

本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。

[外链图片转存中…(img-Gjsq7cWc-1713536342204)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 29
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值