- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们有一个实体,其中包含附加(简单)逻辑,例如在 UI 中使用。该实体是 LegalForm,它包含两个字段,如果该实体属于特定类型,则在数据库和代码中查询以检索这两个字段:
public class LegalForm {
@Column
private String type;
@Column
private String subType;
public boolean isCorporation() {
return type.equals("PLC") ||
type.equals("FC") && (subType.equals("PLC") ||
subType.equals("LTD"));
}
}
上面的代码片段显示了 isCorporation 方法,该方法在 UI 中调用以确定给定 Company 的类型,主要用于具体的、已加载的实体。我们希望使用 CriteriaBuilder 确定数据库中的所有公司,找到所有公司并将其用于进一步处理。
关于如何在 CriteriaBuilder 中利用实体中所示的相同逻辑有任何提示吗?
显然,我们可以尝试在导入外部过程中添加这些字段,然后在查询这些计算字段时添加这些字段。还有别的办法吗?
更新
虽然 @Emre 的以下答案是完全正确的,但这不是我们想要达到的目标。我们希望只对整个业务逻辑进行一次编程,而不是再次对 HQL/SQL/CriteriaBuilder 中已经实现的逻辑进行重新编程。所以基本上我问的是如何只对逻辑进行一次编程并在实体和 CriteriaBuilder 中重用它。
应该更清楚地说明这一点。
最佳答案
据我了解,您正在尝试生成等于您的 isCorporation() 方法计算的查询。
生成的sql查询:
Hibernate:
select
legalform0_.id as id1_0_,
legalform0_.subType as subType2_0_,
legalform0_.type as type3_0_
from
LegalForm legalform0_
where
legalform0_.type=?
or legalform0_.type=?
and (
legalform0_.subType in (
? , ?
)
)
数据库有如下三行:
select * from LegalForm;
+----+---------+------+
| id | subType | type |
+----+---------+------+
| 1 | XYZ | PLC |
| 2 | LTD | ABC |
| 3 | PLC | FC |
+----+---------+------+
以下代码提供的输出是:
LegalForm(id=1, type=PLC, subType=XYZ)
true
LegalForm(id=3, type=FC, subType=PLC)
true
代码:
package test;
import entity.LegalForm;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Expression;
import javax.persistence.criteria.Root;
import java.util.List;
public class Main {
public static void main(String[]args) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory("Hibernate_Jpa");
EntityManager em = emfactory.createEntityManager();
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<LegalForm> cq = cb.createQuery(LegalForm.class);
Root<LegalForm> legalForm = cq.from(LegalForm.class);
Expression<String> subTypeExp = legalForm.get("subType");
cq.where(
cb.or(cb.equal(legalForm.get("type"), "PLC"),
cb.and(cb.equal(legalForm.get("type"), "FC"), subTypeExp.in("PLC", "LTD"))));
TypedQuery<LegalForm> q = em.createQuery(cq);
List<LegalForm> allitems = q.getResultList();
allitems.forEach(x-> {
System.out.println(x);
System.out.println(x.isCorporation());
});
}
}
LegalForm 类:
@Entity
@Data
public class LegalForm {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
@Column
private String type;
@Column
private String subType;
public boolean isCorporation() {
return type.equals("PLC") ||
type.equals("FC") && (subType.equals("PLC") || subType.equals("LTD"));
}
}
持久性.xml:
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="Hibernate_Jpa" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
<class>entity.LegalForm</class>
<properties>
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/jpadb"/>
<property name="javax.persistence.jdbc.user" value="root"/>
<property name="javax.persistence.jdbc.password" value="root"/>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
<property name="hibernate.logging.level" value="FINE"/>
<property name="hibernate.show_sql" value="true"/>
<property name="hibernate.format_sql" value="true"/>
<property name="hibernate.ddl-generation" value="update"/>
<property name="hibernate.hbm2ddl" value="update"/>
</properties>
</persistence-unit>
</persistence>
关于java - JPA 和业务逻辑 - 在两个地方重用相同的条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51989134/
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
操作无法完成。 Places API 库中发生内部错误。如果您认为此错误代表错误,请使用我们社区和支持页面 (https://developers.google.com/places/support)
我正在尝试在我的项目中使用 google places,我将其设置在 fragment 中而不是 Activity 中,我的自动完成 fragment 在 fragment 中。但是,当我尝试搜索它时
我的目的是使用R来查询google api。 我有一个地址和名称列表(属于商店、餐馆等),我需要为每个地址和名称存储: “纬度”、“经度”、“业务类型” 我的想法是使用 google place ap
我正在寻找设置一个自动完成的谷歌地方小部件。 我有一个带有“searchFieldText”id 的输入类型文本。 这是我的 JS 代码: var inputsec = document.getEle
是否可以使用图形 API(或地址/ zip )按纬度/经度和半径获取地点?我在文档中的任何地方都看不到它 最佳答案 搜索 URL 的以下格式将返回某个位置附近的地点列表: https://graph.
我正在探索 Google API,主要是 Places API。由于对 Google Places API 的请求数限制为 100,000,因此我正在寻找方法来最大限度地减少发送到 API 的请求数。
伙计们,我在我的应用程序中有一个功能,可以使用 GetFiles 在特定目录中搜索特定文件。方法 System.IO.Directory.GetFiles(string path, string
我已经在 Laravel 5.3 上使用 where 查询成功创建了许多函数,但是这次发生了一些奇怪的事情。 public function show($id){ $artikel = Art
我正在为我的 iPhone 应用程序使用 Facebook 图形 API 来获取附近地点的列表,我使用带有一些参数的“搜索”请求。我得到的响应是一个包含以下信息的地点列表:“纬度”、“经度”、“名称”
我有一个 Android 应用程序,我在其中使用 Google map 显示附近的地方,如加油站、药店等。我正在使用 map 和地点 API。 https://maps.googleapis.com/
我是一名优秀的程序员,十分优秀!