sql >> Databáze >  >> RDS >> Mysql

Mapování EnumSet na mysql Set pomocí JPA 2.1

Díky moc! Musel jsem použít trochu jinou verzi, kterou máte zde. Co pro mě fungovalo, bylo:

Měl jsem výčet oprávnění, které bylo třeba upravit:

@Convert(converter = SetConverter.class)
@Column(name = "permission")
private EnumSet<Permission> permission;


//in a util and imported
...
@Converter
public static class SetConverter implements AttributeConverter<EnumSet<Permission>, String> {

    public String convertToDatabaseColumn(EnumSet<Permission> attribute) {
        StringBuilder sb = new StringBuilder();
        for (Permission c : attribute) { 
            sb.append(c + ",");
        }
        return sb.toString();
    }

    public EnumSet<Permission> convertToEntityAttribute(String dbData) {
        if (dbData == null) {
            dbData = "";
        }
        EnumSet<Permission> perm = EnumSet.of(Permission.DEFAULT); //default was a value I added.
        String[] persistencePermissions = StringUtils.trimAllWhitespace(dbData).toUpperCase().split(",");
        if (!StringUtils.isEmpty(StringUtils.trimAllWhitespace(dbData))) {
        try {
            for (String str : persistencePermissions) { 
            perm.add(Permission.valueOf(str));
        }}  
        catch (IllegalArgumentException IAE) {
            throw new Exception("INVALID_REQUEST");
        }}

        return perm;

    }

}


  1. java.sql.SQLException:Po ukončení sady výsledků v mysql

  2. Vložit novou položku do sloupce JSONB na základě hodnoty jiného pole - postgres

  3. Vyberte dotaz | Vyberte položky, které nezačínají číslem – MySQL

  4. PHP mysql vložit formát data