All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.fluentjdbc.DatabaseQueryBuilder Maven / Gradle / Ivy

There is a newer version: 0.5.3
Show newest version
package org.fluentjdbc;

import javax.annotation.Nonnull;
import java.sql.Connection;
import java.time.Instant;
import java.util.Optional;

/**
 * Interface for consistent query operations in a fluent way
 */
public interface DatabaseQueryBuilder> extends DatabaseQueriable {

    /**
     * If you haven't called {@link #orderBy}, the results of {@link DatabaseListableQueryBuilder#list}
     * will be unpredicable. Call unordered() if you are okay with this.
     */
    DatabaseListableQueryBuilder unordered();

    /**
     * Adds an order by clause to the query. Needed in order to list results
     * in a predicatable order.
     */
    DatabaseListableQueryBuilder orderBy(String orderByClause);

    /**
     * If the query returns no rows, returns `null`, if exactly one row is returned, maps it and return it,
     * if more than one is returned, throws `IllegalStateException`
     *
     * @param connection Database connection
     * @param mapper Function object to map a single returned row to a object
     * @return the mapped row if one row is returned, Optional.empty otherwise
     * @throws IllegalStateException if more than one row was matched the the query
     */
    @Nonnull
     Optional singleObject(Connection connection, DatabaseTable.RowMapper mapper);

    /**
     * Returns a string from the specified column name
     *
     * @param connection Database connection
     * @return the mapped row if one row is returned, Optional.empty otherwise
     * @throws IllegalStateException if more than one row was matched the the query
     */
    @Nonnull
    default Optional singleString(Connection connection, String fieldName) {
        return singleObject(connection, row -> row.getString(fieldName));
    }

    /**
     * Returns a long from the specified column name
     *
     * @param connection Database connection
     * @return the mapped row if one row is returned, Optional.empty otherwise
     * @throws IllegalStateException if more than one row was matched the the query
     */
    @Nonnull
    default Optional singleLong(Connection connection, final String fieldName) {
        return singleObject(connection, (DatabaseTable.RowMapper) row -> row.getLong(fieldName));
    }

    /**
     * Returns an instant from the specified column name
     *
     * @param connection Database connection
     * @return the mapped row if one row is returned, Optional.empty otherwise
     * @throws IllegalStateException if more than one row was matched the the query
     */
    @Nonnull
    default Optional singleInstant(Connection connection, final String fieldName) {
        return singleObject(connection, row -> row.getInstant(fieldName));
    }

}