SpringBoot使用JdbcTemplate訪問操作數(shù)據(jù)庫基本用法
Spring對(duì)數(shù)據(jù)庫的操作在jdbc上s面做了深層次的封裝,使用spring的注入功能,可以把DataSource注冊(cè)到JdbcTemplate之中。
JdbcTemplate在Spring-jdbc包下面,還需要Spring-tx包支持,里面包含事務(wù)和異??刂?
一、建一個(gè)rumenz_springboot庫
創(chuàng)建user表:
create table user( ? id int primary key auto_increment, ? name varchar(100) not null default '', ? domain varchar(100) not null default '' )engine=innodb default charset=utf8;
二、加入pom的依賴
<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>
三、SpringBoot配置文件
application.properties
spring.datasource.url=jdbc:mysql://localhost:3306/rumenz_springboot spring.datasource.username=root spring.datasource.password=root1234 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
四、創(chuàng)建User實(shí)體類
@Builder
@Data
@AllArgsConstructor
public class User ?implements RowMapper {
? ? private Integer id;
? ? private String name;
? ? private String domain;
? ? @Override
? ? public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
? ? ? ? User user=new User();
? ? ? ? user.setId(rs.getInt("id"));
? ? ? ? user.setName(rs.getString("name"));
? ? ? ? user.setDomain(rs.getString("domain"));
? ? ? ? return user;
? ? }
}五、Service接口
UserService.java
package com.rumenz.lession14.controller.service;
import com.rumenz.lession14.controller.entity.User;
import java.util.List;
/**
?* @className: UserService
?* @description: TODO 類描述
?* @author: 入門小站 rumenz.com
?* @date: 2021/12/13
?**/
public interface UserService {
? ? Integer save(User user);
? ? List<User> list();
? ? Integer update(User user);
? ? Integer batchSave();
}六、Service接口實(shí)現(xiàn)類
UserServiceImpl.java
package com.rumenz.lession14.controller.service.Impl;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.json.JsonMapper;
import com.rumenz.lession14.controller.entity.User;
import com.rumenz.lession14.controller.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
import java.util.List;
/**
?* @className: UserServiceImpl
?* @description: TODO 類描述
?* @author: 入門小站 rumenz.com
?* @date: 2021/12/13
?**/
@Service
public class UserServiceImpl implements UserService {
? ? @Autowired
? ? private JdbcTemplate jdbcTemplate;
? ? @Override
? ? public Integer save(User user) {
? ? ? ? int reint = jdbcTemplate.update("insert into user(name,domain) values (?,?)", user.getName(), user.getDomain());
? ? ? ? return reint;
? ? }
? ? @Override
? ? public Integer batchSave() {
? ? ? ? String sql="insert into user(name,domain) values(?,?)";
? ? ? ? List<Object[]> par=new ArrayList<>();
? ? ? ? for (int i = 0; i < 10; i++) {
? ? ? ? ? ? String[] s=new String[2];
? ? ? ? ? ? s[0]="入門小站"+i;
? ? ? ? ? ? s[1]="https://rumenz.com/"+i;
? ? ? ? ? ? par.add(s);
? ? ? ? }
? ? ? ? int[] ints = jdbcTemplate.batchUpdate(sql, par);
? ? ? ? System.out.println(ints.toString());
? ? ? ? return 0;
? ? }
? ? @Override
? ? public List<User> list() {
? ? ? ? //User實(shí)現(xiàn)RowMapper接口,實(shí)現(xiàn)接口里的mapRow方法。
? ? ? ? List<User> list = jdbcTemplate.query("select * from user",new User());
? ? ? ? return list;
? ? }
? ? @Override
? ? public Integer update(User user) {
? ? ? ? Integer reint=jdbcTemplate.update("update user set name=?,domain=? where id=?", user.getName(),user.getDomain(),user.getId());
? ? ? ? //
? ? ? ? return reint;
? ? }
}七、Controller測(cè)試
RumenzController.java
package com.rumenz.lession14.controller;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.rumenz.lession14.controller.entity.User;
import com.rumenz.lession14.controller.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
/**
?* @className: RumenzController
?* @description: TODO 類描述
?* @author: 入門小站 rumenz.com
?* @date: 2021/12/13
?**/
@RestController
@RequestMapping("/rumenz")
public class RumenzController {
? ? @Autowired
? ? private UserService userService;
? ? //添加數(shù)據(jù)
? ? @GetMapping("/save")
? ? public String save(){
? ? ? ? User user=User.builder().name("入門小站").domain("https://rumenz.com").build();
? ? ? ? Integer reint = userService.save(user);
? ? ? ? return reint.toString();
? ? }
? ? //批量添加數(shù)據(jù)
? ? @GetMapping("/batchSave")
? ? public String batchSave(){
? ? ? ? Integer reint = userService.batchSave();
? ? ? ? return reint.toString();
? ? }
? ? //查詢數(shù)據(jù)
? ? @GetMapping("/list")
? ? public String list() throws JsonProcessingException {
? ? ? ? List<User> list = userService.list();
? ? ? ? ObjectMapper objectMapper=new ObjectMapper();
? ? ? ? String val = objectMapper.writeValueAsString(list);
? ? ? ? return val;
? ? }
? ? //更新數(shù)據(jù)
? ? @GetMapping("/update")
? ? public String update() throws JsonProcessingException {
? ? ? ? User user=User.builder().id(1).name("入門小站-修改").domain("https://tooltt.com").build();
? ? ? ? Integer reint = userService.update(user);
? ? ? ? return reint.toString();
? ? }
}八、總結(jié)
常用CURD操作大致使用以下三個(gè)方法:
- 1.execute方法,用于直接執(zhí)行SQL語句
- 2.update方法,用戶新增修改刪除操作
- 3.query方法,用于查詢方法
到此這篇關(guān)于SpringBoot使用JdbcTemplate訪問操作數(shù)據(jù)庫基本用法的文章就介紹到這了,更多相關(guān)SpringBoot使用JdbcTemplate訪問操作數(shù)據(jù)庫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringMVC結(jié)合ajaxfileupload.js實(shí)現(xiàn)文件無刷新上傳
這篇文章主要介紹了SpringMVC結(jié)合ajaxfileupload.js實(shí)現(xiàn)文件無刷新上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
解決Spring boot 嵌入的tomcat不啟動(dòng)問題
這篇文章主要介紹了解決Spring boot 嵌入的tomcat不啟動(dòng)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10
Netty分布式ByteBuf使用SocketChannel讀取數(shù)據(jù)過程剖析
這篇文章主要為大家介紹了Netty源碼分析ByteBuf使用SocketChannel讀取數(shù)據(jù)過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03
自己動(dòng)手寫一個(gè)java版簡(jiǎn)單云相冊(cè)
這篇文章主要為大家分享了自己動(dòng)手寫的一個(gè)java版簡(jiǎn)單云相冊(cè),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07
java使用Jsoup連接網(wǎng)站超時(shí)的解決方法
jsoup是一個(gè)非常好的解析網(wǎng)頁的包,用java開發(fā)的,提供了類似DOM,CSS選擇器的方式來查找和提取文檔中的內(nèi)容,提取文檔內(nèi)容時(shí)會(huì)出現(xiàn)超時(shí)的情況,解決方法可看下文2013-11-11
Spring-cloud-eureka使用feign調(diào)用服務(wù)接口
這篇文章主要為大家詳細(xì)介紹了Spring-cloud-eureka使用feign調(diào)用服務(wù)接口,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04

