Interface ModifiablePersistenceService
- All Superinterfaces:
- PersistenceService,- QueryablePersistenceService
PersistenceService to allow data to be stored
 at a specific time. This allows bindings that interface to devices that store data internally,
 and then periodically provide it to the server to be accommodated.- Author:
- Chris Jackson - Initial contribution, Mark Herwege - Implement aliases
- 
Method SummaryModifier and TypeMethodDescriptionbooleanremove(FilterCriteria filter) Removes data associated with an item from a persistence service.default booleanremove(FilterCriteria filter, @Nullable String alias) Removes data associated with an item from a persistence service.voidstore(Item item, ZonedDateTime date, State state) Stores the historic item value.voidstore(Item item, ZonedDateTime date, State state, @Nullable String alias) Stores the historic item value under a specified alias.Methods inherited from interface org.openhab.core.persistence.PersistenceServicegetDefaultStrategies, getId, getLabel, store, storeMethods inherited from interface org.openhab.core.persistence.QueryablePersistenceServicegetItemInfo, persistedItem, query, query
- 
Method Details- 
storeStores the historic item value. This allows the item, time and value to be specified. Adding data with the same time as an existing record should update the current record value rather than adding a new record. Implementors should keep in mind that all registered PersistenceServices are called synchronously. Hence long running operations should be processed asynchronously. E.g.storeadds things to a queue which is processed by some asynchronous workers (Quartz Job, Thread, etc.).- Parameters:
- item- the data to be stored
- date- the date of the record
- state- the state to be recorded
 
- 
storeStores the historic item value under a specified alias. This allows the item, time and value to be specified. Adding data with the same time as an existing record should update the current record value rather than adding a new record. Implementors should keep in mind that all registered PersistenceServices are called synchronously. Hence long running operations should be processed asynchronously. E.g.storeadds things to a queue which is processed by some asynchronous workers (Quartz Job, Thread, etc.).- Parameters:
- item- the data to be stored
- date- the date of the record
- state- the state to be recorded
 
- 
removeRemoves data associated with an item from a persistence service. If all data is removed for the specified item, the persistence service should free any resources associated with the item (e.g. remove any tables or delete files from the storage). If the persistence service implementing this method supports aliases for item names, the default implementation ofremove(FilterCriteria, String)should be overriden as well.- Parameters:
- filter- the filter to apply to the data removal. ItemName can not be null.
- Returns:
- true if the query executed successfully
- Throws:
- IllegalArgumentException- if item name is null.
 
- 
removedefault boolean remove(FilterCriteria filter, @Nullable String alias) throws IllegalArgumentException Removes data associated with an item from a persistence service. If all data is removed for the specified item, the persistence service should free any resources associated with the item (e.g. remove any tables or delete files from the storage). Persistence services supporting aliases, and relying on lookups in the item registry, should override the default implementation from this interface.- Parameters:
- filter- the filter to apply to the data removal. ItemName can not be null.
- alias- for item name in database
- Returns:
- true if the query executed successfully
- Throws:
- IllegalArgumentException- if item name is null.
 
 
-