首先新建一個(gè)簡(jiǎn)單的數(shù)據(jù)表,通過操作這個(gè)數(shù)據(jù)表來進(jìn)行演示
成都創(chuàng)新互聯(lián)主營(yíng)上栗網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶App定制開發(fā),上栗h5微信平臺(tái)小程序開發(fā)搭建,上栗網(wǎng)站營(yíng)銷推廣歡迎上栗等地區(qū)企業(yè)咨詢
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依賴及連接類
org.springframework.boot spring-boot-starter-jdbc MySQL mysql-connector-java runtime
在application.properties文件配置mysql的驅(qū)動(dòng)類,數(shù)據(jù)庫地址,數(shù)據(jù)庫賬號(hào)、密碼信息,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
新建一個(gè)實(shí)體類,屬性對(duì)應(yīng)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 + "]"; } }
新增操作
/** * 新增數(shù)據(jù) * @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 "新增出現(xiàn)錯(cuò)誤"; }
我們做一個(gè)測(cè)試。在postman測(cè)試工具中輸入http://localhost:8080/items/add
我們可以看到,新增已經(jīng)成功了,確實(shí)很方便,也沒有繁瑣的配置信息。
其余刪除,更新操作與新增代碼不變,只是sql的變化,這里不做演示。
全部查詢操作
/** * @return * 查詢?nèi)啃畔? */ @RequestMapping("/list") public List
我們做一個(gè)測(cè)試。在postman測(cè)試工具中輸入http://localhost:8080/items/list
我們看到,包括剛才新增的數(shù)據(jù),都已經(jīng)被查出來了。
這里為了學(xué)習(xí)一下springboot的JdbcTemplate操作,所有增刪改查代碼都寫在ItemsController類中,也方便演示,這里把代碼貼出來,需要的可以運(yùn)行一下
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 * 查詢?nèi)啃畔? */ @RequestMapping("/list") public List> itemsList() { String sql = "select * from items"; List > list = jdbcTemplate.queryForList(sql); return list; } /** * @param id * @return * 根據(jù)ID查詢單條信息 */ @RequestMapping("/detail/{id}") public Map detail(@PathVariable int id) { Map map = null; List > list = itemsList(); map = list.get(id); return map; } /** * 新增數(shù)據(jù) * @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 "新增出現(xiàn)錯(cuò)誤"; } /** * @param items * @return * 刪除數(shù)據(jù) */ @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 "刪除出現(xiàn)錯(cuò)誤"; } /** * @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 "修改出現(xiàn)錯(cuò)誤"; } }
這里解釋一個(gè)注解
@ComponentScan:
@ComponentScan告訴Spring 哪個(gè)注解標(biāo)識(shí)的類會(huì)被spring自動(dòng)掃描并且裝入bean容器。如果你有個(gè)類用@Controller注解標(biāo)識(shí)了,那么,如果不加上@ComponentScan自動(dòng)掃描該controller,那么該Controller就不會(huì)被spring掃描到,更不會(huì)裝入spring容器中,Controller就不會(huì)起作用。
啟動(dòng)類代碼
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); } }
總結(jié)
以上所述是小編給大家介紹的springboot使用JdbcTemplate完成對(duì)數(shù)據(jù)庫的增刪改查功能,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)創(chuàng)新互聯(lián)網(wǎng)站的支持!