使用MongoDB+Jpa操做數據庫
SpringData還提供了對多種NoSQL數據庫的支持,包括MongoDB;neo4j和redis.他不只支持自動化的repository,還支持基於模板的數據訪問和映射註解.下面是一個Spring經過Jpa操做MongoDB數據庫的小Demo:java
數據的結構如圖所示:
相關代碼以下:
StuController:mysql
import com.demo.jpamongodb.dao.StudentRepository; import com.demo.jpamongodb.entity.Student; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.Optional; @RestController public class StuController { @Autowired private StudentRepository studentRepository; @RequestMapping("/getStuByName/{name}") public Optional<Student> getSchool1() { Optional<Student> stu = studentRepository.findById(1L); return stu; } }
SchoolReponsitoryweb
package com.demo.jpamongodb.dao; import com.demo.jpamongodb.entity.School; import org.springframework.data.mongodb.repository.MongoRepository; public interface SchoolReponsitory extends MongoRepository<School,Long> { School findSchoolByName(String name); }
StudentRepositoryredis
import com.demo.jpamongodb.entity.Student; import org.springframework.data.mongodb.repository.MongoRepository; public interface StudentRepository extends MongoRepository<Student, Long> { Student findByName(String name); }
Schoolspring
package com.demo.jpamongodb.entity; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.ToString; import org.springframework.data.annotation.Id; import org.springframework.data.mongodb.core.mapping.Document; import java.net.Proxy; @Document public class School { @Id private Long id; private String name; private String address; public School() { } public School(Long id, String name, String address) { this.id = id; this.name = name; this.address = address; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } @Override public String toString() { return "School{" + "id=" + id + ", name='" + name + '\'' + ", address='" + address + '\'' + '}'; } }
Studentsql
package com.demo.jpamongodb.entity; import lombok.AllArgsConstructor; import lombok.Data; import lombok.ToString; import org.springframework.data.annotation.Id; import org.springframework.data.mongodb.core.mapping.Document; //@AllArgsConstructor //@Data //@ToString @Document public class Student { @Id private Long id; private String name; private Integer age; private School shool; public Student() { } public Student(Long id, String name, Integer age, School shool) { this.id = id; this.name = name; this.age = age; this.shool = shool; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public School getShool() { return shool; } public void setShool(School shool) { this.shool = shool; } @Override public String toString() { return "Student{" + "id=" + id + ", name='" + name + '\'' + ", age=" + age + ", shool=" + shool + '}'; } }
application.propertiesmongodb
spring.data.mongodb.host=127.0.0.1 spring.data.mongodb.port=27017 spring.data.mongodb.database=test spring.data.mongodb.username=test spring.data.mongodb.password=123456 server.port=8787
JpaMongodbApplicationTests數據庫
package com.demo.jpamongodb; import com.demo.jpamongodb.dao.SchoolReponsitory; import com.demo.jpamongodb.dao.StudentRepository; import com.demo.jpamongodb.entity.School; import com.demo.jpamongodb.entity.Student; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; import java.util.List; @RunWith(SpringRunner.class) @SpringBootTest public class JpaMongodbApplicationTests { @Autowired private StudentRepository studentRepository; @Autowired private SchoolReponsitory schoolReponsitory; @Test public void contextLoads() { } /** * 第一次單元測試 * - student實體沒有加home屬性 * * @throws Exception */ @Test public void insertStudentWithoutHome() throws Exception { School school1 = schoolReponsitory.findSchoolByName("南京路中學"); School school2 = schoolReponsitory.findSchoolByName("北京路中學"); System.out.println(school1); System.out.println(school2); // schoolReponsitory.save(new School(1L,"南京路中學","南京路")); studentRepository.save(new Student(1L, "小明", 30,school1)); // studentRepository.save(new Student(2L, "小紅", 40,school1)); // studentRepository.save(new Student(3L, "小王", 50,school2)); } /** * 第二次單元測試 * - student實體加home屬性 * * @throws Exception */ @Test public void insertStudentWitHome() throws Exception { School school1 = schoolReponsitory.findSchoolByName("南京路中學"); School school2 = schoolReponsitory.findSchoolByName("北京路中學"); // studentRepository.save(new Student(4L, "tom", 30,school1,"1小區")); // studentRepository.save(new Student(5L, "peter", 40,school1,"2小區")); // studentRepository.save(new Student(6L, "joy", 50,school2,"3小區")); } /** * 對查詢結果打印 */ @Test public void findAll() { List<Student> students = studentRepository.findAll(); students.forEach(student -> { System.out.println(student); }); } // @Test // public void insertSchool(){ // School school1 = School.builder().address("南京路").name("南京路中學").id(1L).build(); // School school2 = School.builder().address("北京路").name("北京路中學").id(2L).build(); //new School(1L,"南京路中學","南京路"); // // schoolReponsitory.save(new School(1L,"南京路中學","南京路")); // schoolReponsitory.save(school2); // // School school = schoolReponsitory.findSchoolByName("南京路中學"); // System.out.println(school); // } }
pom.xml:apache
<?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>com.beacon</groupId> <artifactId>jpa-mongodb</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.3.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> <!--數據庫組件--> <!--<dependency>--> <!--<groupId>org.springframework.boot</groupId>--> <!--<artifactId>spring-boot-starter-data-jpa</artifactId>--> <!--</dependency>--> <!--數據庫組件--> <!--<dependency>--> <!--<groupId>mysql</groupId>--> <!--<artifactId>mysql-connector-java</artifactId>--> <!--</dependency>--> <!--<dependency>--> <!--<groupId>com.alibaba</groupId>--> <!--<artifactId>druid</artifactId>--> <!--<version>1.1.10</version>--> <!--</dependency>--> <!--//添加AOP--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> <!-- Spring boot 引用Thymeleaf模板依賴包(Thymeleaf模板若是不適用,這裏也能夠不添加這段配置,Thymeleaf模板使用在下面會講到) --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <!--mongodb--> <!--<dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver</artifactId> <version>3.6.4</version> </dependency>--> <!-- https://mvnrepository.com/artifact/org.mongodb/mongo-java-driver --> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-driver</artifactId> <version>3.8.0</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.16.22</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>