sql >> Database >  >> RDS >> Mysql

EnumSet toewijzen aan mysql Set met behulp van JPA 2.1

Heel erg bedankt! Ik moest een iets andere versie gebruiken die je hier hebt. Wat voor mij werkte was:

Ik had een opsomming van rechten die aanpasbaar moesten zijn:

@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. uitvoeringscontext van database-trigger in PostgreSQL

  2. Hoe installeer ik luasql op Linux CentOS 7?

  3. Dubbele rijen verwijderen uit MySql-tabel

  4. SQL Server - na invoegen trigger - update een andere kolom in dezelfde tabel