Mysql
 sql >> база данни >  >> RDS >> Mysql

Съпоставяне на EnumSet към mysql Set с помощта на JPA 2.1

Благодаря много! Трябваше да използвам малко по-различна версия от тази, която имате тук. Това, което проработи при мен, беше:

Имах Enum от разрешения, които трябваше да бъдат коригирани:

@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. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Модалът не се зарежда с помощта на javascript в php (CodeIgniter)

  2. Как да възстановим току-що изтритите редове в mysql?

  3. Кое е най-доброто кодиране на символи за японски език за DB, php и html дисплей?

  4. Извличане на mysql записи в html таблица с помощта на PHP

  5. ИЗЧИСЛЕТЕ ПРОЦЕНТ В SQL по група