当前位置:Gxlcms > 数据库问题 > MongoDBHelper

MongoDBHelper

时间:2021-07-01 10:21:17 帮助过:26人阅读

using MongoDB.Driver;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Linq.Expressions;
using System.Text;
using System.Threading.Tasks;

namespace KyeDePart.Common.BLL
{
    public class MongoDBHelper<T> where T : class
    {
        protected MongoClient mongoclient;
        protected IMongoDatabase database;
        protected IMongoCollection<T> collection;
        //public static MongoDBHelper<T> MongoDB=new MongoDBHelper<T>();

        /// <summary>
        /// 初始化操作
        /// </summary>
        public MongoDBHelper()
        {
            try
            {
                mongoclient = new MongoDB.Driver.MongoClient(ConfigurationSettings.AppSettings["MongoConnect"]);
                database = mongoclient.GetDatabase(ConfigurationSettings.AppSettings["MongoDatabase"]);
                collection = database.GetCollection<T>(typeof(T).Name);
            }
            catch (Exception ex)
            {
                Common.WriteLogFile(ex.ToString());
            }
        }

        /// <summary>
        /// MongoDB 语法
        /// </summary>
        /// <param name="filter"></param>
        /// <returns></returns>
        public T Query(FilterDefinition<T> filter)
        {
            return collection.Find(filter).FirstOrDefaultAsync().Result;
        }

        /// <summary>
        /// Linq 语法 
        /// </summary>
        /// <param name="func"></param>
        /// <returns></returns>
        public T Query(Expression<Func<T, bool>> func)
        {
            //collection.Find(func).ForEachAsync(x =>Console.WriteLine(""));
            return collection.Find(func).FirstOrDefaultAsync().Result;
        }

        public List<T> QueryList(FilterDefinition<T> filter)
        {
            //var s = collection.Find(filter).ForEachAsync(x => Console.WriteLine(""));
            return collection.Find(filter).ToListAsync().Result;
        }

        public List<T> QueryList(Expression<Func<T, bool>> func)
        {
            return collection.Find(func).ToListAsync().Result;
        }

        /// <summary>
        /// 分页查询
        /// Skip 性能不高
        /// </summary>
       
        /// <returns></returns>
        public List<T> QueryList(int PageIndex, int PageSize, Expression<Func<T, bool>> func, out long RecordCount)
        {
            RecordCount = collection.Find(func).Count();

            //方法一:
            return collection.AsQueryable<T>().Where(func).OrderByDescending(t => "_id").Skip(PageIndex * PageSize).Take(PageSize).ToList();

           

        }

        public bool IsExist(FilterDefinition<T> filter)
        {
            if (collection.Find(filter).FirstAsync().Result != null)
                return true;
            else
                return false;
        }
        public bool IsExist(Expression<Func<T, bool>> func)
        {
            if (collection.Find(func).FirstOrDefaultAsync().Result != null)
                return true;
            else
                return false;

            //long count = collection.CountAsync(func).Result;
            //if (count > 0)
            //    return true;
            //else
            //    return false;
        }

        public void Add(T model)
        {
            collection.InsertOneAsync(model);
        }

        public void Delete(Expression<Func<T, bool>> func)
        {
            collection.DeleteOneAsync(func);
        }

        public void Delete(FilterDefinition<T> filter)
        {
            collection.DeleteOneAsync(filter);
        }
        public void DeleteMany(Expression<Func<T, bool>> func)
        {
            collection.DeleteMany(func);
        }

        public void Update(FilterDefinition<T> filter, UpdateDefinition<T> updated)
        {
            collection.UpdateOneAsync(filter, updated);
        }
        public void UpdateMany(FilterDefinition<T> filter, UpdateDefinition<T> updated)
        {
            collection.UpdateManyAsync(filter, updated);
        }

        public void Update(Expression<Func<T, bool>> func, UpdateDefinition<T> updated)
        {
            collection.UpdateOneAsync(func, updated);
        }

        public void UpdateMany(Expression<Func<T, bool>> func, UpdateDefinition<T> updated)
        {
            collection.UpdateManyAsync(func, updated);
        }
    }
}

  Model

 public class PerSon
    {
        public ObjectId _id;
        public string Name { get; set; }
        public int Age { get; set; }
    }

  

使用方法

public class PerSonBLL
    {
        protected static MongoDBHelper<Models.PerSon> mongoDB = new MongoDBHelper<Models.PerSon>();
        public static List<Models.PerSon> GetList()
        {
            return mongoDB.QueryList(t => t.Age > 10);
        }

    }

  

MongoDBHelper

标签:mode   art   eric   upd   foreach   base   names   lin   ted   

人气教程排行