首页 > 技术文章 > C#简单连接数据库MongoDB

erlongxizhu-03 2020-07-15 12:03 原文

可将数据库信息写到配置文件中,首先了解配置文件

1、App.config、**.dll.config 和 vshost.exe.config作用区别

 

vshost.exe.config是程序运行时的配置文本

exe.config是程序运行后会复制到vshost.exe.config

app.config是在vshost.exe.config和exe.config没有情况起作用,从app.config复制到exe.config再复制到vshost.exe.config

写配置文件都是写到exe.config文件中了,app.config不会变化。

app.config只在exe.config丢失的情况下在开发环境中重新加载app.config,vshost.exe.config和exe.config会自动创建内容跟app.config一样。

 

vshost.exe.config和app.config两个文件可不要,但exe.config文件不可少。

2、连接MongoDB所需程序包

 

 

然后创建配置文件以及代码读取和修改

3、创建配置文件及配置文件数据读取

 

 

 配置文件App.config:

编译后配置文件dll.config:

 

 

 

 

读取和修改appSettings配置——修改后一定要Save——修改的是App.config编译后的配置文件dll.config

//appSettings:主要存储程序设置,以键值对的形式出现。

 

 

 修改appSettings之前

未Save,dll.config配置的user是888

 

 

 代码中修改appSettings之后

没有调用Save,dll.config配置中的user还是888。

Save写之后,dll.config配置【不是App.config】的 user 修改为999。【App.config并没有改变】

 

 

 

// connectionStrings:由于保存数据连接字符串。

读取connectionStrings配置

 

 

 

 

 

 

providerName属性对应的是数据库的驱动:

 

 

最后上完整代码

4、简单连接数据库MongoDB并查询数据库代码

        // 定义接口
        protected static IMongoDatabase _database;
        // 定义客户端
        protected static IMongoClient _client;
        public static void ConnFindData()
        {
            // 定义要查询的集合名称
            const string collectionName = "UserInfo";
            // 读取连接字符串
            string strCon = ConfigurationManager.ConnectionStrings["mongoDB"].ConnectionString;
            var mongoUrl = new MongoUrlBuilder(strCon);
            // 获取数据库名称
            string databaseName = mongoUrl.DatabaseName;
            // 创建并实例化客户端
            _client = new MongoClient(mongoUrl.ToMongoUrl());
            //  根据数据库名称实例化数据库
            _database = _client.GetDatabase(databaseName);
            // 根据集合名称获取集合
            var collection = _database.GetCollection<BsonDocument>(collectionName);
            var filter = new BsonDocument();
            // 查询集合中的文档
            var list = Task.Run(async () => await collection.Find(filter).ToListAsync()).Result;
            // 循环遍历输出
            foreach (var item in list)
            {
                Console.WriteLine("用户账号:"+item["Account"]);
            }
        }
static void Main(string[] args) { TestConnectMongoDB.ConnFindData(); }

 

推荐阅读