реклама на сайте
подробности

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> СУБД для микроконтроллерной среды., СУБД - система управления базами данных
Буратино
сообщение Sep 19 2011, 09:26
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 433
Регистрация: 27-10-08
Из: Украина, Киев
Пользователь №: 41 215



В свое время работал с базами данных. Очень удобно и функционально получалось реализовывать многие вещи. Скажите, встречаются подобного рода подходы, для хранения и обработки информации, в мире микроэлектронных систем?



--------------------
Брак - это такой вид отношений, в которых один всегда прав, - а другой - муж.
Go to the top of the page
 
+Quote Post
Буратино
сообщение Sep 26 2011, 07:33
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 433
Регистрация: 27-10-08
Из: Украина, Киев
Пользователь №: 41 215



Нашел нечто подходящее для встраиваемых систем: SQLite, но на сколько я понял, для того чтоб развернуть это дело нужен линукс полюбому?
Возможно использовать функционал этой системы в RTOS, ну например FreeRTOS?


--------------------
Брак - это такой вид отношений, в которых один всегда прав, - а другой - муж.
Go to the top of the page
 
+Quote Post
codier
сообщение Sep 26 2011, 07:42
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 29
Регистрация: 21-01-05
Пользователь №: 2 113



Позволю усомниться в надобности СУБД. Если речь про микроэлектронные системы, то тут ограничена и память и быстродействие. Т.к. такие системы обычно работают в реалтайме, то и требования к СУБД тоже реалтаймовые получаются? Думаю что в варианте "без SQL" такое возможно, но опять же есть ли смысл?
Go to the top of the page
 
+Quote Post
Буратино
сообщение Sep 26 2011, 07:52
Сообщение #4


Профессионал
*****

Группа: Свой
Сообщений: 1 433
Регистрация: 27-10-08
Из: Украина, Киев
Пользователь №: 41 215



Цитата(codier @ Sep 26 2011, 10:42) *
Позволю усомниться в надобности СУБД. Если речь про микроэлектронные системы, то тут ограничена и память и быстродействие. Т.к. такие системы обычно работают в реалтайме, то и требования к СУБД тоже реалтаймовые получаются? Думаю что в варианте "без SQL" такое возможно, но опять же есть ли смысл?


Ну базы данных разными бывают. Есть монстры на больших предприятиях и есть небольшие и аккуратные хранилища вспомогательной информации ,данных с периферии и т.д. Ну скажем так: мне не помешает однозначно.


--------------------
Брак - это такой вид отношений, в которых один всегда прав, - а другой - муж.
Go to the top of the page
 
+Quote Post
Idle
сообщение Sep 26 2011, 10:30
Сообщение #5


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



http://stackoverflow.com/questions/2011724...se-for-embedded
http://stackoverflow.com/questions/300746/embedded-sql-in-c
Go to the top of the page
 
+Quote Post
Буратино
сообщение Sep 26 2011, 11:48
Сообщение #6


Профессионал
*****

Группа: Свой
Сообщений: 1 433
Регистрация: 27-10-08
Из: Украина, Киев
Пользователь №: 41 215



Хм, нашел пару ссылок где говорят о том что запускали на RTOS SQLite, но работала база только если хранилась в ОЗУ. Встречаются упоминания о коммерческих реализациях поддержки SQLite в той или иной RTOS ...


--------------------
Брак - это такой вид отношений, в которых один всегда прав, - а другой - муж.
Go to the top of the page
 
+Quote Post
Andrew2000
сообщение Sep 28 2011, 20:32
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 421
Регистрация: 25-12-04
Пользователь №: 1 675



Berkeley DB ?

Wiki: высокопроизводительная встраиваемая база данных, реализованная в виде библиотеки. BDB является нереляционной базой данных — она хранит пары ключ/значение как массивы байтов и поддерживает множество значений для одного ключа. BDB может обслуживать тысячи процессов или потоков, одновременно манипулирующих базами данных размером в 256 терабайт, на разнообразном оборудовании под различными операционными системами, включая большинство UNIX-подобных систем и Windows, а также на операционных системах реального времени.
Go to the top of the page
 
+Quote Post
ARMik
сообщение Oct 31 2011, 16:14
Сообщение #8


Частый гость
**

Группа: Участник
Сообщений: 103
Регистрация: 22-02-07
Пользователь №: 25 588



Посмотрите в сторону .Net Micro Framework. В некоторых портах (например у GHI electronics) есть реализация SQLite.
Go to the top of the page
 
+Quote Post
AlexandrY
сообщение Nov 1 2011, 11:36
Сообщение #9


Ally
******

Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050



Цитата(Буратино @ Sep 26 2011, 13:48) *
Хм, нашел пару ссылок где говорят о том что запускали на RTOS SQLite, но работала база только если хранилась в ОЗУ. Встречаются упоминания о коммерческих реализациях поддержки SQLite в той или иной RTOS ...


А зачем ссылки искать?
В самой доке на SQLite есть пример портирования на платформу вообще без файловой системы с прямой записью на носитель.
Есть там и модуль портирования VFS на RTOS VxWorks.
Есть порт и под POSIX (многие RTOS имеют POSIX совместимый интерфейс)

Если есть лишних 600 КБ под память программ на платформе и хороший менеджер кучи то SQLite можно пожалуй за день портировать и без оси.
Правда их дикий основной файл размером в три метра редкий парсер обработает. wink.gif
Go to the top of the page
 
+Quote Post
SortoVaritu
сообщение Nov 3 2011, 09:51
Сообщение #10


Участник
*

Группа: Участник
Сообщений: 44
Регистрация: 4-11-10
Пользователь №: 60 647



Цитата(Буратино @ Sep 26 2011, 14:48) *
Хм, нашел пару ссылок где говорят о том что запускали на RTOS SQLite, но работала база только если хранилась в ОЗУ. Встречаются упоминания о коммерческих реализациях поддержки SQLite в той или иной RTOS ...


Если база хранится в ОЗУ, то как я понимаю нужно организовывать процедуры записи данных из базы во флэш к примеру, а так же чтения базы при перезапуске системы. Думаю, что если количество данных не очень большое, то проще разработать свои структуры хранения и обработки - думаю будет намного бытрее.
Go to the top of the page
 
+Quote Post
AlexandrY
сообщение Nov 3 2011, 10:14
Сообщение #11


Ally
******

Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050



Цитата(SortoVaritu @ Nov 3 2011, 11:51) *
Если база хранится в ОЗУ, то как я понимаю нужно организовывать процедуры записи данных из базы во флэш к примеру, а так же чтения базы при перезапуске системы. Думаю, что если количество данных не очень большое, то проще разработать свои структуры хранения и обработки - думаю будет намного бытрее.


Тут просто недопонимание.
SQLite не зависит от типа носителя, там все кончается абстракцией называемой "виртуальная файловая система" VFS.
Все что ниже разработчик пишет сам.
В примерах SQLite сразу работает с Flash накопителями.

Но реально тягаться с SQLite в быстроте самопальными на скорую руку методами, IMHO, бессмысленно.

А то что там нужен адекватный большой heap в ОЗУ, так это любые базы данных требуют и самопальные в том числе.
Разница лишь в том, что в SQLite это будет проверено и будет встроена диагностика.
Go to the top of the page
 
+Quote Post
SortoVaritu
сообщение Nov 3 2011, 12:29
Сообщение #12


Участник
*

Группа: Участник
Сообщений: 44
Регистрация: 4-11-10
Пользователь №: 60 647



Я вообщем говорю даже не о самопальной или профессиональной базе, а вообще о ее необходимости. То есть насколько большое количество данных надо структурировать. То есть если у меня к примеру есть только 100 значений данных, то нужна ли для этого база данных...
Go to the top of the page
 
+Quote Post
AlexandrY
сообщение Nov 3 2011, 15:02
Сообщение #13


Ally
******

Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050



Цитата(SortoVaritu @ Nov 3 2011, 14:29) *
Я вообщем говорю даже не о самопальной или профессиональной базе, а вообще о ее необходимости. То есть насколько большое количество данных надо структурировать. То есть если у меня к примеру есть только 100 значений данных, то нужна ли для этого база данных...


Да хоть даже по 10 значений но в 10-и таблицах и сразу почувствуете необходимость в базе данных.


Go to the top of the page
 
+Quote Post
SortoVaritu
сообщение Nov 3 2011, 17:09
Сообщение #14


Участник
*

Группа: Участник
Сообщений: 44
Регистрация: 4-11-10
Пользователь №: 60 647



Хм.... Возможно... Если честно то никогда не задумывался о реализации БД в микроконтроллерах.
Go to the top of the page
 
+Quote Post
Буратино
сообщение Dec 2 2011, 07:52
Сообщение #15


Профессионал
*****

Группа: Свой
Сообщений: 1 433
Регистрация: 27-10-08
Из: Украина, Киев
Пользователь №: 41 215



Цитата(AlexandrY @ Nov 3 2011, 14:14) *
Тут просто недопонимание.
SQLite не зависит от типа носителя, там все кончается абстракцией называемой "виртуальная файловая система" VFS.
Все что ниже разработчик пишет сам.
В примерах SQLite сразу работает с Flash накопителями.

Но реально тягаться с SQLite в быстроте самопальными на скорую руку методами, IMHO, бессмысленно.

А то что там нужен адекватный большой heap в ОЗУ, так это любые базы данных требуют и самопальные в том числе.
Разница лишь в том, что в SQLite это будет проверено и будет встроена диагностика.


Сейчас контроллеры с каждым годом все шире становятся и по памяти программ и по памяти данных. Ну вот на СУБД мне лично не жалко ресурсов. Попробую почитать что там пишут в доках на SQLite, но реально нереально мне поднять такую тему на проце без оси (да и наверное с осью то же).
Единственный вариант прокачать эту дело - это заручиться поддержкой опытных и знающих специалистов, и имея пример реализации попытаться решить этот вопрос в своих проектах.


--------------------
Брак - это такой вид отношений, в которых один всегда прав, - а другой - муж.
Go to the top of the page
 
+Quote Post

2 страниц V   1 2 >
Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 18th July 2025 - 10:50
Рейтинг@Mail.ru


Страница сгенерированна за 0.0148 секунд с 7
ELECTRONIX ©2004-2016