8 / 8 / 0
Регистрация: 13.12.2016
Сообщений: 48

Сравнение производительности MariaDb и PostgreSql на .NET CORE

06.01.2018, 23:05. Показов 4319. Ответов 25

Студворк — интернет-сервис помощи студентам
Решил присоединиться к кроссплатформенной разработке на .NET CORE и переписать одно из API на своих сервисах с PHP на C# ASP .NET CORE

И т.к. по сути пришлось начать с чистого листа, то решил поэкспериментировать на тему какаю базу данных из OpenSource использовать.

До этого использовал MariaDb в связке с PHP. Последние пол года, гугля стал замечать, что все рекомендуют переходить на PostgreSql.
Почитав множество отзывов решил испробовать на собственном опыте.

И так поехали:
- для тестирования создал консольное приложение .NET CORE в VisualStudio;
- для MariaDb скачал с nuget пакет MySqlConnector, для PostgreSql пакет Npgsql;
- на одной машине под Debian (старый системник INTEL 2 ядра, 4 GB, SATA raid-1) в локальной сети поднял MariaDb и PostgreSql;
- создал в базах таблицы с идентичной структурой (столбец id (автоинкремент primary key), столбец name_user (varchar(77)));
- код для тестов практически идентичен для PostgreSql и MariaDb(выложу ниже);
- проводил тесты с использованием транзакций и без них;
- все запросы отправлял в цикле по одному для проверки;
- решил ограничиться простыми запросами, без INNER JOIN(Возможно позже использую и их и дополню тему);

Перед каждым тестом очищал таблицу (truncate + сброс автоинкремента), затем делал производил до 10 итераций одного теста.

И вот что получилось:

Скрины тестов:
INSERT:


UPDATE:


SELECT:


DELETE:



Таблица с результатами тестов:
тест баз.xlsx


Код, использованный для теста, может кто еще потестит и отпишет результаты:
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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
using System;
using System.Collections.Generic;
using System.Diagnostics;
using MySql.Data.MySqlClient;
using Npgsql;
 
namespace SpeedBase
{
    internal static class Program
    {
        private static MySqlConnection MySqlConnection { get; }
        private static Stopwatch TimerExecute { get; }
        private static NpgsqlConnection PostgreSqlConnection { get; }
        private static int CountOperation { get; set; }
 
        static Program()
        {
            TimerExecute = new Stopwatch();
            MySqlConnection = new MySqlConnection("server=192.168.0.103;user=UserDb4;database=dataBase4;password=1234567;");
            PostgreSqlConnection = new NpgsqlConnection("Server=192.168.0.103;User Id=postgres;Password=Papa1958;Database=test_postgres;");
        }
 
        private static void Main()
        {
            Console.WriteLine("Test speed DataBase");
 
            do
            {
                Console.WriteLine("Введите команду");
 
                //считываем команду
                var typeBase = Console.ReadLine();
 
                //смотрим какая команда
                switch (typeBase)
                {
                    case "mysql_insert":
                        InsertMySql(1000, true);
                        break;
                    case "postgresql_insert":
                        InsertPostgreSql(1000, true);
                        break;
                    case "mysql_update":
                        UpdateMySql(10000, true);
                        break;
                    case "postgresql_update":
                        UpdatePostgreSql(10000, true);
                        break;
                    case "mysql_select":
                        SelectMySql(10000, true);
                        break;
                    case "postgresql_select":
                        SelectPostgreSql(10000, true);
                        break;
                    case "mysql_delete":
                        DeleteMySql(1000, false);
                        break;
                    case "postgresql_delete":
                        DeletePostgreSql(1000, false);
                        break;
                    default:
                        Console.WriteLine("Неверная команда");
                        break;
                }
 
                Console.WriteLine("Для выхода нажмите Escape; для продолжения - любую другую клавишу");
 
            } while (Console.ReadKey().Key != ConsoleKey.Escape);
        }
 
        //удаление в PostgreSql
        private static void DeletePostgreSql(int countIteration, bool useTransaction)
        {
            CountOperation++;
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            PostgreSqlConnection.Open();
 
            //объявляем транзакцию
            NpgsqlTransaction transaction = null;
 
            //если применяются транзакции открываем ее
            if (useTransaction)
            {
                transaction = PostgreSqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new NpgsqlCommand
            {
                Connection = PostgreSqlConnection,
                CommandText = "DELETE FROM testtable WHERE id=@id;"
            };
 
            //добавляем в параметры транзакцию
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //итерации
            for (var i = 0; i < countIteration; i++)
            {
                command.Parameters.AddWithValue("@id", i + 1);
 
                //отправляем запрос
                command.ExecuteNonQuery();
 
                //очищаем параметры подстановки
                command.Parameters.Clear();
            }
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            PostgreSqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. DELETE IN PostgreSql, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}");
        }
 
        //удаление в MySql
        private static void DeleteMySql(int countIteration, bool useTransaction)
        {
            CountOperation++;
 
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            MySqlConnection.Open();
 
            //объявляем транзакцию
            MySqlTransaction transaction = null;
 
            //если применяются транзакции открываем ее
            if (useTransaction)
            {
                transaction = MySqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new MySqlCommand
            {
                Connection = MySqlConnection,
                CommandText = "DELETE FROM testtable WHERE id=@id;"
            };
 
            //добавляем в параметры транзакцию
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //итерации
            for (var i = 0; i < countIteration; i++)
            {
                command.Parameters.AddWithValue("@id", i + 1);
                //отправляем запрос
                command.ExecuteNonQuery();
            }
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            MySqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. DELETE IN MySQL, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}");
        }
 
        //выбор из PostgreSql
        private static void SelectPostgreSql(int countIteration, bool useTransaction)
        {
            CountOperation++;
 
            var collectionAnswer = new List<string>();
 
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            PostgreSqlConnection.Open();
 
            //объявляем транзакцию
            NpgsqlTransaction transaction = null;
 
            //если применяются транзакции открываем ее
            if (useTransaction)
            {
                transaction = PostgreSqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new NpgsqlCommand
            {
                Connection = PostgreSqlConnection,
                CommandText = "SELECT name_user FROM testtable WHERE id <= @id;"
            };
            command.Parameters.AddWithValue("@id", countIteration);
 
            //добавляем в параметры транзакцию
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //отправляем команду
            var reader = command.ExecuteReader();
 
            //перебираем результат
            while (reader.Read())
            {
                collectionAnswer.Add((string)reader["name_user"]);
            }
 
            reader.Close();
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            PostgreSqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. SELECT IN PostgreSql, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}, count in result = {collectionAnswer.Count}");
        }
 
        //выбор из MySql
        private static void SelectMySql(int countIteration, bool useTransaction)
        {
            CountOperation++;
 
            var collectionAnswer = new List<string>();
 
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            MySqlConnection.Open();
 
            //объявляем транзакцию
            MySqlTransaction transaction = null;
 
            //если применяются транзакции открываем ее
            if (useTransaction)
            {
                transaction = MySqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new MySqlCommand
            {
                Connection = MySqlConnection,
                CommandText = "SELECT name_user FROM testtable WHERE id <= @id;"
            };
            command.Parameters.AddWithValue("@id", countIteration);
 
            //добавляем в параметры транзакцию
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //отправляем команду
            var reader = command.ExecuteReader();
 
            //перебираем результат
            while (reader.Read())
            {
                collectionAnswer.Add((string)reader["name_user"]);
            }
 
            reader.Close();
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            MySqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. SELECT IN MySQL, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}, count in result = {collectionAnswer.Count}");
        }
 
        //обновление данных в PostgreSql
        private static void UpdatePostgreSql(int countIteration, bool useTransaction)
        {
            CountOperation++;
 
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            PostgreSqlConnection.Open();
 
            //объявляем транзакцию
            NpgsqlTransaction transaction = null;
 
            //если применяются транзакции открываем ее
            if (useTransaction)
            {
                transaction = PostgreSqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new NpgsqlCommand
            {
                Connection = PostgreSqlConnection,
                CommandText = "UPDATE testtable SET name_user=@name_user WHERE id=@id;"
            };
 
            //добавляем в параметры транзакцию
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //итерации
            for (var i = 0; i < countIteration; i++)
            {
                command.Parameters.AddWithValue("@name_user", "lkdsdsdfwf435rtgder5jvnslnvxzkjsruJhJFncKr8jfnC444444ffyutfuygjjgjhgfjghfhjg");
                command.Parameters.AddWithValue("@id", i + 1);
                //отправляем запрос
                command.ExecuteNonQuery();
 
                //!!!пришлось делать сброс подставляемых параметров к запросу, почему то без этого апдэйтило только превую строку в таблице
                command.Parameters.Clear();
            }
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            PostgreSqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. UPDATE IN PostgreSql, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}");
        }
 
        //обновление данных в MySql
        private static void UpdateMySql(int countIteration, bool useTransaction)
        {
            CountOperation++;
 
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            MySqlConnection.Open();
 
            //объявляем транзакцию
            MySqlTransaction transaction = null;
 
            //если применяются транзакции инициализируем ее
            if (useTransaction)
            {
                transaction = MySqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new MySqlCommand
            {
                Connection = MySqlConnection,
                CommandText = "UPDATE testtable SET name_user=@name_user WHERE id=@id;"
            };
 
 
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //итерации
            for (var i = 0; i < countIteration; i++)
            {
                command.Parameters.AddWithValue("@name_user", "lkdsdsdfwf435rtgder5jvnslnvxzkjsruJhJFncKr8jfnC444444ffyutfuygjjgjhgfjghfhjg");
                command.Parameters.AddWithValue("@id", i + 1);
                //отправляем запрос
                command.ExecuteNonQuery();
            }
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            MySqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. UPDATE IN MySQL, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}");
        }
 
        //вставка данных в PostgreSql
        private static void InsertPostgreSql(int countIteration, bool useTransaction)
        {
            CountOperation++;
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            PostgreSqlConnection.Open();
 
            //объявляем транзакцию
            NpgsqlTransaction transaction = null;
 
            //если применяются транзакции открываем ее
            if (useTransaction)
            {
                transaction = PostgreSqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new NpgsqlCommand
            {
                Connection = PostgreSqlConnection,
                CommandText = "INSERT INTO testtable (name_user) VALUES (@name_user);"
            };
            command.Parameters.AddWithValue("@name_user", "asjassfewerweryoquy49r76wt87oqhufewoufiefwy34yoi3y3iu4y34yri3u4yr34u3o4uy4dd");
 
            //добавляем в параметры транзакцию
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //итерации
            for (var i = 0; i < countIteration; i++)
            {
                //отправляем запрос
                command.ExecuteNonQuery();
            }
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            PostgreSqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. INSERT IN PostgreSql, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}");
        }
 
        //вставка данных в MySql
        private static void InsertMySql(int countIteration, bool useTransaction)
        {
            CountOperation++;
 
            //сбрасываем таймер
            TimerExecute.Reset();
 
            //запускаем таймер
            TimerExecute.Start();
 
            //открываем соединение
            MySqlConnection.Open();
 
            //объявляем транзакцию
            MySqlTransaction transaction = null;
 
            //если применяются транзакции открываем ее
            if (useTransaction)
            {
                transaction = MySqlConnection.BeginTransaction();
            }
 
            //формируем команду
            var command = new MySqlCommand
            {
                Connection = MySqlConnection,
                CommandText = "INSERT INTO testtable (name_user) VALUES (@name_user);"
            };
            command.Parameters.AddWithValue("@name_user", "asjassfewerweryoquy49r76wt87oqhufewoufiefwy34yoi3y3iu4y34yri3u4yr34u3o4uy4dd");
 
            //добавляем в параметры транзакцию
            if (useTransaction)
            {
                command.Transaction = transaction;
            }
 
            //итерации
            for (var i = 0; i < countIteration; i++)
            {
                //отправляем запрос
                command.ExecuteNonQuery();
            }
 
            //закрываем транзакцию
            if (useTransaction)
            {
                transaction.Commit();
            }
 
            //закрываем соединение
            MySqlConnection.Close();
 
            //останавливаем таймер
            TimerExecute.Stop();
 
            //считаем разницу
            var time = TimerExecute.Elapsed;
 
            //выводим результат
            Console.WriteLine($@"№ {CountOperation}. INSERT IN MySQL, time = {time.Hours:00}:{time.Minutes:00}:{time.Seconds:00}.{time.Milliseconds:000}");
        }
    }
}
Исходя из результатов тестов, получилось, что при прочих равных условиях:
1. PostgreSql почти в 4 раза быстрее производит запросы на добавление данных (INSERT) без применения транзакций.
2. При использовании транзакций производительность у MariaDb (INSERT) увеличилась практически в 13 раз.
3. При использовании транзакций производительность у PostgreSql (INSERT) увеличилась в среднем в 1,6 раз.
4. При увеличении объема вставляемых данных (INSERT) MariaDb при применении транзакций начинает выигрывать у PostgreSql.
5. Смутил в PostgreSql Update, почему то обновлялась только первая строка, пришлось делать сброс подставляемых параметров к запросу (пометил в коде !!!).
6. Был неприятно удивлен скоростью работы MariaDb без транзакций. Раньше их не применял в связке с PHP. Да и на боевом сервере ранее особо тормозов не замечал.
7. Пришел к выводу что транзакции нужно использовать.

В целом при применении транзакций Производительность MariaDb сопоставима с PostgreSql. Кроме этого MariaDb использую на протяжении нескольких лет и пока она не подводила.
Поэтому не могу однозначно по тестам сделать вывод с какой базой лучше работать.

Помогите принять решение, какую из этих двух баз лучше использовать и почему, основываясь на вашем опыте?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.01.2018, 23:05
Ответы с готовыми решениями:

Оптимизация производительности C#.NET (Алгоритм, Многопоточность, Debug, Release, .Net Core, Net Native)
Решил поделится своим небольшим опытом по оптимизации вычислений на C#.NET. НЕ профи, палками не кидать, конструктив приветствуется! ...

Asp.net core + EFCore + PostgreSQL: трабла с миграцией
Есть старенькая миграция, которая прекрасно работала с MSSQL. protected override void Up(MigrationBuilder migrationBuilder) ...

ASP.NET Core. Старт - что нужно знать, чтобы стать ASP.NET Core разработчиком?
Попалось хор краткое обзорное видео 2016 года с таким названием - Что нужно знать, чтобы стать ASP.NET MVC разработчиком? Сейчас уже 2018...

25
Эксперт .NET
 Аватар для Usaga
13497 / 9030 / 1326
Регистрация: 21.01.2016
Сообщений: 33,858
07.01.2018, 14:48
spocher, вы не получите краткого и ясного ответа. Обе СУБД взрослые и с успехом используются в "продакшене" кучей фирм.

Выберете любую.
2
 Аватар для AnastasiaSX
53 / 31 / 4
Регистрация: 19.12.2013
Сообщений: 170
17.03.2023, 15:38
Какая база будет работать быстрее существенно зависит от ваших данных. В некоторых случаях быстрее будет MySQL/MariaDB, в других PostgreSQL, в третьих разница будет минимальна,
в четвертых вы упретесь в сеть и разницы не увидите. Увы, но на ваших данных и железе вам надо провести тест самостоятельно и выбрать самостоятельно. Если разница будет не более 10-20 % тогда вы глазом не увидите разницу, берите ту базу что более популярна, а именно MariaDB.
0
403 / 265 / 69
Регистрация: 12.04.2020
Сообщений: 1,404
17.03.2023, 16:04
Цитата Сообщение от AnastasiaSX Посмотреть сообщение
Какая база будет работать быстрее существенно зависит от ваших данных. В некоторых случаях быстрее будет MySQL/MariaDB, в других PostgreSQL, в третьих разница будет минимальна,
в четвертых вы упретесь в сеть и разницы не увидите. Увы, но на ваших данных и железе вам надо провести тест самостоятельно и выбрать самостоятельно. Если разница будет не более 10-20 % тогда вы глазом не увидите разницу, берите ту базу что более популярна, а именно MariaDB.
а еще я провел исследование
и увидел некропостинг!
0
Эксперт .NET
 Аватар для Usaga
13497 / 9030 / 1326
Регистрация: 21.01.2016
Сообщений: 33,858
17.03.2023, 16:05
AnastasiaSX, почему вы решили, что Мария более популярная? Почему вы решили, что если она действительно более популярная на цифрах, то это какое-то значимое преимущество?

PHP популярнее шарпов в вебразработке, но ТСа это не остановило начать переписывать проект на шарпе.
0
403 / 265 / 69
Регистрация: 12.04.2020
Сообщений: 1,404
17.03.2023, 16:07
Цитата Сообщение от Usaga Посмотреть сообщение
PHP популярнее шарпов в вебразработке
главное потом из энтерпрайза вылезти и выдохнуть
0
 Аватар для Andrey-MSK
3202 / 2095 / 379
Регистрация: 14.08.2018
Сообщений: 6,981
Записей в блоге: 4
17.03.2023, 16:14
Цитата Сообщение от AnastasiaSX Посмотреть сообщение
берите ту базу что более популярна, а именно MariaDB
А я думаю, что в связке с C#, MS SQL Server более популярна...
0
Эксперт .NET
 Аватар для Usaga
13497 / 9030 / 1326
Регистрация: 21.01.2016
Сообщений: 33,858
17.03.2023, 16:15
Dr9vik, а что оттуда вылазить? Это люк канализационный?
0
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3313 / 2540 / 562
Регистрация: 04.09.2018
Сообщений: 8,121
Записей в блоге: 3
17.03.2023, 16:20
Цитата Сообщение от AnastasiaSX Посмотреть сообщение
берите ту базу что более популярна, а именно MariaDB
Что что? Хорошая популярность у MariaDB - первый раз о ней слышу .
С разными БД работаю много лет, заказчиков еще больше - ни у одного такой не видел.. Более популярна блин. Не смешите.
0
 Аватар для Andrey-MSK
3202 / 2095 / 379
Регистрация: 14.08.2018
Сообщений: 6,981
Записей в блоге: 4
17.03.2023, 16:28
Цитата Сообщение от wizard41 Посмотреть сообщение
первый раз о ней слышу
Ну дык MySQL жеж
0
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3313 / 2540 / 562
Регистрация: 04.09.2018
Сообщений: 8,121
Записей в блоге: 3
17.03.2023, 16:30
Цитата Сообщение от Andrey-MSK Посмотреть сообщение
Ну дык MySQL жеж
Очередная обертка?
0
 Аватар для Andrey-MSK
3202 / 2095 / 379
Регистрация: 14.08.2018
Сообщений: 6,981
Записей в блоге: 4
17.03.2023, 16:33
Цитата Сообщение от wizard41 Посмотреть сообщение
Очередная обертка?
MariaDB is a fork from MySQL and is 100% compatible with prior versions of MySQL.
0
 Аватар для IamRain
4637 / 2651 / 728
Регистрация: 02.08.2011
Сообщений: 7,113
17.03.2023, 16:37
Цитата Сообщение от wizard41 Посмотреть сообщение
Хорошая популярность у MariaDB - первый раз о ней слышу
Не то чтобы я сомневаюсь в камнях, которые вы бросаете в огород MariaDb, но на некоторых зарубежных сайтах все так.
Desktop Distribution of the Year - Ubuntu
Server Distribution of the Year - Debian Stable
Live Distribution of the Year - Slackware Live Edition
Database of the Year - MariaDB
Browser of the Year - Firefox
Desktop Environment of the Year - Plasma Desktop (KDE)
Window Manager of the Year - Openbox
Audio Media Player Application of the Year - VLC
Digital Audio Workstation of the Year - Ardour / LMMS
Video Media Player of the Year - VLC
Video Authoring Application of the Year - KDEnlive
Security Hardening and/or Scanning Application of the Year - nmap
Network Monitoring Application of the Year - Nagios Core
IDE of the Year - Visual Studio Code
(результаты опроса за 2021 год опубликованы 15 февраля 2022 года)
Общеизвестно, что многие технологические тренды перетекают в РФ с приличной задержкой в 2-3 года...

Добавлено через 55 секунд
Цитата Сообщение от wizard41 Посмотреть сообщение
Очередная обертка?
Это форк, видать, у MySql есть известные косяки, которые были решены в Maшульке.
0
403 / 265 / 69
Регистрация: 12.04.2020
Сообщений: 1,404
17.03.2023, 16:39
Цитата Сообщение от IamRain Посмотреть сообщение
Database of the Year - MariaDB
https://www.percona.com/blog/w... ose-money/
тоесть будет тоже самое?
0
 Аватар для Andrey-MSK
3202 / 2095 / 379
Регистрация: 14.08.2018
Сообщений: 6,981
Записей в блоге: 4
17.03.2023, 16:41
Цитата Сообщение от IamRain Посмотреть сообщение
но на некоторых зарубежных сайтах все так.
Тут всё из *NIX вроде как...
0
403 / 265 / 69
Регистрация: 12.04.2020
Сообщений: 1,404
17.03.2023, 16:42
Цитата Сообщение от Usaga Посмотреть сообщение
Dr9vik, а что оттуда вылазить? Это люк канализационный?
простите оговорился
имелось ввиду легаси
0
 Аватар для IamRain
4637 / 2651 / 728
Регистрация: 02.08.2011
Сообщений: 7,113
17.03.2023, 16:43
Dr9vik, не знаю, не проверял (да и лень), можете провести опыты и поделиться результатами с нами.
0
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3313 / 2540 / 562
Регистрация: 04.09.2018
Сообщений: 8,121
Записей в блоге: 3
17.03.2023, 16:44
Цитата Сообщение от IamRain Посмотреть сообщение
но на некоторых зарубежных сайтах
Мда, интересно.. Ну у нас действительно с этим трендом похуже будет.
К слову сказать, наверное даже потому, что и саму MySQL уже все труднее встретить в организациях, не то что-бы какой-то ее клон...
0
 Аватар для IamRain
4637 / 2651 / 728
Регистрация: 02.08.2011
Сообщений: 7,113
17.03.2023, 16:45
Цитата Сообщение от Andrey-MSK Посмотреть сообщение
Тут всё из *NIX вроде как..
Ну Машуля-то кроссплатформенная.

Не по теме:


Как разработчики политически корректно называют трансгендеров?
- Кроссплатформенные


0
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3313 / 2540 / 562
Регистрация: 04.09.2018
Сообщений: 8,121
Записей в блоге: 3
17.03.2023, 16:46
Цитата Сообщение от IamRain Посмотреть сообщение
[OFF="Шутка"]
У OFF'а нет аргументов??
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.03.2023, 16:46
Помогаю со студенческими работами здесь

переезд с lightt + mariadb 5.x на nginx + php-fpm + mariadb
Доброго времени суток, коллеги. Имею такую проблему: Ранее был lighttpd на centos 7.X, всё работало корректно. Сейчас...

Какая разница между ASP .Net Core и ASP .Net Core MVC?
Какая разница между ASP .Net Core и ASP .Net Core MVC? Или я может что-то не так понял? И подскажите пожалуйста еще какие-то книги для...

Объясните на пальцах совместимость библиотек в .Net Core, .Net Framework, .Net Standart
Изучаю .Net. Хочу написать некое серверное приложение (думаю что учеба лучше на реальном примере, нежели писать примитивные hello world)....

ASP.NET Core + EF Core: ошибка при обновлении БД после создания миграции
Всем привет! Начал осваивать ASP.NET Core: создал проект &quot;Веб-приложение&quot; без Identity. Сразу же решил подружить его с Entity...

Разница между ASP.NET Core 2, ASP.NET Core MVC, ASP.NET MVC 5 и ASP.NET WEBAPI 2
Здравствуйте. Я в бекенд разработке полный ноль. В чем разница между вышеперечисленными технологиями? Есть ли в них что-то общее - могу ли...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

Новые блоги и статьи
JWT аутентификация в ASP.NET Core
UnmanagedCoder 18.06.2025
Разрабатывая веб-приложения, я постоянно сталкиваюсь с дилеммой: как обеспечить надежную аутентификацию пользователей без ущерба для производительности и масштабируемости? Классические подходы на. . .
Краткий курс по С#
aaLeXAA 18.06.2025
Здесь вы найдете все необходимые функции чтоб написать програму на C# Задание 1: КЛАСС FORM 1 public partial class Form1 : Form { Spisok listin = new Spisok(); . . .
50 самых полезных примеров кода Python для частых задач
py-thonny 17.06.2025
Эффективность работы разработчика часто измеряется не количеством написаных строк, а скоростью решения задач. Готовые сниппеты значительно ускоряют разработку, помогают избежать типичных ошибок и. . .
C# и продвинутые приемы работы с БД
stackOverflow 17.06.2025
Каждый . NET разработчик рано или поздно сталкивается с ситуацией, когда привычные методы работы с базами данных превращаются в источник бессонных ночей. Я сам неоднократно попадал в такие ситуации,. . .
Angular: Вопросы и ответы на собеседовании
Reangularity 15.06.2025
Готовишься к техническому интервью по Angular? Я собрал самые распространенные вопросы, с которыми сталкиваются разработчики на собеседованиях в этом году. От базовых концепций до продвинутых. . .
Архитектура Onion в ASP.NET Core MVC
stackOverflow 15.06.2025
Что такое эта "луковая" архитектура? Термин предложил Джеффри Палермо (Jeffrey Palermo) в 2008 году, и с тех пор подход только набирал обороты. Суть проста - представьте себе лук с его. . .
Unity 4D
GameUnited 13.06.2025
Четырехмерное пространство. . . Звучит как что-то из научной фантастики, правда? Однако для меня, как разработчика со стажем в игровой индустрии, четвертое измерение давно перестало быть абстракцией из. . .
SSE (Server-Sent Events) в ASP.NET Core и .NET 10
UnmanagedCoder 13.06.2025
Кажется, Microsoft снова подкинула нам интересную фичу в новой версии фреймворка. Работая с превью . NET 10, я наткнулся на нативную поддержку Server-Sent Events (SSE) в ASP. NET Core Minimal APIs. Эта. . .
С днём независимости России!
Hrethgir 13.06.2025
Решил побеседовать, с утра праздничного дня, с LM о завоеваниях. То что она написала о народе, представителем которого я являюсь сам сначала возмутило меня, но дальше только смешило. Это чисто. . .
Лето вокруг.
kumehtar 13.06.2025
Лето вокруг. Наполненное бурями и ураганами событий. На фоне магии Жизни, священной и вечной, неумелой рукой человека рисуется панорама душевного непокоя. Странные серые краски проникают и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru