SpringのデータMongoDBでは、

save()

、 `insert()`を使ってオブジェクトのリストやオブジェクトのリストをmongoDBデータベースに保存することができます。

    User user = new User("...");

   //save user object into "user" collection/table
   //class name will be used as collection name
    mongoOperation.save(user);

   //save user object into "tableA" collection
    mongoOperation.save(user,"tableA");

   //insert user object into "user" collection
   //class name will be used as collection name
    mongoOperation.insert(user);

   //insert user object into "tableA" collection
    mongoOperation.insert(user, "tableA");

   //insert a list of user objects
    mongoOperation.insert(listofUser);

デフォルトでは、オブジェクトを保存し、 “コレクション名”を指定しなかった場合、クラス名がコレクション名として使用されます。

1.保存して挿入する

保存または挿入する必要がありますか?

  1. Save – `saveOrUpdate()`に名前を変更し、 `insert()`を実行しますif



id”が存在しない場合は ”

id”が存在しないか、 “__id”が存在する場合は `update()`が存在します。

  1. Insert – “__id”が存在する場合にのみ、エラーが生成されます.

下記の例を参照してください

   //get an existed data, and update it
    User userD1 = mongoOperation.findOne(
        new Query(Criteria.where("age").is(64)), User.class);
    userD1.setName("new name");
    userD1.setAge(100);

   //if you insert it, 'E11000 duplicate key error index' error is generated.
   //mongoOperation.insert(userD1);

   //instead you should use save.
    mongoOperation.save(userD1);

2.ドキュメントの挿入例

MongoDBに “user”オブジェクトのリストまたはリストを保存する方法の完全な例を見てください。

SpringMongoConfig.java – SpringコンテナでmongoTemplate Beanを作成します。

package com.mkyong.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.mongodb.core.MongoTemplate;
import com.mongodb.MongoClient;
/** **
 **  Spring MongoDB configuration file
 **
 ** /@Configuration
public class SpringMongoConfig{

    public @Bean
    MongoTemplate mongoTemplate() throws Exception {

        MongoTemplate mongoTemplate =
            new MongoTemplate(new MongoClient("127.0.0.1"),"yourdb");
        return mongoTemplate;

    }

}

@Documentを使用して、このオブジェクトを保存するときに「コレクション名」を定義します。

この場合、 “user”オブジェクトが保存されると、 “users”コレクションに保存されます。

User.java

package com.mkyong.user;

import java.util.Date;
import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.index.Indexed;
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.format.annotation.DateTimeFormat.ISO;

@Document(collection = "users")
public class User {

    @Id
    private String id;

    @Indexed
    private String ic;

    private String name;

    private int age;

    @DateTimeFormat(iso = ISO.DATE__TIME)
    private Date createdDate;

   //getter and setter methods
}

完全な例は、データを挿入するさまざまな方法、コードとコメントを読んで自明に説明します。

App.java

package com.mkyong.core;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.data.mongodb.core.MongoOperations;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;

import com.mkyong.config.SpringMongoConfig;
import com.mkyong.user.User;

public class App {

    public static void main(String[]args) {
       //For Annotation
        ApplicationContext ctx =
                     new AnnotationConfigApplicationContext(SpringMongoConfig.class);
        MongoOperations mongoOperation =
                     (MongoOperations) ctx.getBean("mongoTemplate");

       //Case1 - insert a user, put "tableA" as collection name
        System.out.println("Case 1...");
        User userA = new User("1000", "apple", 54, new Date());
        mongoOperation.save(userA, "tableA");

       //find
        Query findUserQuery = new Query();
        findUserQuery.addCriteria(Criteria.where("ic").is("1000"));
        User userA1 = mongoOperation.findOne(findUserQuery, User.class, "tableA");
        System.out.println(userA1);

       //Case2 - insert a user, put entity as collection name
        System.out.println("Case 2...");
        User userB = new User("2000", "orange", 64, new Date());
        mongoOperation.save(userB);

       //find
        User userB1 = mongoOperation.findOne(
                     new Query(Criteria.where("age").is(64)), User.class);
        System.out.println(userB1);

       //Case3 - insert a list of users
        System.out.println("Case 3...");
        User userC = new User("3000", "metallica", 34, new Date());
        User userD = new User("4000", "metallica", 34, new Date());
        User userE = new User("5000", "metallica", 34, new Date());
        List<User> userList = new ArrayList<User>();
        userList.add(userC);
        userList.add(userD);
        userList.add(userE);
        mongoOperation.insert(userList, User.class);

       //find
        List<User> users = mongoOperation.find(
                           new Query(Criteria.where("name").is("metallica")),
               User.class);

        for (User temp : users) {
            System.out.println(temp);
        }

       //save vs insert
        System.out.println("Case 4...");
        User userD1 = mongoOperation.findOne(
                          new Query(Criteria.where("age").is(64)), User.class);
        userD1.setName("new name");
        userD1.setAge(100);

       //E11000 duplicate key error index, __id existed
       //mongoOperation.insert(userD1);
        mongoOperation.save(userD1);
        User userE1 = mongoOperation.findOne(
                         new Query(Criteria.where("age").is(100)), User.class);
        System.out.println(userE1);
    }

}


出力

Case 1...
User[id=id, ic=1000, name=apple, age=54, createdDate=Sat Apr 06 12:35:15 MYT 2013]Case 2...
User[id=id, ic=2000, name=orange, age=64, createdDate=Sat Apr 06 12:59:19 MYT 2013]Case 3...
User[id=id, ic=3000, name=metallica, age=34, createdDate=Sat Apr 06 12:59:19 MYT 2013]User[id=id, ic=4000, name=metallica, age=34, createdDate=Sat Apr 06 12:59:19 MYT 2013]User[id=id, ic=5000, name=metallica, age=34, createdDate=Sat Apr 06 12:59:19 MYT 2013]Case 4...
User[id=id, ic=2000, name=new name, age=100, createdDate=Sat Apr 06 12:59:19 MYT 2013]....

===  3. Mongo Console

Mongoコンソールを見て、何が挿入され、作成されているかを確認してください。

mongo
MongoDB shell version: 2.2.3
connecting to: test

show dbs
admin 0.203125GB
yourdb 0.203125GB

use yourdb
switched to db yourdb
show collections
system.indexes
tableA
users

db.tableA.find()
{ ”

id” : ObjectId(“id”), ”

class” : “com.mkyong.user.User”,
“ic” : “1000”, “name” : “apple”, “age” : 54, “createdDate” : ISODate(“2013-04-06T05:04:06.384Z”) }

db.users.find()
{ ”

id” : ObjectId(“id”), ”

class” : “com.mkyong.user.User”,
“ic” : “3000”, “name” : “metallica”, “age” : 34, “createdDate” : ISODate(“2013-04-06T05:04:06.735Z”) }
{ ”

id” : ObjectId(“id”), ”

class” : “com.mkyong.user.User”,
“ic” : “4000”, “name” : “metallica”, “age” : 34, “createdDate” : ISODate(“2013-04-06T05:04:06.735Z”) }
{ ”

id” : ObjectId(“id”), ”

class” : “com.mkyong.user.User”,
“ic” : “5000”, “name” : “metallica”, “age” : 34, “createdDate” : ISODate(“2013-04-06T05:04:06.735Z”) }
{ ”

id” : ObjectId(“id”), ”

class” : “com.mkyong.user.User”,
“ic” : “2000”, “name” : “new name”, “age” : 100, “createdDate” : ISODate(“2013-04-06T05:04:06.731Z”) }

P.S余分な__class列を削除するには、link://mongodb/spring-data-mongodb-remove-__class-column/[SpringデータMongoDB Remove __class Column]の記事を読んでください。

=== ソースコードをダウンロードする

ダウンロードする -  link://wp-content/uploads/2011/05/SpringMongoDB-Insert-Example.zip[SpringData-MongoDB-Insert-Example.zip](24KB)

=== 参考文献

.  http://static.springsource.org/spring-data/mongodb/docs/current/reference/html/mongo.core.html#mongo-template.save-update-remove[Spring

データMongoDB  - 文書の保存、更新、削除]。リンク://mongodb/spring-data-mongodb-hello-world-example/[Springデータ

MongoDB Hello Worldの例]

link://tag/insert/[insert]link://tag/mongodb/[mongodb]link://tag/spring-data/[spring-data]