Mysql
 sql >> Database >  >> RDS >> Mysql

Utilizzo di un convertitore personalizzato per DSL.val() di JOOQ

Soluzione:utilizzare DSL.val(java.lang.Object value, DataType<T> type) invece di solo DSL.val(java.lang.Object value)

Di seguito è riportato lo snippet di codice aggiornato

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();
}