Skip to content

Commit ec44ea5

Browse files
author
liuzidong
committed
FIX Mongo Reactive
1 parent 93f458f commit ec44ea5

File tree

10 files changed

+62
-35
lines changed

10 files changed

+62
-35
lines changed

Chapter10/README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
#### Mongo Reactive

Chapter10/pom.xml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@
99
<parent>
1010
<groupId>org.springframework.boot</groupId>
1111
<artifactId>spring-boot-starter-parent</artifactId>
12-
<version>2.0.5.RELEASE</version>
12+
<version>2.1.4.RELEASE</version>
1313
</parent>
1414

1515
<properties>

Chapter10/src/main/java/net/liuzd/spring/boot/v2/domain/Person.java

Lines changed: 9 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -3,16 +3,20 @@
33
import org.springframework.data.annotation.Id;
44
import org.springframework.data.mongodb.core.mapping.Document;
55

6+
import lombok.AllArgsConstructor;
67
import lombok.Data;
8+
import lombok.NoArgsConstructor;
79

810
@Data
9-
@Document
11+
@AllArgsConstructor
12+
@NoArgsConstructor
13+
@Document(collection = "person")
1014
public class Person {
1115

12-
private @Id String id;
13-
private final String firstname;
14-
private final String lastname;
15-
private final int age;
16+
private @Id String id;
17+
private String firstname;
18+
private String lastname;
19+
private int age;
1620

1721
public Person(String firstname, String lastname, int age) {
1822
super();

Chapter10/src/main/java/net/liuzd/spring/boot/v2/repository/ReactivePersonRepository.java

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,8 @@
1212
*
1313
* @author Mark Paluch
1414
*/
15-
public interface ReactivePersonRepository extends ReactiveCrudRepository<Person, String> {
15+
public interface ReactivePersonRepository extends ReactiveCrudRepository<Person, String> {
16+
1617

1718
/**
1819
* Derived query selecting by {@code lastname}.

Chapter10/src/main/java/net/liuzd/spring/boot/v2/repository/RxJava2PersonRepository.java

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -8,12 +8,7 @@
88
import io.reactivex.Single;
99
import net.liuzd.spring.boot.v2.domain.Person;
1010

11-
/**
12-
* Repository interface to manage {@link Person} instances.
13-
*
14-
* @author Mark Paluch
15-
* @author Christoph Strobl
16-
*/
11+
1712
public interface RxJava2PersonRepository extends RxJava2CrudRepository<Person, String> {
1813

1914
/**

Chapter10/src/main/java/net/liuzd/spring/boot/v2/repository/UserRepository.java

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -3,13 +3,13 @@
33

44
import org.springframework.data.domain.Page;
55
import org.springframework.data.domain.Pageable;
6+
import org.springframework.data.mongodb.repository.MongoRepository;
67
import org.springframework.data.mongodb.repository.Query;
7-
import org.springframework.data.repository.CrudRepository;
88

99
import net.liuzd.spring.boot.v2.domain.User;
1010

1111
//Repository
12-
public interface UserRepository extends CrudRepository<User, Long> {
12+
public interface UserRepository extends MongoRepository<User, Long> {
1313

1414
/**
1515
* Like(模糊查询)

Chapter10/src/main/resources/application.properties

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ spring.application.name=spring-boot-mongodb
22
#
33
spring.data.mongodb.host=127.0.0.1
44
spring.data.mongodb.port=27017
5-
#spring.data.mongodb.authentication-database=admin
5+
spring.data.mongodb.authentication-database=admin
66
spring.data.mongodb.database=admin
77
#
88
spring.data.mongodb.username=admin

Chapter10/src/test/java/net/liuzd/spring/boot/v2/ReactivePersonRepositoryTest.java

Lines changed: 16 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,9 @@
11
package net.liuzd.spring.boot.v2;
22

3+
import java.util.ArrayList;
4+
import java.util.List;
5+
6+
import org.junit.Before;
37
import org.junit.Test;
48
import org.junit.runner.RunWith;
59
import org.slf4j.Logger;
@@ -22,14 +26,24 @@ public class ReactivePersonRepositoryTest {
2226
@Autowired
2327
private ReactivePersonRepository reactivePersonRepository;
2428

29+
@Before
30+
public void before() {
31+
reactivePersonRepository.deleteAll();
32+
}
33+
2534
@Test
2635
public void testAdd() throws Exception {
2736
// ReactiveMongoTemplate t = null;
2837
// 创建多个User,并验证User总数
2938
int size = 20;
30-
for (int i = 0; i < size; i++) {
31-
reactivePersonRepository.save(new Person("liu" + i, "felix" + i, 22 + i));
39+
List<Person> pps = new ArrayList<>();
40+
for (int i = 1; i <= size; i++) {
41+
Person p = new Person("liu" + i, "felix" + i, 22 + i);
42+
pps.add(p);
3243
}
44+
Flux<Person> f = reactivePersonRepository.saveAll(pps);
45+
this.logger.info(f.blockFirst().toString());
46+
// 必须加上:Flux<Person> f = 才会插入到Mongo
3347
}
3448

3549
@Test

Chapter10/src/test/java/net/liuzd/spring/boot/v2/RxJava2PersonRepositoryTest.java

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,8 @@
11
package net.liuzd.spring.boot.v2;
22

3+
import java.util.ArrayList;
4+
import java.util.List;
5+
36
import javax.annotation.Resource;
47

58
import org.junit.Test;
@@ -28,9 +31,14 @@ public class RxJava2PersonRepositoryTest {
2831
public void testAdd() throws Exception {
2932
// 创建多个User,并验证User总数
3033
int size = 20;
31-
for (int i = 0; i < size; i++) {
32-
rxJava2PersonRepository.save(new Person("liu" + i, "felix" + i, 22 + i));
34+
List<Person> pps = new ArrayList<>();
35+
for (int i = 1; i <= size; i++) {
36+
Person p = new Person("liu" + i, "felix" + i, 22 + i);
37+
pps.add(p);
3338
}
39+
//
40+
Flowable<Person> f = rxJava2PersonRepository.saveAll(pps);
41+
this.logger.info(f.blockingFirst().toString());
3442
}
3543

3644
@Test

Chapter10/src/test/java/net/liuzd/spring/boot/v2/UserRepositoryTest.java

Lines changed: 19 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@
22

33
import java.util.List;
44

5+
import org.junit.Before;
56
import org.junit.Test;
67
import org.junit.runner.RunWith;
78
import org.slf4j.Logger;
@@ -20,18 +21,22 @@
2021
@SpringBootTest
2122
public class UserRepositoryTest {
2223

23-
private final Logger logger = LoggerFactory.getLogger(getClass());
24+
private final Logger logger = LoggerFactory.getLogger(getClass());
2425

2526
@Autowired
2627
private UserRepository userRepository;
2728

29+
@Before
30+
public void before() {
31+
// userRepository.deleteAll();
32+
}
2833

2934
@Test
3035
public void testAdd() throws Exception {
3136
// 创建多个User,并验证User总数
3237
userRepository.save(new User(1L, "felix", 22));
3338
userRepository.save(new User(2L, "tim", 23));
34-
userRepository.save(new User(3L, "cc", 23));
39+
userRepository.save(new User(3L, "cc", 23));
3540
userRepository.save(new User(4L, "pyh", 22));
3641
userRepository.save(new User(5L, "simba", 28));
3742
userRepository.save(new User(6L, "felix2", 10));
@@ -46,16 +51,8 @@ public void testAdd() throws Exception {
4651
userRepository.save(new User(15L, "felix10", 100));
4752
userRepository.save(new User(16L, "", 50));
4853
userRepository.save(new User(17L, null, 50));
49-
}
50-
51-
@Test
52-
public void testDel() throws Exception {
53-
// 删除一个User,再验证User总数
54-
User u = userRepository.findById(1L).orElse(null);
55-
this.logger.info(u.toString());
56-
userRepository.delete(u);
57-
}
58-
54+
}
55+
5956
@Test
6057
public void testFindMore() throws Exception {
6158

@@ -77,9 +74,9 @@ public void testFindMore() throws Exception {
7774
this.logger.info(u8.toString());
7875

7976
}
80-
77+
8178
@Test
82-
public void test3() throws Exception {
79+
public void testPage() throws Exception {
8380

8481
Pageable pageable = PageRequest.of(0, 10);
8582
Page<User> u1 = userRepository.findByNameAndAgeRange("felix", 50, pageable);
@@ -92,6 +89,13 @@ public void test3() throws Exception {
9289
this.logger.info(u3.toString());
9390
u3.getContent().stream().forEach(n -> System.out.println(n.toString()));
9491
}
95-
92+
93+
@Test
94+
public void testDel() throws Exception {
95+
// 删除一个User,再验证User总数
96+
User u = userRepository.findById(1L).orElse(null);
97+
this.logger.info(u.toString());
98+
userRepository.delete(u);
99+
}
96100

97101
}

0 commit comments

Comments
 (0)