SpringBoot实战(四)之使用JDBC和Spring访问数据库
这里演示的是h2databse示例,所以简单的介绍普及下h2database相关知识 H2数据库是一个开源的关系型数据库。 H2是一个嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时H2提供了一个十分方便的web控制台用于操作和管理数据库内容。它还提供兼容模式,可以兼容一些主流的数据库,因此采用H2作为开发期的数据库非常方便。 H2数据库特点:
? ? 这里说下JdbcTemplate,之所以会出现JdbcTemplate,我个人加上我自己的一些想法,传统的JDBC的高耦合性和许多重复性增删改查,使得JDBC的升级版诞生,这一点与MyBatis Plus有共同的特点。而JDBCTemplate正是看到这一点后,对于JDBC进行升级。 关于JDBCTemplate示例,大家可以参考这位朋友写的示例:https://www.cnblogs.com/janes/p/6971839.html ? 下面引用下他的关于JdbcTemplate的介绍: JdbcTemplate是最基本的Spring JDBC模板,这个模板支持简单的JDBC数据库访问功能以及基于索引参数的查询。 Spring数据访问模板:在数据库操作过程中,有很大一部分重复工作,比如事务控制、管理资源以及处理异常等,Spring的模板类处理这些固定部分。同时,应用程序相关的数据访问在回调的实现中处理,包括语句、绑定参数以及整理结果等。这样一来,我们只需关心自己的数据访问逻辑即可。 Spring的JDBC框架承担了资源管理和异常处理的工作,从而简化了JDBC代码,我们只需要编写从数据库读写数据的必需代码就万事大吉了。 ? 一、导入依赖 <?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.springframework</groupId>
<artifactId>gs-relational-data-access</artifactId>
<version>0.1.0</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.8.RELEASE</version>
</parent>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
? ? 二、编写实体 Customer.java package hello; public class Customer { private long id; private String firstName,lastName; public Customer( id,String firstName,String lastName) { this.id = id; this.firstName = firstName; this.lastName = lastName; } @Override public String toString() { return String.format( "Customer[id=%d,firstName='%s',lastName='%s']",id,firstName,lastName); } getId() { id; } void setId( id) { String getFirstName() { firstName; } void setFirstName(String firstName) { String getLastName() { lastName; } setLastName(String lastName) { lastName; } } ? ? ? ? 三、编写启动类 import org.slf4j.Logger; org.slf4j.LoggerFactory; org.springframework.beans.factory.annotation.Autowired; org.springframework.boot.CommandLineRunner; org.springframework.boot.SpringApplication; org.springframework.boot.autoconfigure.SpringBootApplication; org.springframework.jdbc.core.JdbcTemplate; java.util.Arrays; java.util.List; java.util.stream.Collectors; @SpringBootApplication class Application implements CommandLineRunner { static final Logger log = LoggerFactory.getLogger(Application.); main(String args[]) { SpringApplication.run(Application.void run(String... strings) throws Exception { log.info("Creating tables"); jdbcTemplate.execute("DROP TABLE customers IF EXISTS"); jdbcTemplate.execute("CREATE TABLE customers(" + "id SERIAL,first_name VARCHAR(255),last_name VARCHAR(255))"); // Split up the array of whole names into an array of first/last names List<Object[]> splitUpNames = Arrays.asList("John Woo","Jeff Dean","Josh Bloch","Josh Long").stream() .map(name -> name.split(" ")) .collect(Collectors.toList()); Use a Java 8 stream to print out each tuple of the list splitUpNames.forEach(name -> log.info(String.format("Inserting customer record for %s %s",name[0],name[1]))); Uses JdbcTemplate's batchUpdate operation to bulk load data jdbcTemplate.batchUpdate("INSERT INTO customers(first_name,last_name) VALUES (?,?)"); jdbcTemplate.query( "SELECT id,first_name,last_name FROM customers WHERE first_name = ?",new Object[] { "Josh" },(rs,rowNum) -> new Customer(rs.getLong("id"),rs.getString("first_name"),rs.getString("last_name")) ).forEach(customer -> log.info(customer.toString())); } } ? 最终结果是: ? 该 Spring Boot支持H2,一种内存中的关系数据库引擎,并自动创建连接。因为我们使用的是spring-jdbc,Spring Boot会自动创建一个 这个 首先,使用 其次,您获取字符串列表并使用Java 8流,将它们拆分为Java数组中的firstname / lastname对。 然后使用 ? 补充说明: Java 8 lambdas很好地映射到单个方法接口,如Spring的 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |