Skip to content

Latest commit

 

History

History
130 lines (107 loc) · 5.62 KB

README.md

File metadata and controls

130 lines (107 loc) · 5.62 KB

DatabaseUtils is a library that allows you to write Repository interfaces that support both SQL and No-SQL (MongoDB) databases. The implementation of the interface is automatically generated while compiling.

This readme will be expanded in the future with for example code examples, currently examples can be found in the tests of the AP module and the tests of the core module.

What's left to do?

  • make 'simple' actions like insert more flexible
    • support adding every variable of the entity as parameter
  • add upsert which either inserts the entity if it's not present or updates the already existing entity
  • adding migrations
  • add null and non-null support
  • and plenty more

Supported types

Every database type is responsible for providing support for at least:

  • Boolean
  • Byte
  • Short
  • Char
  • Integer
  • Long
  • Float
  • Double
  • String
  • Byte[]

Using TypeCodecRegistry the supported types can be expanded (each of them will be stored as a byte[]). The following types are added out of the box:

  • UUID

SQL

This project tries to support the following SQL dialects:

  • H2
  • (Microsoft) SQL Server
  • MariaDB
  • MySQL
  • Oracle Database
  • PostgreSQL
  • SQLite

However not everything is the same across dialects.

Missing functionality for specific dialects

TestEntity deleteByAAndB(String, String)

This currently doesn't work on MySQL (not MariaDB) and H2. This is caused by the lack of support for 'REPLACING' or a variant of it. We have to fetch a record first and then delete it (inside a transaction). The current codebase is not flexible enough to do these wildly different behaviours per dialect, but will be supported in the future.

any deleteFirst() and any deleteTop*()

Anything with a limit projection in delete currently doesn't work for Oracle Database, PostgreSQL, SQLite and SQL Server. For SQL Server it's TOP instead of LIMIT. For SQLite this is a flag that can be enabled during compile, but it's disabled by default. For Oracle and Postgres delete with a limit doesn't exist. We have to fetch a record first and then delete it (inside a transaction). The current codebase is not flexible enough to do these wildly different behaviours per dialect, but will be supported in the future.

any deleteOrderBy()

Anything with an order by in delete currently doesn't work for Oracle Database, SQL Server, H2 and SQLite. For SQLite this is a flag that can be enabled during compile, but it's disabled by default. For the others this functionality doesn't exist. We have to fetch a record first and then delete it (inside a transaction). The current codebase is not flexible enough to do these wildly different behaviours per dialect, but will be supported in the future.

Different data types across dialects

Not every data type has the same name / is available on each dialect. These are the base type conversions:

Java Type SQL type Reason / remarks
Boolean boolean More platforms support boolean than tinyint / bit
Byte tinyint SQL Server's tinyint is unsigned and PostgresSQL has no tinyint
Short smallint -
Char int Unlike short, char is unsigned
Integer int -
Long bigint -
Float real MySQL and MariaDB map this as a double precision type
Double double precision -
String varchar All dialects support varchar, but it's deprecated on OracleDB
Byte[] varbinary Most dialects support varbinary

And these are the exceptions:

Java Type Dialect SQL Type
Boolean SQLite int
Boolean SQL Server bit
Byte PostgreSQL smallint
Byte SQL Server smallint
Char MariaDB smallint unsigned
Char MySQL smallint unsigned
Char OracleDB number(5)
Double SQL Server float
String OracleDB varchar2
Byte[] OracleDB raw
Byte[] PostgreSQL bytea
Byte[] SQLite blob

Query syntax

Assuming we have the following entity called TestEntity:

Name Type Is Key?
a int Yes
b String Yes
c String No
d UUID No

delete

int/boolean delete(TestEntity) - delete single entity

If you delete a single entity, it'll look at the

TestEntity deleteByAAndB(a, b) - delete by key

If you delete by the key then you know for certain that there can at most be only one match.

List deleteByB(b) - delete by a non-unique column

If you delete by a non-unique column everything matching that column is deleted. Note that for the returning collection that not every database type has a defined order.

TestEntity deleteFirstByB(b) - delete by a non-unique column

If you delete by a non-unique column you have to specify first if your return type is a single row. Only use this if any match is fine, because not every database type has a defined order.