从C#.NET控制台应用程序连接到MongoDb时出错

时间:2012-04-25 17:45:52

标签: c# mongodb

  

无法连接到服务器localhost:27017:
   无法建立连接,因为目标计算机主动拒绝它127.0.0.1:27017。

当我使用mongoDB运行带有C#的控制台应用程序时,会出现此异常 我已经下载了CSharpDriver-1.4.1.4490.msi

 using System;
  using System.Collections.Generic;
 using System.Linq;
using System.Text;
using MongoDB.Bson;
using MongoDB.Driver;
using MongoDB.Driver.Builders;


namespace ConsoleApplication4
{
    public class Entity
   {
       public ObjectId Id { get; set; }
       public string Name { get; set; }
    }

class Program
{
    static void Main(string[] args)
    {

        var connectionString = "mongodb://localhost:27017"; 
            var server = MongoServer.Create(connectionString);
            var database = server.GetDatabase("test");
            var collection = database.GetCollection<Entity>("entities");

            var entity = new Entity { Name = "Tom" };
            collection.Insert(entity);
            var id = entity.Id;

            var query = Query.EQ("_id", id);
            entity = collection.FindOne(query);

            entity.Name = "Dick";
            collection.Save(entity);

            var update = Update.Set("Name", "Harry");
            collection.Update(query, update);

            collection.Remove(query);

      }
 }

1 个答案:

答案 0 :(得分:0)

我会按照Mongo网站上的说明进行操作。 Windows quickstart是开始在Windows上使用Mongo的非常好的资源。

就连接到.Net中的Mongo实例而言,如果在安装Mongo期间没有做任何特殊操作,则不必显式提供连接字符串。以下代码适用于我的Mongo通用设置。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using MongoDB.Bson;
using MongoDB.Driver;
using MongoDB.Bson.IO;
using MongoDB.Bson.Serialization;
using MongoDB.Bson.Serialization.Attributes;
using MongoDB.Bson.Serialization.Conventions;
using MongoDB.Bson.Serialization.IdGenerators;
using MongoDB.Bson.Serialization.Options;
using MongoDB.Bson.Serialization.Serializers;
using MongoDB.Driver.Builders;
using MongoDB.Driver.GridFS;
using MongoDB.Driver.Wrappers;

namespace MongoDB
{
    class Program
    {
        static void Main(string[] args)
        {
            MongoServer server;
            MongoDatabase moviesDb;

            server = MongoServer.Create();
            moviesDb = server.GetDatabase("movies_db");

            //Create some data
            var movie1 = new Movie { Title = "Indiana Jones and the Raiders of the Lost Ark", Year = "1981" };
            movie1.AddActor("Harrison Ford");
            movie1.AddActor("Karen Allen");
            movie1.AddActor("Paul Freeman");

            var movie2 = new Movie { Title = "Star Wars: Episode IV - A New Hope", Year = "1977" };
            movie2.AddActor("Mark Hamill");
            movie2.AddActor("Harrison Ford");
            movie2.AddActor("Carrie Fisher");

            var movie3 = new Movie { Title = "Das Boot", Year = "1981" };
            movie3.AddActor("Jürgen Prochnow");
            movie3.AddActor("Herbert Grönemeyer");
            movie3.AddActor("Klaus Wennemann");

            //Insert the movies into the movies_collection
            var moviesCollection = moviesDb.GetCollection<Movie>("movies_collection");
            //moviesCollection.Insert(movie1);
            //moviesCollection.Insert(movie2);
            //moviesCollection.Insert(movie3);

            var query = Query.EQ("Year","1981");

            var movieFound = moviesDb.GetCollection<Movie>("movies_collection").Drop();

        }



    }


}