热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

springboot整合JDBC使用

上周回顾SpringBoot是什么?微服务HelloWorld~探究源码自动装配原理配置yaml多文档环境切换静态资源映射Thymeleafth:xxxSpringBoot如何扩

上周回顾


  • SpringBoot是什么?
  • 微服务
  • HelloWorld~
  • 探究源码
  • 自动装配原理
  • 配置yaml
  • 多文档环境切换静态资源映射
  • Thymeleaf th:xxx
  • SpringBoot如何扩展MVCjavaconfig
  • 如何修改SpringBoot的默认配置~
  • CRUD
  • 国际化
  • 拦截器
  • 定制首页,错误页~

这周


  • JDBC
  • Mybatis :重点
  • Druid :重点
  • Shiro :安全:重点
  • Spring Security :安全∶重点
  • 异步任务~,邮件发送,定时任务()
  • Swagger
  • Dubbo +Zookeeper

JDBCTemplate

1、有了数据源(com.zaxxer.hikari.HikariDataSource),然后可以拿到数据库连接(java.sql.Connection),有了连接,就可以使用原生的 JDBC 语句来操作数据库;

2、即使不使用第三方第数据库操作框架,如 MyBatis等,Spring 本身也对原生的JDBC 做了轻量级的封装,即JdbcTemplate。

3、数据库操作的所有 CRUD 方法都在 JdbcTemplate 中。

4、Spring Boot 不仅提供了默认的数据源,同时默认已经配置好了 JdbcTemplate 放在了容器中,程序员只需自己注入即可使用

5、JdbcTemplate 的自动配置是依赖 org.springframework.boot.autoconfigure.jdbc 包下的 JdbcTemplateConfiguration 类

JdbcTemplate主要提供以下几类方法:

方法作用
execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;
update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;
query方法及queryForXXX方法:用于执行查询相关语句;
用于执行查询相关语句:用于执行存储过程、函数相关语句。

代码实现

依赖

<dependency><groupId>org.springframework.bootgroupId><artifactId>spring-boot-starter-jdbcartifactId>dependency>

yaml配置文件

spring:datasource:username: rootpassword: 7777#假如时区报错就增加一个时区配置即可&#xff1a;serverTimezone&#61;UTC&#xff1a;表示当前时区url: jdbc:mysql://localhost:3306/rbac?serverTimezone&#61;UTC&userUnicode&#61;true&characterEncoding&#61;utf-8driver-class-name: com.mysql.cj.jdbc.Driver

JDBCController类&#xff1a;

/*** &#64;author acoffee* &#64;create 2021-08-09 21:25*/
&#64;RestController
public class JDBCController {//XXX Template&#xff1a;SpringBoot已经配置好模块bean&#xff0c;拿来即用 CRUD&#64;AutowiredJdbcTemplate jdbcTemplate;//查询数据库的所有信息//没有实体类&#xff0c;数据库中的东西&#xff0c;怎么获取&#xff1f; Map&#64;GetMapping("/userList")public List<Map<String,Object>> userList(){String sql &#61; "select * from sys_dept";List<Map<String, Object>> list_maps &#61; jdbcTemplate.queryForList(sql);return list_maps;}//添加功能&#64;GetMapping("/addUser")public String addUser(){String sql &#61; "insert into rbac.sys_dept (id,dname) values (8,&#39;税务部&#39;)";jdbcTemplate.update(sql);return "update-ok";}//修改功能&#64;GetMapping("/updateUser/{id}")public String updateUser(&#64;PathVariable("id") int id){String sql &#61; "update rbac.sys_dept set dname&#61;? where id&#61;"&#43;id;//封装String str &#61; "运动部";jdbcTemplate.update(sql,str);return "updateUser-ok";}//删除功能&#64;GetMapping("/deleteUser/{id}")public String deleteUser(&#64;PathVariable("id") int id){String sql &#61; "delete from rbac.sys_dept where id &#61; "&#43;id;jdbcTemplate.update(sql);return "deleteUser-ok";}
}

测试类&#xff1a;

&#64;SpringBootTest
class Springboot05DataApplicationTests {//springboot数据库自动配置类&#64;AutowiredDataSource dataSource;&#64;Testvoid contextLoads() throws SQLException {//查看一下默认的数据源System.out.println(dataSource.getClass());//获得数据库的连接Connection connection &#61; dataSource.getConnection();System.out.println(connection);connection.close();}
}

数据库表&#xff1a;
在这里插入图片描述
执行结果&#xff1a;

查询&#xff1a;
在这里插入图片描述

增加&#xff1a;
在这里插入图片描述
在这里插入图片描述
修改&#xff1a;
在这里插入图片描述
在这里插入图片描述
删除&#xff1a;
在这里插入图片描述
在这里插入图片描述
即完成了springboot去整合JDBC去操作数据库


推荐阅读
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 您的数据库配置是否安全?DBSAT工具助您一臂之力!
    本文探讨了Oracle提供的免费工具DBSAT,该工具能够有效协助用户检测和优化数据库配置的安全性。通过全面的分析和报告,DBSAT帮助用户识别潜在的安全漏洞,并提供针对性的改进建议,确保数据库系统的稳定性和安全性。 ... [详细]
  • 本文深入解析了WCF Binding模型中的绑定元素,详细介绍了信道、信道管理器、信道监听器和信道工厂的概念与作用。从对象创建的角度来看,信道管理器负责信道的生成。具体而言,客户端的信道通过信道工厂进行实例化,而服务端则通过信道监听器来接收请求。文章还探讨了这些组件之间的交互机制及其在WCF通信中的重要性。 ... [详细]
  • ### 优化后的摘要本学习指南旨在帮助读者全面掌握 Bootstrap 前端框架的核心知识点与实战技巧。内容涵盖基础入门、核心功能和高级应用。第一章通过一个简单的“Hello World”示例,介绍 Bootstrap 的基本用法和快速上手方法。第二章深入探讨 Bootstrap 与 JSP 集成的细节,揭示两者结合的优势和应用场景。第三章则进一步讲解 Bootstrap 的高级特性,如响应式设计和组件定制,为开发者提供全方位的技术支持。 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • 在Linux系统中,网络配置是至关重要的任务之一。本文详细解析了Firewalld和Netfilter机制,并探讨了iptables的应用。通过使用`ip addr show`命令来查看网卡IP地址(需要安装`iproute`包),当网卡未分配IP地址或处于关闭状态时,可以通过`ip link set`命令进行配置和激活。此外,文章还介绍了如何利用Firewalld和iptables实现网络流量控制和安全策略管理,为系统管理员提供了实用的操作指南。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • poj 3352 Road Construction ... [详细]
  • 本文总结了一些开发中常见的问题及其解决方案,包括特性过滤器的使用、NuGet程序集版本冲突、线程存储、溢出检查、ThreadPool的最大线程数设置、Redis使用中的问题以及Task.Result和Task.GetAwaiter().GetResult()的区别。 ... [详细]
  • 在JavaWeb开发中,文件上传是一个常见的需求。无论是通过表单还是其他方式上传文件,都必须使用POST请求。前端部分通常采用HTML表单来实现文件选择和提交功能。后端则利用Apache Commons FileUpload库来处理上传的文件,该库提供了强大的文件解析和存储能力,能够高效地处理各种文件类型。此外,为了提高系统的安全性和稳定性,还需要对上传文件的大小、格式等进行严格的校验和限制。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 阿里巴巴终面技术挑战:如何利用 UDP 实现 TCP 功能?
    在阿里巴巴的技术面试中,技术总监曾提出一道关于如何利用 UDP 实现 TCP 功能的问题。当时回答得不够理想,因此事后进行了详细总结。通过与总监的进一步交流,了解到这是一道常见的阿里面试题。面试官的主要目的是考察应聘者对 UDP 和 TCP 在原理上的差异的理解,以及如何通过 UDP 实现类似 TCP 的可靠传输机制。 ... [详细]
  • 在对WordPress Duplicator插件0.4.4版本的安全评估中,发现其存在跨站脚本(XSS)攻击漏洞。此漏洞可能被利用进行恶意操作,建议用户及时更新至最新版本以确保系统安全。测试方法仅限于安全研究和教学目的,使用时需自行承担风险。漏洞编号:HTB23162。 ... [详细]
  • 本文介绍了如何利用Struts1框架构建一个简易的四则运算计算器。通过采用DispatchAction来处理不同类型的计算请求,并使用动态Form来优化开发流程,确保代码的简洁性和可维护性。同时,系统提供了用户友好的错误提示,以增强用户体验。 ... [详细]
  • 为了在Hadoop 2.7.2中实现对Snappy压缩和解压功能的原生支持,本文详细介绍了如何重新编译Hadoop源代码,并优化其Native编译过程。通过这一优化,可以显著提升数据处理的效率和性能。此外,还探讨了编译过程中可能遇到的问题及其解决方案,为用户提供了一套完整的操作指南。 ... [详细]
author-avatar
手机用户2602913827
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有