Skip to content

Setting up a database

NeumimTo edited this page Dec 5, 2015 · 15 revisions

All your database configuration is in a file database.properties. This file is located in a mods folder and generated during the first plugin startup.

The file looks like this: (Every line which starts with # character is a comment)

(Following example is for postgresql)

### Hibernate setup`
hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect
hibernate.hbm2ddl.auto = create-tables
hibernate.show_sql = false

### Hikari Connection pool setup
#Hikari is a connection pool, the library comes with sponge
#Do not change provider_class unless you know what are you doing.
hibernate.connection.provider_class = com.zaxxer.hikari.hibernate.HikariConnectionProvider
hibernate.hikari.minimumIdle = 5
hibernate.hikari.maximumPoolSize = 10
hibernate.hikari.idleTimeout = 30000

### PostgreSQL datasource *
#This is a datasource class, each database vendor has its own
#Do not forget to install jdbc driver(!) for your database
hibernate.hikari.dataSourceClassName = org.postgresql.ds.PGSimpleDataSource
hibernate.hikari.username = username
hibernate.hikari.password = password

### PGSimpleDataSource *(!!)
hibernate.hikari.dataSource.serverName=localhost
hibernate.hikari.dataSource.portNumber=5432
hibernate.hikari.dataSource.databaseName=dbname

* - Names of properties depend on a choosen database. Properties names will be different (more or less) for different types of databases

  • dialect - Represents which dialect will hibernate use.

  • hbm2.dll.auto: during the first startup make sure its value is create or create-tables, then change its value to update or validate

    • validate: validate the schema, makes no changes to the database.
    • update: update the schema.
    • create: creates the schema, destroying previous data.
    • create-drop: drop the schema at the end of the session.

Table of most common dialects:

RDBMS Dialect
DB2 org.hibernate.dialect.DB2Dialect
DB2 AS/400 org.hibernate.dialect.DB2400Dialect
DB2 OS390 org.hibernate.dialect.DB2390Dialect
PostgreSQL org.hibernate.dialect.PostgreSQLDialect
MySQL org.hibernate.dialect.MySQLDialect
MySQL with InnoDB org.hibernate.dialect.MySQLInnoDBDialect
MySQL with MyISAM org.hibernate.dialect.MySQLMyISAMDialect
Oracle (any version) org.hibernate.dialect.OracleDialect
Oracle 9i/10g org.hibernate.dialect.Oracle9Dialect
Sybase org.hibernate.dialect.SybaseDialect
Sybase Anywhere org.hibernate.dialect.SybaseAnywhereDialect
Microsoft SQL Server org.hibernate.dialect.SQLServerDialect
SAP DB org.hibernate.dialect.SAPDBDialect
Informix org.hibernate.dialect.InformixDialect
HypersonicSQL (also works for h2) org.hibernate.dialect.HSQLDialect
Ingres org.hibernate.dialect.IngresDialect
Progress org.hibernate.dialect.ProgressDialect
Mckoi SQL org.hibernate.dialect.MckoiDialect
Interbase org.hibernate.dialect.InterbaseDialect
Pointbase org.hibernate.dialect.PointbaseDialect
FrontBase org.hibernate.dialect.FrontbaseDialect
Firebird org.hibernate.dialect.FirebirdDialect
H2 org.hibernate.dialect.H2Dialect

If you would like to use a self-contained databse do not try to use litesql, use H2 instead

Example of database properties for mysql:

Todo

Example of database properties for H2:

Todo

Common failures:

  • java.lang.RuntimeException: java.lang.ClassNotFoundException: <datasource.class.name>
  • Jdbc driver is not installed.
  • You wrote wrong classpath to the datasource.

todo

Clone this wiki locally