Class GenericMapLoader<K,V> 
- Type Parameters:
- K- type of the key
- V- type of the value
- All Implemented Interfaces:
- MapLoader<K,,- V> - MapLoaderLifecycleSupport
- Direct Known Subclasses:
- GenericMapStore
MapLoader built
 on top of Hazelcast SQL engine.
 It works with any SQL connector supporting SELECT statements.
Usage:
 First define data connection, e.g. for JDBC use JdbcDataConnection:
 
Config config = new Config();
 config.addDataConnectionConfig(
   new DataConnectionConfig("mysql-ref")
     .setType("Jdbc")
     .setProperty("jdbcUrl", dbConnectionUrl)
 );
 Then create a Map with MapLoader using the GenericMapLoader implementation:
 
MapConfig mapConfig = new MapConfig(mapName);
 MapStoreConfig mapStoreConfig = new MapStoreConfig();
 mapStoreConfig.setClassName(GenericMapLoader.class.getName());
 mapStoreConfig.setProperty(GenericMapLoader.DATA_CONNECTION_REF_PROPERTY, "mysql-ref");
 mapConfig.setMapStoreConfig(mapStoreConfig);
 instance().getConfig().addMapConfig(mapConfig);The GenericMapLoader creates a SQL mapping with name "__map-store." + mapName. This mapping is removed when the map is destroyed.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected List<SqlColumnMetadata>static final StringProperty key to define column names in databasestatic final StringProperty key to define data connectionstatic final StringProperty key to define external name of the tablestatic final StringProperty key to define id column name in databasestatic final StringProperty key to control loading of all keys when IMap is first createdstatic final HazelcastPropertyTimeout for initialization of GenericMapLoaderstatic final StringProperty key to decide on getting a single column as the valueprotected SqlServicestatic final StringProperty key to data connection type name
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidAwaits successful initialization; if the initialization fails, throws an exception.voiddestroy()Hazelcast will call this method before shutting down.voidinit(HazelcastInstance instance, Properties properties, String mapName) Initializes this MapLoader implementation.Loads the value of a given key.loadAll(Collection<K> keys) Size of thekeyscollection is limited byClusterProperty.MAP_LOAD_CHUNK_SIZELoads all the keys from the store.
- 
Field Details- 
DATA_CONNECTION_REF_PROPERTYProperty key to define data connection- See Also:
 
- 
EXTERNAL_NAME_PROPERTYProperty key to define external name of the table- See Also:
 
- 
ID_COLUMN_PROPERTYProperty key to define id column name in database- See Also:
 
- 
COLUMNS_PROPERTYProperty key to define column names in database- See Also:
 
- 
TYPE_NAME_PROPERTYProperty key to data connection type name- See Also:
 
- 
LOAD_ALL_KEYS_PROPERTYProperty key to control loading of all keys when IMap is first created- See Also:
 
- 
SINGLE_COLUMN_AS_VALUEProperty key to decide on getting a single column as the value- See Also:
 
- 
MAPSTORE_INIT_TIMEOUTTimeout for initialization of GenericMapLoader
- 
sqlService
- 
columnMetadataList
 
- 
- 
Constructor Details- 
GenericMapLoaderpublic GenericMapLoader()
 
- 
- 
Method Details- 
initDescription copied from interface:MapLoaderLifecycleSupportInitializes this MapLoader implementation. Hazelcast will call this method when the map is first used on the HazelcastInstance. Implementation can initialize required resources for the implementing mapLoader, such as reading a config file and/or creating a database connection. References to maps, other than the one on which thisMapLoaderis configured, can be obtained from thehazelcastInstancein this method's implementation.On members joining a cluster, this method is executed during finalization of the join operation, therefore care should be taken to adhere to the rules for PostJoinAwareService.getPostJoinOperation(). If the implementation executes operations which may wait on locks or otherwise block (e.g. waiting for network operations), this may result in a time-out and obstruct the new member from joining the cluster. If blocking operations are required for initialization of theMapLoader, consider deferring them with a lazy initialization scheme.- Specified by:
- initin interface- MapLoaderLifecycleSupport
- Parameters:
- instance- HazelcastInstance of this mapLoader.
- properties- Properties set for this mapStore. see MapStoreConfig
- mapName- name of the map.
 
- 
destroypublic void destroy()Description copied from interface:MapLoaderLifecycleSupportHazelcast will call this method before shutting down. This method can be overridden to clean up the resources held by this map loader implementation, such as closing the database connections, etc.- Specified by:
- destroyin interface- MapLoaderLifecycleSupport
 
- 
loadDescription copied from interface:MapLoaderLoads the value of a given key. If distributed map doesn't contain the value for the given key then Hazelcast will call implementation's load (key) method to obtain the value. Implementation can use any means of loading the given key; such as an O/R mapping tool, simple SQL or reading a file etc.
- 
loadAllSize of thekeyscollection is limited byClusterProperty.MAP_LOAD_CHUNK_SIZE
- 
loadAllKeysDescription copied from interface:MapLoaderLoads all the keys from the store. The returnedIterablemay return the keys lazily by loading them in batches. TheIteratorof thisIterablemay implement theCloseableinterface in which case it will be closed once iteration is over. This is intended for releasing resources such as closing a JDBC result set.The returned Iterable should not contain any nullkeys.- Specified by:
- loadAllKeysin interface- MapLoader<K,- V> 
- Returns:
- all the keys. Keys inside the Iterable cannot be null.
 
- 
awaitSuccessfulInitprotected void awaitSuccessfulInit()Awaits successful initialization; if the initialization fails, throws an exception.
 
-