Maison  >  Article  >  Java  >  Comment les types d’énumération Java fonctionnent-ils avec le framework Spring ?

Comment les types d’énumération Java fonctionnent-ils avec le framework Spring ?

WBOY
WBOYoriginal
2024-05-04 13:45:011134parcourir

Le type d'énumération dans le framework Spring est utilisé pour représenter un ensemble de valeurs constantes prédéfinies. Il est principalement utilisé des manières suivantes : Déclarez le type d'énumération et utilisez l'annotation @Enumerated pour spécifier la stratégie de persistance (EnumType.ORDINAL ou EnumType. STRING) Cas pratique : autorisations utilisateur Les types d'énumération peuvent être utilisés dans le système de gestion pour représenter les autorisations utilisateur, et l'annotation @CollectionTable peut être utilisée pour s'associer au modèle utilisateur afin de gérer facilement les autorisations utilisateur et de conserver les constantes d'énumération.

Java 枚举类型如何与 Spring 框架配合使用?

L'utilisation des types d'énumération Java dans le framework Spring

Dans le framework Spring, les types d'énumération sont utilisés pour représenter un ensemble de valeurs constantes prédéfinies, telles que :

public enum Role {
    ADMIN,
    USER,
    GUEST
}

Types d'énumération et framework Spring Le principal Les façons de l'utiliser ensemble sont les suivantes :

1 Déclarez un type d'énumération

Tout d'abord, vous devez déclarer un type d'énumération :

public enum Role {

    // 枚举常量
    ADMIN,
    USER,
    GUEST
}

2. Utilisez l'annotation @Enumerated @Enumerated 注解

在使用枚举类型之前,你需要使用 @Enumerated 注解指定其持久化策略。Spring 提供了两种策略:

  • EnumType.ORDINAL:将枚举常量的顺序值存储在数据库中(从 0 开始)。
  • EnumType.STRING:将枚举常量的字符串值存储在数据库中。
@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Enumerated(EnumType.STRING)
    private Role role;
}

实战案例:用户权限管理

考虑一个用户权限管理系统,其中用户可以拥有不同的权限。你可以使用以下枚举类型来表示权限:

public enum Permission {
    READ,
    WRITE,
    DELETE
}

然后,可以将 Permission 枚举类型与用户模型关联:

@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String username;
    private String password;

    @Enumerated(EnumType.STRING)
    @CollectionTable(
            name = "user_permissions",
            joinColumns = @JoinColumn(name = "user_id")
    )
    @Column(name = "permission")
    private Set<Permission> permissions;
}

User 类中,permissions 属性是一个 Set4021e4fcee2d18f954cbe4ec9db50982,用于存储用户的权限。通过使用 @CollectionTable.

in Avant d'utiliser un type énuméré, vous devez spécifier sa stratégie de persistance à l'aide de l'annotation @Enumerated. Spring propose deux stratégies :

  • EnumType.ORDINAL : stocke les valeurs séquentielles des constantes d'énumération dans la base de données (en commençant par 0).
  • EnumType.STRING : stocke la valeur de chaîne d'une constante d'énumération dans la base de données.
rrreee🎜🎜Cas pratique : Gestion des droits des utilisateurs🎜🎜🎜Considérons un système de gestion des droits des utilisateurs dans lequel les utilisateurs peuvent avoir différents droits. Vous pouvez utiliser le type d'énumération suivant pour représenter les autorisations : 🎜rrreee🎜 Vous pouvez ensuite associer le type d'énumération Permission au modèle utilisateur : 🎜rrreee🎜Dans la classe Utilisateur, permissions est un Set4021e4fcee2d18f954cbe4ec9db50982 utilisé pour stocker les autorisations de l'utilisateur. En utilisant l'annotation @CollectionTable, Spring utilisera une table auxiliaire pour stocker la relation entre les utilisateurs et les autorisations. 🎜🎜De cette façon, vous pouvez facilement gérer les autorisations des utilisateurs et utiliser la fonction de conversion automatique de Spring pour convertir entre les objets persistants et les constantes d'énumération. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn