-
Notifications
You must be signed in to change notification settings - Fork 9
Setting up a database
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 class.
todo