sql >> Base de Datos >  >> RDS >> Mysql

Usando un convertidor personalizado para DSL.val() de JOOQ

Solución:use DSL.val(java.lang.Object value, DataType<T> type) en lugar de solo DSL.val(java.lang.Object value)

A continuación se muestra el fragmento de código actualizado

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