Skip to content

Latest commit

 

History

History
128 lines (104 loc) · 4.21 KB

RELEASE_NOTES.md

File metadata and controls

128 lines (104 loc) · 4.21 KB

Release notes

Improvements

  • #23: Implementation of Stored class.
// Reading 'Link' objects from db.
final List<Stored<Long, Link>> links = select
	.as(LINK_PARSER.stored("id").list(), conn);

// Printing the result + its DB ids.
links.forEach(System.out::println);

// > Stored[id=1, value=Link[http://jenetics.io, text=null, type=null]]
// > Stored[id=2, value=Link[http://jenetics.io, text=Jenetics, type=web]]
// > Stored[id=3, value=Link[https://duckduckgo.com, text=DuckDuckGo, type=search]]
  • #49: Implement PreparedQuery class.
final var query = INSERT_LINK.prepareQuery(conn);
final var batch = Batch.of(links, LINK_DCTOR);
query.execute(batch);

Bug

  • #23: Remove wrong null check in Param factory method.

Improvements

  • #21: Create Ctor instances from Record classes. It is now possible to create Ctor directly from record classes.
// Simple `Dctor` creation.
final Dctor<Book> dctor = Dctor.of(Book.class);

// Adapt the name conversion.
final Dctor<Book> dctor = Records.dctor(
    Book.class,
    component -> switch (component.getName()) {
        case "author" -> "primary_author";
        case "isbn" -> "isbn13";
        default -> Records.toSnakeCase(component);
    }
);

// Add additional columns.
final Dctor<Book> dctor = Records.dctor(
    Book.class,
    field("title_hash", book -> book.title().hashCode())
);
  • #43: Create RowParser instances from record classes.
// Simple `RowParser` creation.
final RowParser<Book> parser = RowParser.of(Book.class);

// Adapting the record component parsing.
final RowParser<Book> parser = Records.parserWithFields(
    Book.class,
    Map.of(
        "isbn", string("isbn").map(Isbn::new),
        "authors", int64("id").map(Author::selectByBookId)
    )
);
  • #45: Make RowParser composable.
  • #40: Allow streaming of selection results.
final var select = Query.of("SELECT * FROM person;");

// Make sure to close the returned stream.
try (var persons = select.as(PARSER.stream(), conn)) {
    // Do some processing with the person stream.
    persons.forEach(person -> ...);
}
  • #39: Parser for exporting results as CSV file/string.
final var select = Query.of("SELECT * FROM book;");
final var csv = select.as(ResultSetParser.csvLine(), conn);
System.out.println(csv);
  • #26: Implement multi-value parameter
final List<Book> results = Query.of("SELECT * FROM book WHERE id IN(:ids);")
    .on(Param.values("ids", 1, 2, 3, 4))
    .as(PARSER.list(), conn);

Improvements

Improvements

  • #24: Support for SQL type transformation methods.
  • #27: Allow to define the query timeout and fetch size.

Improvements

  • #15: Make the Query class serializable.
  • #17: Add lightwieght transaction functionality.
final Transactional db = () -> DriverManager.getConnection(
    "jdbc:hsqldb:mem:testdb",
    "SA",
    ""
);
db.transaction().accept(conn -> {
    for (var query : queries) {
        query.execute(conn);
    }
});
final long id = db.transaction().apply(conn ->
    Book.insert(BOOKS.get(0), conn)
);
  • #19: The original SQL string is reconstructible from the query object; Query.rawSql().