Currently we only test PostgreSQL support. We need feedback and help to follow supporting other database backends.
Wether you choose to run Aggregate on Google App Engine or Tomcat, properly configured jdbc.properties
and odk-settings.xml
files must exist inside the WAR/EAR artifact.
You can find these files in src/main/resources
directories on each submodule.
If you want to work with Google App Engine and Google Big Table, just leave the file empty.
All three supported RDBs use the same configuration file structure. This is an example for PostgreSQL:
jdbc.driverClassName=org.postgresql.Driver
jdbc.resourceName=jdbc/odk_aggregate
jdbc.url=jdbc:postgresql://127.0.0.1/odk_db?autoDeserialize=true
jdbc.username=odk_unit
jdbc.password=test
jdbc.schema=odk_db
Driver class names are:
Database | Driver class name |
---|---|
PostgreSQL | org.postgresql.Driver |
MySQL | com.mysql.jdbc.Driver |
SQLServer | com.microsoft.sqlserver.jdbc.SQLServerDriver |
You have to make sure that the datastore
bean has the right class configured:
<bean id="datastore" class="org.opendatakit.common.persistence.engine.pgres.DatastoreImpl">
<!-- ... -->
</bean>
Table of posible values:
Database | Class |
---|---|
PostgreSQL | org.opendatakit.common.persistence.engine.pgres.DatastoreImpl |
MySQL | org.opendatakit.common.persistence.engine.mysql.DatastoreImpl |
SQLServer | org.opendatakit.common.persistence.engine.sqlserver.DatastoreImpl |
Google App Engine | org.opendatakit.common.persistence.engine.gae.DatastoreImpl |
Run the following SQL scripts to create and prepare a database to be used by Aggregate
PostgreSQL
CREATE USER "odk_unit" WITH PASSWORD 'test';
CREATE DATABASE odk_db WITH OWNER odk_unit;
GRANT ALL PRIVILEGES ON DATABASE odk_db TO odk_unit;
\connect odk_db;
CREATE SCHEMA odk_db;
GRANT ALL PRIVILEGES ON SCHEMA odk_db TO odk_unit;
MySQL
CREATE DATABASE `odk_db`;
CREATE USER 'odk_unit'@'localhost' IDENTIFIED BY 'test';
GRANT ALL ON `odk_db`.* TO 'odk_unit'@'localhost' IDENTIFIED BY 'test';
FLUSH PRIVILEGES;
SQLServer
USE master;
go
CREATE DATABASE odk_unit;
go
USE odk_unit;
go
CREATE SCHEMA odk_schema;
go