mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
0306f4508f
* Adds a dynamic package import so JDBC drivers on the classpath can be used * Upgrades OpenJPA from 2.4.0 to 3.2.2 * Upgrades Derby JDBC driver from 10.11.1.1 to 10.16.1.1 * Adds config.xml and ConfigurableService annotation so add-on can be configured using the UI * Adds null annotations on all classes * Prevent NPEs and some code cleanup See also: * https://openjpa.apache.org/builds/3.2.2/apache-openjpa/RELEASE-NOTES.html * https://community.openhab.org/t/jpa-with-mysql-or-mariadb/138679 Fixes #13375 Signed-off-by: Wouter Born <github@maindrain.net>
46 lines
2.9 KiB
Markdown
46 lines
2.9 KiB
Markdown
# Java Persistence API (JPA) Persistence
|
|
|
|
This service allows you to persist state updates using a SQL or NoSQL database through the [Java Persistence API](https://en.wikipedia.org/wiki/Java_Persistence_API).
|
|
The service uses an abstraction layer that theoretically allows it to support many available SQL or NoSQL databases.
|
|
|
|
It will create one table named `historic_item` where all item states are stored.
|
|
The item state is stored in a string representation.
|
|
|
|
The service currently supports Apache Derby, MariaDB, MySQL and PostgreSQL databases.
|
|
Only the embedded Apache Derby database driver is included.
|
|
Other drivers must be installed manually.
|
|
(See below for more information on that.)
|
|
|
|
## Configuration
|
|
|
|
This service can be configured in the file `services/jpa.cfg`.
|
|
|
|
| Property | Default | Required | Description |
|
|
| ------------ | ------- | :-------: | ------------------------------------------------------------ |
|
|
| url | | Yes | JDBC connection URL. Examples:<br/><br/>`jdbc:derby://hab.local:1527/openhab;create=true`<br/>`jdbc:mariadb://localhost:3306/openhab`<br/>`jdbc:mysql://localhost:3306/openhab`<br/>`jdbc:postgresql://hab.local:5432/openhab` |
|
|
| driver | | Yes | database driver. Examples:<br/><br/>`com.mysql.jdbc.Driver`<br/>`org.apache.derby.jdbc.ClientDriver``org.mariadb.jdbc.Driver`<br/><br/>`org.postgresql.Driver`<br/></br>Only the Apache Derby driver is included with the service. Drivers for other databases must be installed manually. This is a trivial process. Normally JDBC database drivers are packaged as OSGi bundles and can just be dropped into the `addons` folder. This has the advantage that users can update their drivers as needed. The following database drivers are known to work:<br/><br/>`postgresql-9.4-1203-jdbc41.jar`<br/>`postgresql-9.4-1206-jdbc41.jar` |
|
|
| user | | if needed | database user name for connection |
|
|
| password | | if needed | database user password for connection |
|
|
| syncmappings | | if needed | The OpenJPA synchronize mappings configuration |
|
|
|
|
## Adding support for other JPA supported databases
|
|
|
|
All item- and event-related configuration is done in the file `persistence/jpa.persist`.
|
|
|
|
If a database driver is not an OSGi bundle, the technique below can be used to extend the openHAB classpath.
|
|
|
|
Other database drivers can be added by expanding the openHAB classpath.
|
|
|
|
Use the following classpath setup in start.sh / start_debug.sh of openHAB:
|
|
|
|
```
|
|
cp=$(echo lib/*.jar | tr ' ' ':'):$(find $eclipsehome -name "org.eclipse.equinox.launcher_*.jar" | sort | tail -1);
|
|
```
|
|
|
|
This will add all .jar files in a folder "lib" in the root of openhab.
|
|
|
|
All databases that are supported by JPA can be added.
|
|
|
|
Define `driver` and `url` according to the database definitions.
|
|
|