springboot使用JdbcTemplate完成对数据库的增删改查功能

 更新时间:2022年05月20日 10:36:42   作者:阿木侠  
这篇文章主要介绍了springboot使用JdbcTemplate完成对数据库的增删改查功能,需要的朋友可以参考下

首先新建一个简单的数据表,通过操作这个数据表来进行演示

DROP TABLE IF EXISTS `items`; 
CREATE TABLE `items` ( 
 `id` int(11) NOT NULL AUTO_INCREMENT, 
 `title` varchar(255) DEFAULT NULL, 
 `name` varchar(10) DEFAULT NULL, 
 `detail` varchar(255) DEFAULT NULL, 
 PRIMARY KEY (`id`) 
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8; 

引入JdbcTemplate的maven依赖及连接类

<dependency> 
 <groupId>org.springframework.boot</groupId> 
 <artifactId>spring-boot-starter-jdbc</artifactId> 
</dependency> 
<dependency> 
 <groupId>mysql</groupId> 
 <artifactId>mysql-connector-java</artifactId> 
 <scope>runtime</scope> 
</dependency> 

在application.properties文件配置mysql的驱动类,数据库地址,数据库账号、密码信息,application.properties新建在src/main/resource文件夹下

spring.datasource.url=jdbc:mysql://127.0.0.1:3306/spring?useSSL=false 
spring.datasource.username=root 
spring.datasource.password=123456 
spring.datasource.driver-class-name=com.mysql.jdbc.Driver 
spring.datasource.max-idle=10 
spring.datasource.max-wait=10000 
spring.datasource.min-idle=5 
spring.datasource.initial-size=5 
server.port=8080 
server.session.timeout=10 
server.tomcat.uri-encoding=UTF-8 

新建一个实体类,属性对应sql字段

package org.amuxia.start; 
public class Items { 
 private Integer id; 
 private String title; 
 private String name; 
 private String detail; 
 public Integer getId() { 
  return id; 
 } 
 public void setId(Integer id) { 
  this.id = id; 
 } 
 public String getTitle() { 
  return title; 
 } 
 public void setTitle(String title) { 
  this.title = title; 
 } 
 public String getName() { 
  return name; 
 } 
 public void setName(String name) { 
  this.name = name; 
 } 
 public String getDetail() { 
  return detail; 
 } 
 public void setDetail(String detail) { 
  this.detail = detail; 
 } 
 public Items() { 
  super(); 
  // TODO Auto-generated constructor stub 
 } 
 public Items(Integer id, String title, String name, String detail) { 
  super(); 
  this.id = id; 
  this.title = title; 
  this.name = name; 
  this.detail = detail; 
 } 
 @Override 
 public String toString() { 
  return "Items [id=" + id + ", title=" + title + ", name=" + name + ", detail=" + detail + "]"; 
 } 
} 

新增操作

/** 
  * 新增数据 
  * @param items 
  * @return 
  */ 
 @RequestMapping("/add") 
 public @ResponseBody String addItems(Items items) { 
  String sql = "insert into items (id,title,name,detail) value (?,?,?,?)"; 
  Object args[] = {items.getId(),items.getTitle(),items.getName(),items.getDetail()}; 
  int temp = jdbcTemplate.update(sql, args); 
  if(temp > 0) { 
   return "文章新增成功"; 
  } 
  return "新增出现错误"; 
 } 

我们做一个测试。在postman测试工具中输入http://localhost:8080/items/add

我们可以看到,新增已经成功了,确实很方便,也没有繁琐的配置信息。

其余删除,更新操作与新增代码不变,只是sql的变化,这里不做演示。

全部查询操作

/** 
  * @return 
  * 查询全部信息 
  */ 
 @RequestMapping("/list") 
 public List<Map<String, Object>> itemsList() { 
  String sql = "select * from items"; 
  List<Map<String, Object>> list = jdbcTemplate.queryForList(sql); 
  return list; 
 } 

我们做一个测试。在postman测试工具中输入http://localhost:8080/items/list

我们看到,包括刚才新增的数据,都已经被查出来了。

这里为了学习一下springboot的JdbcTemplate操作,所有增删改查代码都写在ItemsController类中,也方便演示,这里把代码贴出来,需要的可以运行一下

package org.amuxia.start; 
import java.util.List; 
import java.util.Map; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.context.annotation.ComponentScan; 
import org.springframework.jdbc.core.JdbcTemplate; 
import org.springframework.web.bind.annotation.PathVariable; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.ResponseBody; 
import org.springframework.web.bind.annotation.RestController; 
@ComponentScan 
@RestController 
@RequestMapping("/items") 
public class ItemsController { 
 @Autowired 
 private JdbcTemplate jdbcTemplate; 
 /** 
  * @return 
  * 查询全部信息 
  */ 
 @RequestMapping("/list") 
 public List<Map<String, Object>> itemsList() { 
  String sql = "select * from items"; 
  List<Map<String, Object>> list = jdbcTemplate.queryForList(sql); 
  return list; 
 } 
 /** 
  * @param id 
  * @return 
  * 根据ID查询单条信息 
  */ 
 @RequestMapping("/detail/{id}") 
 public Map<String, Object> detail(@PathVariable int id) { 
  Map<String, Object> map = null; 
  List<Map<String, Object>> list = itemsList(); 
  map = list.get(id); 
  return map; 
 } 
 /** 
  * 新增数据 
  * @param items 
  * @return 
  */ 
 @RequestMapping("/add") 
 public @ResponseBody String addItems(Items items) { 
  String sql = "insert into items (id,title,name,detail) value (?,?,?,?)"; 
  Object args[] = {items.getId(),items.getTitle(),items.getName(),items.getDetail()}; 
  int temp = jdbcTemplate.update(sql, args); 
  if(temp > 0) { 
   return "文章新增成功"; 
  } 
  return "新增出现错误"; 
 } 
 /** 
  * @param items 
  * @return 
  * 删除数据 
  */ 
 @RequestMapping("/del") 
 public @ResponseBody String delItems(Items items) { 
  String sql = "delete from items where id = ?"; 
  Object args[] = {items.getId()}; 
  int temp = jdbcTemplate.update(sql, args); 
  if(temp > 0) { 
   return "文章删除成功"; 
  } 
  return "删除出现错误"; 
 } 
 /** 
  * @param items 
  * @return 
  * 更新操作 
  */ 
 @RequestMapping("/upd") 
 public @ResponseBody String updItems(Items items) { 
  String sql = "update items set title = ?,detail = ? where id = ?"; 
  Object args[] = {items.getTitle(),items.getDetail(),items.getId()}; 
  int temp = jdbcTemplate.update(sql, args); 
  if(temp > 0) { 
   return "文章修改成功"; 
  } 
  return "修改出现错误"; 
 } 
} 

这里解释一个注解

@ComponentScan:

        @ComponentScan告诉Spring 哪个注解标识的类会被spring自动扫描并且装入bean容器。如果你有个类用@Controller注解标识了,那么,如果不加上@ComponentScan自动扫描该controller,那么该Controller就不会被spring扫描到,更不会装入spring容器中,Controller就不会起作用。

启动类代码

package org.amuxia.start; 
import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.EnableAutoConfiguration; 
import org.springframework.web.bind.annotation.RestController; 
@RestController 
@EnableAutoConfiguration 
public class App 
{ 
 public static void main( String[] args ) 
 { 
  System.out.println( "start....." ); 
  SpringApplication.run(ItemsController.class, args); 
 } 
} 

总结

以上所述是小编给大家介绍的springboot使用JdbcTemplate完成对数据库的增删改查功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • java版十大排序经典算法:完整代码

    java版十大排序经典算法:完整代码

    优秀的文章也不少,但是Java完整版的好像不多,我把所有的写一遍巩固下,同时也真诚的希望阅读到这篇文章的小伙伴们可以自己去从头敲一遍,不要粘贴复制!希望我的文章对你有所帮助,每天进步一点点
    2021-07-07
  • 基于SpringBoot bootstrap.yml配置未生效的解决

    基于SpringBoot bootstrap.yml配置未生效的解决

    这篇文章主要介绍了基于SpringBoot bootstrap.yml配置未生效的解决方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-10-10
  • idea中断点类型之All和Thread的区别介绍

    idea中断点类型之All和Thread的区别介绍

    使用all模式对于程序中含有多个线程来说,会将多个线程都阻塞在断点,此时所有的线程都执行到此处,在最后一个线程执行到此处是会发生暂停,在这之前的线程会继续执行到任意位置,本文给大家详细介绍下idea中断点类型之All和Thread的区别,感兴趣的朋友一起看看吧
    2022-03-03
  • python中jieba库(中文分词库)使用安装教程

    python中jieba库(中文分词库)使用安装教程

    这篇文章主要介绍了python中jieba库(中文分词库)使用安装教程,jieba库是通过中文词库的方式来识别分词的。它首先利用一个中文词库,通过词库计算汉字之间构成词语的关联概率,所以通过计算汉字之间的概率,就可以形成分词的结果,需要的朋友可以参考下
    2023-04-04
  • java学习之路_篇超好的文章

    java学习之路_篇超好的文章

    一篇超好的文章!就看你有没耐心看!java学习之路!
    2008-10-10
  • Spring运行时动态注册bean的方法

    Spring运行时动态注册bean的方法

    这篇文章主要介绍了Spring运行时动态注册bean的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • SpringBoot整合Thymeleaf的方法

    SpringBoot整合Thymeleaf的方法

    这篇文章主要介绍了SpringBoot整合Thymeleaf的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • SpringBoot中使用@ControllerAdvice注解详解

    SpringBoot中使用@ControllerAdvice注解详解

    这篇文章主要介绍了SpringBoot中使用@ControllerAdvice注解详解,@ControllerAdvice,是Spring3.2提供的新注解,它是一个Controller增强器,可对controller中被 @RequestMapping注解的方法加一些逻辑处理,需要的朋友可以参考下
    2023-10-10
  • 阿里巴巴 Sentinel + InfluxDB + Chronograf 实现监控大屏

    阿里巴巴 Sentinel + InfluxDB + Chronograf 实现监控大屏

    这篇文章主要介绍了阿里巴巴 Sentinel + InfluxDB + Chronograf 实现监控大屏,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • SpringBoot使用过滤器、拦截器和监听器的案例代码(Springboot搭建java项目)

    SpringBoot使用过滤器、拦截器和监听器的案例代码(Springboot搭建java项目)

    这篇文章主要介绍了SpringBoot使用过滤器、拦截器和监听器(Springboot搭建java项目),本文是基于Springboot搭建java项目,结合案例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-02-02

最新评论