Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Usando conversor personalizado para DSL.val() do JOOQ


Solução:use DSL.val(java.lang.Object value, DataType<T> type) em vez de apenas DSL.val(java.lang.Object value)

Segue o trecho de código atualizado
public void copy(UUID source, UUID target) {
    DataType<UUID> uuidType = SQLDataType.BINARY
                                .asConvertedDataType(new UuidBinaryConverter());
    jooq.insertInto(PERSON)
            .columns(PERSON.ID, PERSON.FNAME, PERSON.LNAME)
            .select(select(val(target, uuidType), PERSON.FNAME, PERSON.LNAME)
                   .from(PERSON)
                   .where(PERSON.ID.eq(source)))
            .execute();
}