Я пишу программу на C#, которая должна будет хранить несколько таблиц данных на компьютере пользователя и загружать их обратно при перезапуске программы: до 10000 записей, состоящих из текст и целые числа. Я не хочу использовать CSV-файл, и у меня были проблемы с SQLite. Есть ли другие хорошие варианты?Какую базу данных использовать в .NET
ответ
Microsoft эквивалент SQLite - SQL Server Compact. Это бесплатно. Вам просто нужно перераспределить некоторые dll с вашим приложением. Конечный пользователь не будет вынужден устанавливать полноценный продукт db, такой как SQL Server Express или MySQL, для запуска вашего приложения.
Это. Работает с инструментами, легкий. Только проще - сериализация. – Will
Это гораздо лучший вариант, если вы хотите, чтобы поведение типа РСУБД в приложении просто использовалось для локального сопротивления. SQL Express - это SQL Server с искусственно установленным пределом 4 ГБ и несет в себе нетривиальные затраты на установку, помимо постоянно работающего сервера, всегда, если вы не отключите его. SQL CE намного более легкий вес и работает в процессе приложения. –
Почему бы просто не сериализовать директивы datatables в двоичном формате и сохранить их на диске. Загрузка будет проще, чем desierlising для datatables снова?
Используя Linq To Objects, вы также можете выполнять запросы (включая объединения), агрегации и т. Д. Против этих объектов. С 10 000 записей вы также получите хорошую скорость (при условии, что у вас есть только несколько таблиц с таким количеством записей, конечно). Я получил довольно мгновенный ответ с примерно 50 000 записей. Время для десериализации, которое вы не будете делать по каждому запросу. Память, очевидно, является пределом, особенно если вы используете общий хостинг. Вы можете легко сериализовать как двоичный, XML или JSON, в зависимости от того, что вам нужно. – jeffa00
Вы также можете использовать «Изолированное хранилище», менее известную функцию .net для хранения, а также предложение Preet. – SoftwareGeek
Хорошая точка в объектах Linq2Objects Я забыл обо всем этом. –
Собираетесь ли вы загружать все в память, а затем выполнять всю обработку данных в памяти? В этом случае использование механизма базы данных будет чрезмерным, возможно, сделает простой XML-файл.
Мне нравится выпуск SQL Server Express.
Мне нравится опция Sql Server Express, потому что она дает вам простой путь обновления для полномасштабного продукта. –
SQL Express будет работать. Вы можете использовать Linq для SQL и легко обращаться к вашим данным.,
Вы также можете использовать Entity Framework. –
Поместите свои DataTables в DataSet (если они еще не были) и используйте метод WriteXml
DataSet для сохранения содержимого в файле XML и ReadXml
для восстановления вашего DataSet.
Если ваше приложение уже написано для работы с DataTables (т. Е. Вы используете Sort, Select и т. Д. Непосредственно в DataTable), это ваше самое простое и простое решение. Полученный XML-файл может быть слишком большим для ваших морских свиней (поскольку XML довольно многословный), но, вероятно, не дал 10 000 строк.
Лично я люблю SQLite (совместно с провайдером .NET с открытым исходным кодом, System.Data.SQLite). Я не уверен, какие проблемы у вас возникли с SQLite, но, может быть, переход на простой в использовании провайдер поможет.
Это то, что мы используем ... как для компактной рамки, так и для рабочего стола. Отлично работает для наших целей. –
Firebird отлично работает с dotNet и может использоваться для этого.
- 1. Какую базу данных использовать?
- 2. какую платформу/базу данных следует использовать?
- 3. Как подключить базу данных на C++? Какую базу данных использовать?
- 4. Какую базу данных использовать и как ускорить
- 5. Какую базу данных java я должен использовать
- 6. Какую базу данных выбрать?
- 7. Какую базу данных использовать для аналитики игры?
- 8. Какую базу данных я должен использовать?
- 9. Моно на Mac - какую базу данных использовать?
- 10. Какую базу данных использовать с Django?
- 11. какую базу данных я должен использовать?
- 12. Какую базу данных я должен использовать?
- 13. Какую базу данных использовать для следующего сценария?
- 14. Какую базу данных браузера SQL использовать?
- 15. iOS, какую базу данных выбрать?
- 16. Какую базу данных я должен использовать для небольшого приложения dotnet?
- 17. Какую базу данных NoSQL следует использовать для ведения журнала?
- 18. Какую структуру и базу данных я должен использовать?
- 19. Каков наилучший способ сообщить базе данных, какую базу данных использовать?
- 20. Какую базу данных следует использовать для максимальной производительности?
- 21. Subversion использует какую базу данных?
- 22. , какую базу данных использовать в Scala (и необходимые примеры)
- 23. Укажите, какую базу данных использовать в скрипте mjodb .js
- 24. Какую облегченную базу данных следует использовать в расширении Firefox?
- 25. Какую базу данных я должен использовать в приложении JavaScript (AngularJS)?
- 26. Какую структуру данных использовать?
- 27. Какую базу данных или псевдо-базу данных следует использовать для данных переменных?
- 28. Какую структуру данных использовать?
- 29. Какую структуру данных использовать?
- 30. Какую структуру данных использовать?
SQLite был бы моим выбором. Какая у вас проблема с SQLite? –