Java springcloud B2B2C o2o多用戶商城 springcloud架構(八)springboot整合mongodb

準備工做

  • 安裝MongoDB
  • jdk 1.8
  • maven 3.0
  • idea

環境依賴

在pom文件引入spring-boot-starter-data-mongodb依賴:java

1
2
3
4
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

  

數據源配置

若是mongodb端口是默認端口,而且沒有設置密碼,可不配置,sprinboot會開啓默認的。spring

1
spring.data.mongodb.uri=mongodb: //localhost:27017/springboot-db

  mongodb設置了密碼,這樣配置:mongodb

1
spring.data.mongodb.uri=mongodb: //name:pass@localhost:27017/dbname

  

定義一個簡單的實體

mongodbspringboot

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
package com.forezp.entity;
import org.springframework.data.annotation.Id;
public class Customer {
@Id
public String id;
public String firstName;
public String lastName;
public Customer() {}
public Customer(String firstName, String lastName) {
this .firstName = firstName;
this .lastName = lastName;
}
@Override
public String toString() {
return String.format(
"Customer[id=%s, firstName='%s', lastName='%s']" ,
id, firstName, lastName);
}
}

  

數據操做dao層

1
2
3
4
5
6
public interface CustomerRepository extends MongoRepository<Customer, String> {
public Customer findByFirstName(String firstName);
public List<Customer> findByLastName(String lastName);
}

  

寫一個接口,繼承MongoRepository,這個接口有了幾本的CURD的功能。若是你想自定義一些查詢,好比根據firstName來查詢,獲取根據lastName來查詢,只須要定義一個方法便可。注意firstName嚴格按照存入的mongodb的字段對應。在典型的java的應用程序,寫這樣一個接口的方法,須要本身實現,可是在springboot中,你只須要按照格式寫一個接口名和對應的參數就能夠了,由於springboot已經幫你實現了。maven

測試

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
@SpringBootApplication
public class SpringbootMongodbApplication implements CommandLineRunner {
@Autowired
private CustomerRepository repository;
public static void main(String[] args) {
SpringApplication.run(SpringbootMongodbApplication. class , args);
}
@Override
public void run(String... args) throws Exception {
repository.deleteAll();
// save a couple of customers
repository.save( new Customer( "Alice" , "Smith" ));
repository.save( new Customer( "Bob" , "Smith" ));
// fetch all customers
System.out.println( "Customers found with findAll():" );
System.out.println( "-------------------------------" );
for (Customer customer : repository.findAll()) {
System.out.println(customer);
}
System.out.println();
// fetch an individual customer
System.out.println( "Customer found with findByFirstName('Alice'):" );
System.out.println( "--------------------------------" );
System.out.println(repository.findByFirstName( "Alice" ));
System.out.println( "Customers found with findByLastName('Smith'):" );
System.out.println( "--------------------------------" );
for (Customer customer : repository.findByLastName( "Smith" )) {
System.out.println(customer);
}
}

Spring Cloud大型企業分佈式微服務雲構建的B2B2C電子商務平臺源碼請加企鵝求求:一零三八七七四六二六 
分佈式

相關文章
相關標籤/搜索