Mysql
 sql >> Base de données >  >> RDS >> Mysql

Utilisation d'un convertisseur personnalisé pour DSL.val() de JOOQ

Solution :utilisez DSL.val(java.lang.Object value, DataType<T> type) au lieu de simplement DSL.val(java.lang.Object value)

Voici l'extrait de code mis à jour

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