Показать сообщение отдельно
  #1  
Старый 12.01.2012, 17:23
Rat Rat вне форума
Активный
 
Регистрация: 12.09.2008
Сообщения: 391
Репутация: 6078
По умолчанию Организация очереди для записи в БД

Коллеги, как думаете, как мне лучше реализовать следующее?:

Есть некоторое устройство, с которого по TCPIP каждые 100ms с помощью таймера, считывается значение = 4 байтам. (В дальнейшем предполагается что количество считываемых значений может быть несколько, т.е. должно конфигурироваться).

Ну так вот. Все значения, которые приходят с устройства, необходимо как можно быстрее, записывать в базу данных в одну таблицу, соответственно в таком виде: Id записи, Id переменной, значение, время.

Если сразу писать в базу одно значение, то вроде как всё ОК. всё записывается, всё успевает. Но если несколько, то уже не успевает.

Логично предположить, что необходимо создать некий буфер, который после накопления, будет скидываться в базу данных. Опять же существует вероятность, что при скидывании буфера, данные приходящие в это время, будут потеряны. Поэтому необходимо создать два буфера. Накапливаем один, после накопления, скидываем его в базу, в это время накапливая второй. Ну и всё повторяется заново.
Как думаете, это лучшее решение или есть какие то еще мысли?
Ответить с цитированием