Форум программистов, компьютерный форум, киберфорум
C#: Базы данных, ADO.NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 19.06.2016
Сообщений: 11
1

ORM для MongoDB

16.10.2017, 13:25. Показов 2398. Ответов 4

Author24 — интернет-сервис помощи студентам
Привет всем. Написал ORM для MongoDB, подобную EntityFramework.
Написано под netstandard 2.0, для .Net FrameWork 4.6.1 и выше должно работать.
Ссылка на github - https://github.com/slynetigor/ORM.
Система сама разруливает связи подобно EF, хранит все в отдельных коллекциях (как в sql). Пока что поддерживается только string ID, но в планах сделать поддержку Guid, ObjectID, и числовые ID (int, long и т.д.), а также добавить хранение данных как в sql подобном, так и документо-ориентированном виде
Примеры:
C#
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
//Модели
 
public class BaseModel
{
        public virtual string Id { get; set; }
}
 
public class Message : BaseModel
{
        public string Text { get; set; }
 
        public string Date { get; set; }
 
        public virtual User User { get; set; }
 
        public virtual Room Room { get; set; }
}
 
public class Room : BaseModel
{
        public Room()
        {
            this.Users = new List<User>();
 
            this.Messages = new List<Message>();
        }
 
        public string Name { get; set; }
 
        public virtual ICollection<User> Users { get; set; }
 
        public virtual ICollection<Message> Messages { get; set; }
}
 
public class User : BaseModel
{
        public string UserName { get; set; }
 
        public string Password { get; set; }
 
        public virtual Room Room { get; set; }
}
 
//Контекст
public class MongoAppContext : MongoDbContext
{
        public MongoAppContext(MongoContextSettings settings)
            : base(settings)
        {
        }
 
        public IModelsProvider<Room> Rooms { get; set; }
 
        public IModelsProvider<Message> Messages { get; set; }
 
        public IModelsProvider<User> Users { get; set; }
}
 
//Пример репозиториев
 
public class GenericMongoRepository<TEntity> : IRepository<TEntity>
        where TEntity : BaseModel, new()
{
        private MongoAppContext context;
        private IModelsProvider<TEntity> modelsProvider;
 
        public GenericMongoRepository(MongoAppContext context)
        {
            this.context = context;
            this.modelsProvider = this.context.Set<TEntity>();
        }
 
        protected MongoAppContext Context
        {
            get { return this.context; }
        }
 
        protected IModelsProvider<TEntity> ModelsProvider
        {
            get { return this.modelsProvider; }
        }
 
        protected IEnumerable<TEntity> Query { get; set; }
 
        public void Add(TEntity entity)
        {
            this.modelsProvider.AddAsync(entity);
        }
 
        public void Update(TEntity entity)
        {
            this.modelsProvider.UpdateAsync(entity);
        }
 
        public void Remove(TEntity entity)
        {
            this.modelsProvider.RemoveAsync(entity);
        }
 
        public TEntity GetById(string id)
        {
            if (this.Query != null)
            {
                return this.Query.FirstOrDefault(e => e.Id == id);
            }
 
            return this.modelsProvider.FirstOrDefault(e => e.Id == id);
        }
 
        public IEnumerable<TEntity> GetEntities()
        {
            if (this.Query != null)
            {
                return this.Query;
            }
 
            return this.modelsProvider;
        }
 
        public IEnumerable<TEntity> GetEntities(Expression<Func<TEntity, bool>> predicate)
        {
            if (this.Query != null)
            {
                return this.Query.Where(predicate.Compile());
            }
 
            return this.modelsProvider.Where(predicate.Compile());
        }
}
 
public class MessagesMongoRepository : GenericMongoRepository<Message>
{
        public MessagesMongoRepository(MongoAppContext context)
            : base(context)
        {
            this.Query = this.ModelsProvider.Include("Room", "User");
        }
}
Пример работы можно посмотреть здесь (код, тот что выше, оттуда): https://github.com/slynetigor/webmessenger

P.S: жду критику и если кто хочет, помощь в разработке)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.10.2017, 13:25
Ответы с готовыми решениями:

Mongodb, Mongoid как ускорить запись данных в Mongodb
Добрый вечер всем! Мне нужно записать в Mongodb 2.000.000 рядов информации, по очереди, один за...

как реализовать аутентификацию на mongodb используя gem devise (mongodb + Rails + devise)
как реализовать аутентификацию в mongodb используя gem devise? в роутах у меня есть devise_for...

Выбор ORM для проекта
Вообще для продакшн - проектов не использую никакие ORM никогда!Но тут прилетел проект для...

Лёгкая ORM для PHP
Не могу найти подходящую ORM для пыха. Проект маленький, но работа с БД - примерно 80 процентов от...

4
Эксперт .NET
12078 / 8387 / 1281
Регистрация: 21.01.2016
Сообщений: 31,597
16.10.2017, 13:50 2
skynet_igor, с каких пор для MongoDB понадобилась ORM?
0
0 / 0 / 0
Регистрация: 19.06.2016
Сообщений: 11
16.10.2017, 14:53  [ТС] 3
Она как бы и не нужна, но я чисто для себя сделал такой проект, в котором попытался реализовать подход sql к mongodb, и решил им поделиться.

Добавлено через 16 минут
По сути это ODM, но назвал ORM так как я пытался сделать работу с данными подобно sql и меньше писать кода используя официальный драйвер
0
0 / 0 / 0
Регистрация: 19.06.2016
Сообщений: 11
23.10.2017, 11:31  [ТС] 4
Обновление: добавил инклуд навигационных свойств при помощи Expression

Пример:

C#
1
this.ModelsProvider.Include(m => m.Room, m => m.User);
Так же хочу написать query провайдера, так как на данный момент тянутся все модели, а потом уже фильтруются через IEnumerable... Пока что читаю тех. документацию по поводу провайдера, если есть хорошие статейки по этому поводу, подкиньте

Так же тестировал производительность, 2 ляма моделей закидывает в базу за 20 сек.
0
3 / 3 / 0
Регистрация: 04.06.2015
Сообщений: 56
06.05.2020, 02:21 5
Эх ты, решил глянуть что там, да как. Очень понадобилась система роллбека... А репозиторий то тю-тю...
0
06.05.2020, 02:21
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.05.2020, 02:21
Помогаю со студенческими работами здесь

Посоветуйте ORM для моего проекта
Добрый день Уважаемые коллеги! Посоветуйте ORM для проекта Сейчас я это делаю так /** ...

Выбор ORM для динамического подключения к различным базам
Приветствую. Поставлена следующая задача: есть приложение на Java Spring MVC. Требуется...

Установка драйверов для работы с MongoDB
Сделал $ pecl install mongodb $ echo &quot;extension=mongodb.so&quot; &gt;&gt; `php --ini | grep &quot;Loaded...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru