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

文章详细介绍了如何在SpringBoot应用中配置Druid数据源的连接池参数,并结合MyBatis事务管理,展示了JdbcTemplate的使用方法,包括DDL操作、基础CRUD操作以及各种查询API的用法。
摘要由CSDN通过智能技术生成

@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的复习思路,收获美团,小米,京东等Java岗offer

更多笔记分享

秋招我借这份PDF的复习思路,收获美团,小米,京东等Java岗offer

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。[外链图片转存中…(img-6WsQIzCH-1713404376180)]

[外链图片转存中…(img-IQpKRBQP-1713404376181)]

[外链图片转存中…(img-z77OpVvZ-1713404376181)]

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

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

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

img

读者福利

[外链图片转存中…(img-lXwElRHm-1713404376182)]

更多笔记分享

[外链图片转存中…(img-Ng2OpoZe-1713404376182)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值