`
ssydxa219
  • 浏览: 622297 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

JPA 注释

    博客分类:
  • jpa
 
阅读更多

JPA 注释

本文的主要内容如下:

详细解释了下面9个批注的含义及其批注所包含的属性:
@MapKey
@MappedSuperclass
@NamedNativeQueries
@NamedNativeQuery
@NamedQueries
@NamedQuery
@OneToMany
@OneToOne
@OrderBy
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■

 

@MapKey

默认情况下,JPA 持续性提供程序假设关联实体的主键为 java.util.Map 类型的关联的 Map 键:

如果主键是批注为 @Id 的非复合主键,则该字段或属性的类型实例将用作 Map 键。

如果主键是批注为 @IdClass 的复合主键,则主键类的实例将用作 Map 键。

使用 @MapKey 批注:

● 将某个其他字段或属性指定为 Map 键(如果关联实体的主键不适合于应用程序)

● 指定一个嵌入的复合主键类(请参阅 @EmbeddedId)

● 指定的字段或属性必须具有唯一约束(请参阅 @UniqueConstraint)。

表 1-24 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-24 @MapKey 属性

 

属性

必需

说明

name

默认值:默认情况下,JPA 持续性提供程序将关联实体的主键作为 Map 键,以用于映射到非复合主键或复合主键(批注为 @IdClass)的 java.util.Map 的属性或字段。
如果要将某个其他字段或属性用作 Map 键,请将 name 设置为要使用的关联实体的 String 字段或属性名。

在 示例 1-52 中,Project 对作为 Map 的 Employee 实例拥有一对多关系。示例 1-52 显示了如何使用 @MapKey 批注指定此 Map 的键为 Employee 字段 empPK,它是一个类型为 EmployeePK(请参阅示例 1-52)的嵌入式复合主键(请参阅示例 1-51)。

示例 1-50 使用 @MapKey 的 Project 实体

@Entity
public class Project {
    ...
    @OneToMany(mappedBy="project")   
    @MapKey(name="empPK")
    public Map<EmployeePK, Employee> getEmployees() {
    ...
    }
    ...
}

示例 1-51 Employee 实体

@Entity
public class Employee {
    @EmbeddedId
    public EmployeePK getEmpPK() {
     ...
    }
    ...
    @ManyToOne
    @JoinColumn(name="proj_id")
    public Project getProject() {
    ...
    }
...
}

示例 1-52 EmployeePK 复合主键类

@Embeddable
public class EmployeePK {
    String name;
    Date birthDate;
}

@MappedSuperclass

默认情况下,JPA 持续性提供程序假设实体的所有持久字段均在该实体中定义。

使用 @MappedSuperclass 批注指定一个实体类从中继承持久字段的超类。当多个实体类共享通用的持久字段或属性时,这将是一个方便的模式。

您可以像对实体那样使用任何直接和关系映射批注(如 @Basic 和 @ManyToMany)对该超类的字段和属性进行批注,但由于没有针对该超类本身的表存在,因此这些映射只适用于它的子类。继承的持久字段或属性属于子类的表。

可以在子类中使用 @AttributeOverride 或 @AssociationOverride 批注来覆盖超类的映射配置。

该批注没有属性。有关更多详细信息,请参阅 API

示例 1-53 显示了如何使用此批注将 Employee 指定为映射超类。示例 1-54 显示了如何扩展实体中的此超类,以及如何在实体类中使用 @AttributeOverride 以覆盖超类中设置的配置。

示例 1-53 @MappedSuperclass

@MappedSuperclass
public class Employee {
@Id
protected Integer empId;

@Version
protected Integer version;

@ManyToOne
@JoinColumn(name="ADDR")
protected Address address;

public Integer getEmpId() {
        ...
    }

public void setEmpId(Integer id) {
        ...
    }

public Address getAddress() {
        ...
    }

public void setAddress(Address addr) {
        ...
    }
}

示例 1-54 扩展 @MappedSuperclass

@Entity
@AttributeOverride(name="address", column=@Column(name="ADDR_ID"))
public class PartTimeEmployee extends Employee {

@Column(name="WAGE")
protected Float hourlyWage;

public PartTimeEmployee() {
        ...
    }

public Float getHourlyWage() {
        ...
    }

public void setHourlyWage(Float wage) {
        ...
    }
}


@NamedNativeQueries

如果需要指定多个 @NamedNativeQuery,则必须使用一个 @NamedNativeQueries 批注指定所有命名查询。

表 1-25 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-25 @NamedNativeQueries 属性

 

属性

必需

说明

value

要指定两个或更多属性覆盖,请将 value 设置为 NamedNativeQuery 实例数组(请参阅 @NamedNativeQuery)。

示例 1-55 显示了如何使用此批注指定两个命名原生查询。

示例 1-55 @NamedNativeQueries

@Entity
@NamedNativeQueries({
@NamedNativeQuery(
name="findAllPartTimeEmployees",
query="SELECT * FROM EMPLOYEE WHERE PRT_TIME=1"
    ),
@NamedNativeQuery(
name="findAllSeasonalEmployees",
query="SELECT * FROM EMPLOYEE WHERE SEASON=1"
    )
})
public class PartTimeEmployee extends Employee {
    ...
}


@NamedNativeQuery

在使用 JPA 持续性提供程序的应用程序中,可以使用实体管理器动态创建和执行查询,也可以预定义查询并在运行时按名称执行。

使用 @NamedNativeQuery 批注创建与 @Entity 或 @MappedSuperclass 关联的预定义查询,这些查询:

● 使用基础数据库的原生 SQL

● 经常被使用

● 比较复杂并且难于创建

● 可以在不同实体之间共享

● 返回实体、标量值或两者的组合(另请参阅 @ColumnResult、@EntityResult、@FieldResult 和@SqlResultSetMapping)

如果有多个要定义的 @NamedNativeQuery,则必须使用 @NamedNativeQueries。

要预定义适合于任何数据库的可移植查询,请参阅 @NamedQuery。

表 1-26 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-26 @NamedNativeQuery 属性

 

属性

必需

说明

query

要指定查询,请将 query 设置为 SQL 查询(作为 String)。
有关原生 SQL 查询语言的详细信息,请参阅数据库文档。 hints

默认值:空 QueryHint 数组。
默认情况下,JPA 持续性提供程序假设 SQL 查询应完全按照 query 属性提供的方式执行。
要微调查询的执行,可以选择将 hints 设置为一个 QueryHint 数组(请参阅 @QueryHint)。在执行时,EntityManager 将向基础数据库传递提示。 name

要指定查询名称,请将 name 设置为所需的 String 名称。
这是您在运行时调用查询所使用的名称(请参阅示例 1-56)。 resultClass

默认值:JPA 持续性提供程序假设结果类是关联实体的 Class。
要指定结果类,请将 resultClass 设置为所需的 Class。 resultSetMapping

默认值:JPA 持续性提供程序假设原生 SQL 查询中的 SELECT 语句:返回一个类型的实体;包括与返回的实体的所有字段或属性相对应的所有列;并使用与字段或属性名称(未使用 AS 语句)相对应的列名。
要控制 JPA 持续性提供程序如何将 JDBC 结果集映射到实体字段或属性以及标量,请通过将 resultSetMapping 设置为所需的 @SqlResultSetMapping 的 String 名称来指定结果集映射。

示例 1-56 显示了如何使用 @NamedNativeQuery 批注定义一个使用基础数据库的原生 SQL 的查询。示例 1-57 显示了如何使用 EntityManager 获取此查询以及如何通过 Query 方法 getResultList 执行该查询。

示例 1-56 使用 @NamedNativeQuery 实现一个 Oracle 层次查询

@Entity
@NamedNativeQuery(
name="findAllEmployees",
query="SELECT * FROM EMPLOYEE"
)
public class Employee implements Serializable {
    ...
}

示例 1-57 执行一个命名原生查询

Query queryEmployees = em.createNamedQuery("findAllEmployees");
Collection employees = queryEmployees.getResultList();

@NamedQueries

如果需要指定多个 @NamedQuery,则必须使用一个 @NamedQueries 批注指定所有命名查询。

表 1-27 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-27 @NamedQueries 属性

 

属性

必需

说明

value

要指定两个或更多属性覆盖,请将 value 设置为 NamedQuery 实例数组(请参阅 @NamedQuery)。

示例 1-58 显示了如何使用此批注指定两个命名查询。

示例 1-58 @NamedQueries

@Entity
@NamedQueries({
@NamedQuery(
name="findAllEmployeesByFirstName",
query="SELECT OBJECT(emp) FROM Employee emp WHERE emp.firstName = :firstname"
    ),
@NamedQuery(
name="findAllEmployeesByLasttName",
query="SELECT OBJECT(emp) FROM Employee emp WHERE emp.lasstName = :lastname"
    )
})
public class PartTimeEmployee extends Employee {
    ...
}

@NamedQuery

在使用 JPA 持续性提供程序的应用程序中,可以使用实体管理器动态创建和执行查询,也可以预定义查询并在运行时按名称执行。

使用 @NamedQuery 批注创建与 @Entity 或 @MappedSuperclass 关联的预定义查询,这些查询:

● 使用 JPA 查询语言(请参阅 JSR-000220 Enterprise JavaBeans v3.0 规范,第 4 章)进行基于任何基础数据库的可移植执行

● 经常被使用

● 比较复杂并且难于创建

● 可以在不同实体之间共享

● 只返回实体(从不返回标量值),并只返回一个类型的实体

如果有多个要定义的 @NamedQuery,则必须使用 @NamedQueries。

要在已知的基础数据库中预定义原生 SQL 查询,请参阅 @NamedNativeQuery。使用原生 SQL 查询,您可以返回实体(包括不同类型的实体)、标量值或同时返回两者。

表 1-28 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-28 @NamedQuery 属性

 

属性

必需

说明

query

要指定查询,请将 query 设置为 JPA 查询语言(作为 String)。
有关 JPA 查询语言的详细信息,请参阅 JSR-000220 Enterprise JavaBeans v.3.0 规范的第 4 章。 hints

默认值:空 QueryHint 数组。
默认情况下,JPA 持续性提供程序假设 SQL 查询应完全按照 query 属性提供的方式执行,而不管基础数据库如何。
如果您知道基础数据库在运行时的状态,则要微调查询的执行,可以选择将 hints 设置为 QueryHint 数组(请参阅 @QueryHint)。在执行时,EntityManager 将向基础数据库传递提示。 name

要指定查询名称,请将 name 设置为查询名称(作为 String)。
这是您在运行时调用查询所使用的名称(请参阅示例 1-59)。

示 例 1-59 显示了如何使用 @NamedQuery 批注定义一个JPA 查询语言查询,该查询使用名为 firstname 的参数。示例 1-60 显示了如何使用 EntityManager 获取此查询并使用 Query 方法 setParameter 设置 firstname 参数。

示例 1-59 使用 @NamedQuery 实现一个带参数的查询

@Entity
@NamedQuery(
name="findAllEmployeesByFirstName",
query="SELECT OBJECT(emp) FROM Employee emp WHERE emp.firstName = :firstname"
)
public class Employee implements Serializable {
    ...
}

示例 1-60 执行命名查询

Query queryEmployeesByFirstName = em.createNamedQuery("findAllEmployeesByFirstName");
queryEmployeeByFirstName.setParameter("firstName", "John");
Collection employees = queryEmployessByFirstName.getResultList();

@OneToMany

默认情况下,JPA 为具有一对多多重性的多值关联定义一个 OneToMany 映射。

使用 @OneToMany 批注:

● 将获取类型配置为 LAZY

● 由于所使用的 Collection 不是使用一般参数定义的,因此配置关联的目标实体

● 配置必须层叠到关联目标的操作:例如,如果删除了拥有实体,则确保还删除关联的目标

● 配置持续性提供程序对单向一对多关系使用的连接表(请参阅 @JoinTable)的详细信息

表 1-29 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-29 @OneToMany 属性

 

属性

必需

说明

cascade

默认值:CascadeType 的空数组。
默认情况下,JPA 不会将任何持续性操作层叠到关联的目标。
如果希望某些或所有持续性操作层叠到关联的目标,请将 cascade 设置为一个或多个 CascadeType 实例,其中包括:
● ALL - 针对拥有实体执行的任何持续性操作均层叠到关联的目标。
● MERGE - 如果合并了拥有实体,则将 merge 层叠到关联的目标。
● PERSIST - 如果持久保存拥有实体,则将 persist 层叠到关联的目标。
● REFRESH - 如果刷新了拥有实体,则 refresh 为关联的层叠目标。
● REMOVE - 如果删除了拥有实体,则还删除关联的目标。
fetch

默认值:FetchType.EAGER。
默认情况下,JPA 持续性提供程序使用获取类型 EAGER:它要求持续性提供程序运行时必须急性获取数据。
如果这不适合于应用程序或特定的持久字段,请将 fetch 设置为 FetchType.LAZY:它提示持续性提供程序在首次访问数据(如果可以)时应惰性获取数据。 mappedBy

默认值:如果关系是单向的,则该持续性提供程序确定拥有该关系的字段。
如果关系是双向的,则将关联相反(非拥有)方上的 mappedBy 元素设置为拥有此关系的字段或属性的名称(如示例 1-61 所示)。 targetEntity

默认值:使用一般参数定义的 Collection 的参数化类型。
默认情况下,如果使用通过一般参数定义的 Collection,则持续性提供程序将从被引用的对象类型推断出关联的目标实体。
如果 Collection 不使用一般参数,则必须指定作为关联目标的实体类:将关联拥有方上的 targetEntity 元素设置为作为关系目标的实体的 Class。

示例 1-61 和示例 1-62 显示了如何使用此批注在使用一般参数的 Customer(被拥有方)和 Order(拥有方)之间配置一个一对多映射。

示例 1-61 @OneToMany - 使用一般参数的 Customer 类

@Entity
public class Customer implements Serializable {
    ...
@OneToMany(cascade=ALL, mappedBy="customer")
public Set<Order> getOrders() {
return orders;
    }
    ...
}

示例 1-62 @ManyToOne - 使用一般参数的 Order 类

@Entity
public class Customer implements Serializable {
    ...
@ManyToOne
@JoinColumn(name="CUST_ID", nullable=false)
public Customer getCustomer() {
return customer;
    }
    ...
}


@OneToOne

默认情况下,JPA 为指向另一个具有一对一多重性的实体的单值关联定义一个 OneToOne 映射,并从被引用的对象类型推断出关联的目标实体。

使用 @OneToOne 批注:

● 将获取类型配置为 LAZY

● 如果空值不适合于应用程序,则将映射配置为禁止空值(针对非基元类型)

● 配置关联的目标实体(如果无法从被引用的对象类型推断出它)

● 配置必须层叠到关联目标的操作:例如,如果删除了拥有实体,则确保还删除关联的目标

表 1-30 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-30 @OneToOne 属性

 

属性

必需

说明

cascade

默认值:CascadeType 的空数组。
默认情况下,JPA 不会将任何持续性操作层叠到关联的目标。
如果希望某些或所有持续性操作层叠到关联的目标,请将 cascade 设置为一个或多个 CascadeType 实例,其中包括:
● ALL - 针对拥有实体执行的任何持续性操作均层叠到关联的目标。
● MERGE - 如果合并了拥有实体,则将 merge 层叠到关联的目标。
● PERSIST - 如果持久保存拥有实体,则将 persist 层叠到关联的目标。
● REFRESH - 如果刷新了拥有实体,则 refresh 为关联的层叠目标。
● REMOVE - 如果删除了拥有实体,则还删除关联的目标。
fetch

默认值:FetchType.EAGER。
默认情况下,JPA 持续性提供程序使用获取类型 EAGER:它要求持续性提供程序运行时必须急性获取数据。
如果这不适合于应用程序或特定的持久字段,请将 fetch 设置为 FetchType.LAZY:它提示持续性提供程序在首次访问数据(如果可以)时应惰性获取数据。 mappedBy

默认值:如果关系是单向的,则该持续性提供程序确定拥有该关系的字段。
如果关系是双向的,则将关联相反(非拥有)方上的 mappedBy 元素设置为拥有此关系的字段或属性的名称(如示例 1-64 所示)。

optional

默认值:true。
默认情况下,JPA 持续性提供程序假设所有(非基元)字段和属性的值可以为空。
如果这并不适合于您的应用程序,请将 optional 设置为 false。 targetEntity

默认值:JPA 持续性提供程序从被引用的对象类型推断出关联的目标实体。
如果持续性提供程序无法推断出目标实体的类型,则将关联的拥有方上的 targetEntity 元素设置为作为关系目标的实体的 Class。

示例 1-63 和示例 1-64 显示了如何使用此批注在 Customer(拥有方)和 CustomerRecord(被拥有方)之间配置一个一对一映射。

示例 1-63 @OneToOne - Customer 类

@Entity
public class Customer implements Serializable {
    ...
@OneToOne(optional=false)
@JoinColumn(name="CUSTREC_ID", unique=true, nullable=false, updatable=false)
public CustomerRecord getCustomerRecord() {
return customerRecord;
    }
    ...
}

示例 1-64 @OneToOne - CustomerRecord 类

@Entity
public class CustomerRecord implements Serializable {
    ...
@OneToOne(optional=false, mappedBy="customerRecord")
public Customer getCustomer() {
return customer;
    }
    ...
}


@OrderBy

默认情况下,JPA 持续性提供程序按关联实体的主键以升序顺序检索 Collection 关联的成员。

将 @OrderBy 批注与 @OneToMany 和 @ManyToMany 一起使用以便:

● 指定一个或多个作为排序依据的其他字段或属性

● 为每个这样的字段或属性名指定不同的排序(升序或降序)

表 1-31 列出了此批注的属性。有关更多详细信息,请参阅 API

表 1-31 @OrderBy 属性

 

属性

必需

说明

value

默认值:JPA 持续性提供程序按关联实体的主键以升序顺序检索 Collection 关联的成员。
如果要按某些其他字段或属性排序并指定了不同的排序,则将 value 设置为以下元素的逗号分隔列表:"property-or-field-name ASC|DESC”(请参阅示例 1-65)。

示 例 1-65 显示了如何使用 @OrderBy 批注指定 Project 方法 getEmployees 应按 Employee 字段 lastname 以升序顺序并按 Employee 字段 seniority 以降序顺序返回 Employee 的 List。示例 1-66 显示了默认情况下,Employee 方法 getProjects 按 Employee 主键 empId 以升序顺序返回 List。

示例 1-65 Project 实体

@Entity public class Project {
    ...
@ManyToMany
@OrderBy("lastname ASC", "seniority DESC")
public List<Employee> getEmployees() {
    ...
    };
    ...
}

示例 1-66 Employee 实体

@Entity public class Employee {
@Id
private int empId;
    ...
private String lastname;
    ...
private int seniority;
    ...
@ManyToMany(mappedBy="employees")
// By default, returns a List in ascending order by empId
public List<Project> getProjects() {
    ...
    };
    ...
}

分享到:
评论

相关推荐

    JPA注释说明带范例

    JavaEE 5 的JPA注释的参考手册,带配置范例。 本参考广泛引用了 JSR-220 Enterprise JavaBean 版本 3.0 Java 持续性 API 规范,以按类别汇总批注信息,并解释了何时以及如何使用这些批注来自定义 JPA 行为,以满足...

    学习struts2,hibernate3(jpa注释编程),spring2,ajax的经典项目.rar

    学习struts2,hibernate3(jpa注释编程),spring2,ajax的经典项目.rar 学习struts2,hibernate3(jpa注释编程),spring2,ajax的经典项目.rar

    学习struts2,hibernate3(jpa注释编程),spring2,ajax的经典实例

    通过JPA注释编程,可以将数据库表和Java类映射,减少了手动编写SQL语句的工作量。在企业级应用中,Hibernate提高了开发效率,降低了维护成本,尤其是在处理大数据量和复杂查询时。 3. JPA(Java Persistence API)...

    Eclipse中反向生成hibernate实体类+jpa注释

    本资源详细描述了Eclipse中反向生成hibernate实体类+jpa注释的详细过程,是一个不错的图文教程。

    jpa注解doc文档

    Jpa注解的各种jpa注释详解

    JPA 和 注释文档

    综上,JPA 和注释在 Java 开发中起到了至关重要的作用,它们简化了数据库操作,提供了元数据的声明方式,并通过自定义注释扩展了元数据的功能。理解和熟练运用这些注解,能够提高代码的可读性,降低维护成本,同时...

    SpringJPATest:一个混合 Spring、JPA、Hibernate 和 Postgresql 的教程测试项目

    本文档提供了有关如何将Spring与PostgreSQL和 JPA 注释一起使用的信息。第 1 章:项目结构该项目是一个虚拟项目,它读取PostgreSQL数据库中的一些用户信息(id、用户名和密码),并通过 GET 请求将它们作为 JSON ...

    学习SSH2经典实例的jar包2

    JPA注释编程简化了数据库表与实体类之间的映射,减少了XML配置,提高了开发效率。 **Spring2** 是一个全面的企业级应用开发框架,提供了依赖注入(DI)和面向切面编程(AOP)等核心特性。Spring2中的IoC容器管理着...

    学习SSH2经典实例的jar包1

    JPA(Java Persistence API)是Java标准,用于管理持久化数据,而Hibernate3支持JPA注释编程,使得开发者可以更方便地在实体类上定义数据存储规则,减少了手动编写SQL语句的需求。 Spring2是SSH2中的最后一个重要...

    hibernate-jpa-2.1-api-1.0.2.Final-API文档-中文版.zip

    赠送jar包:hibernate-jpa-2.1-api-1.0.2.Final.jar; 赠送原API文档:hibernate-jpa-2.1-api-1.0.2.Final-javadoc.jar;...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。

    spring基础

    如使用 JPA 注释配置 ORM 映射时,我们就不需要指定 PO 的属性名、类型等信息,如果关系表字段和 PO 属性名、类型都一致,您甚至无需编写任务属性映射信息——因为这些信息都可以通过 Java 反射机制获取。...

    hibernate逆向工程

    - 如果需要生成带有JPA注释的Java实体类,需要勾选`Generate JPA annotations`。 ##### 3.3 执行逆向工程 - **执行逆向工程**:完成上述配置后,点击工具栏上的逆向工程按钮来启动逆向工程过程。 - **检查生成的...

    学习SSH2经典实例的jar包5

    JPA(Java Persistence API)是Java EE中定义的一个标准,用于处理对象持久化,Hibernate3支持JPA注释编程,使得开发者可以通过在实体类上添加注解来实现数据访问。 Spring2是全面的企业级应用框架,它提供了依赖...

    struts2+spring2.5+jpa(基于注释)

    总的来说,"SSJ使用注释版"项目展示了如何利用Struts2、Spring2.5和JPA这三大框架,结合注解方式,构建一个现代Java Web应用。通过深入理解这些技术和注解的用法,开发者可以更高效地开发和维护复杂的业务系统。

    querydsl-entityql:QueryDSL EntityQL-JPA的本机查询构建器

    不喜欢JPA注释? 不用担心,EntityQL还支持Spring Data JDBC及其元数据! 想要使用Groovy或Kotlin? EntityQL支持它们,并能够为这些语言生成本机代码。 EntityQL可以: 用作任何现有JPA / Spring Data JDBC配置...

    spring-data-jpa-2.0.9.RELEASE-API文档-中文版.zip

    赠送jar包:spring-data-jpa-2.0.9.RELEASE.jar; 赠送原API文档:spring-data-jpa-2.0.9.RELEASE-javadoc.jar; 赠送源代码:spring-...人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。

    OpenJPA 2.2.1 API (CHM格式)

    反向映射 是指 OpenJPA 框架中提供的 org.apache.openjpa.jdbc.meta.ReverseMappingTool 工具从数据库表生成符合 JPA 标准要求的实体以及相应的对象 / 关系映射注释内容。 中间匹配 是指开发者负责创建数据库表、...

    扩展MyBatis JPA支持,简化CUID操作,增强SELECT分页查询

    扩展MyBatis JPA支持,简化CUID...MyBatis JPA Extra对MyBatis扩展JPA功能:Jakarta JPA 3注释简化CUID操作;Interceptor实现数据库SELECT分页查询;链式Query查询条件构造器;提供starter,简化SpringBoot集成;数据库支持

    play框架mvc模式

    Model 对象需要存储到持久化存储设备里,一般情况下他们或许还包含有一些 JPA 注释和 SQL 语句。 View 层 View 层把 Model 层渲染到一个适当的交互窗体,如典型的用户接口。一个 Model 可以有多个 Views,以实现...

Global site tag (gtag.js) - Google Analytics