최대 절전 모드에서 Double Select의 문제
문제
(이중 변수)가있는 객체를 읽고 싶을 때 문제가 있습니다. 이것은 내 코드입니다.
지점 구축 테이블 :
@Entity
@Table(name = "branchbuilding", uniqueConstraints={@UniqueConstraint(columnNames={"buildingname","branch_fk"})})//uniqueConstraints={@UniqueConstraint(columnNames={"username","buildingname"})}
public class BranchBuildingEntity implements Serializable {
@Id
@GeneratedValue
private int id;
@Column(name = "buildingname", length = 64)
private String buildingName;
@Column(name = "description", columnDefinition = "mediumtext", length = 16777215)
private String description;
@Embedded
@AttributeOverrides({
@AttributeOverride(name = "bremainAdr", column = @Column(name = "bremainadr", columnDefinition = "mediumtext", length = 16777215, nullable=true)),
@AttributeOverride(name = "bmainStreet", column = @Column(name = "bmainstreet", length = 64, nullable=true)),
@AttributeOverride(name = "bstate", column = @Column(length = 64, nullable=true)),
@AttributeOverride(name = "bcity", column = @Column(length = 64, nullable=true)),
@AttributeOverride(name = "bcentralBuilding", column = @Column(name = "bcentralbuilding", columnDefinition = "tinyint", nullable=true)),
@AttributeOverride(name = "blongitude", column = @Column(nullable=true)),
@AttributeOverride(name = "blatitude", column = @Column(nullable=true))
})
Address buildingAdr;
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "branch_fk", referencedColumnName = "id", nullable = false)
private BranchEntity branch;
@OneToMany(mappedBy = "branchbuilding", fetch = FetchType.LAZY, cascade = CascadeType.ALL)
@OnDelete(action=OnDeleteAction.CASCADE)
@Cascade(org.hibernate.annotations.CascadeType.DELETE_ORPHAN)
private Set<BuildingTelEntity> buildingtel = new HashSet<BuildingTelEntity>();
//some setter and getter
Adrresse가 새벽 :
@Embeddable
public class Address implements Serializable {
String bstate;
String bcity;
String bmainStreet;
String bremainAdr;
double blongitude;
double blatitude;
int bcentralBuilding;
//Some getter and Setter
이것은 내 쿼리 관리자입니다.
public List<T> executeQuery(String query, Object... values) throws DatabaseException {
logger.info("it's at the first of executeQuery(String query, Object... values)");
List<Object> ret;
Session sess = null;
boolean freed = false;
List<T> result;
try {
sess = HibernateUtil.getSession();
Transaction tx = sess.beginTransaction();
Query q = sess.createQuery(query);
for (int i = 0; i < values.length; i++) {
if (values[i].getClass().getSimpleName().equals("Long")) {
q.setLong(i, (Long) values[i]);
} else if (values[i].getClass().getSimpleName().equals("String")) {
q.setString(i, (String) values[i]);
} else if (values[i].getClass().getSimpleName().equals("Integer")) {
q.setInteger(i, (Integer) values[i]);
} else if (values[i].getClass().getSimpleName().equals("Double")) {
q.setDouble(i, (Double) values[i]);
} else if (values[i].getClass().getSimpleName().equals("Boolean")) {
q.setBoolean(i, (Boolean) values[i]);
} else {
q.setEntity(i, values[i]);
}
}
ret = q.list();
tx.commit();
result = makeClass(ret);
HibernateUtil.freeSession(sess);
freed = true;
} catch (HibernateException e) {
logger.error("Hibernate Exception occurred in executeQuery() Method", e);
e.printStackTrace();
if (!freed && sess != null) {
HibernateUtil.freeSession(sess);
}
throw new DatabaseException("Can not execute query.");
} catch (Exception e) {
logger.fatal("Exception occurred in executeQuery() Method", e);
System.out.println(e.getMessage());
throw new DatabaseException("Can not execute query.");
}
return result;
}
이것은 클래스 메이커입니다.
private List<T> makeClass(List<Object> input) {
List<T> ret = new ArrayList<T>();
int size = input.size();
for (int i = 0; i < size; i++) {
T curr = (T) input.get(i);
ret.add(curr);
}
return ret;
}
지리적 좌표로 BuildingBranch 엔티티를로드하고 싶지만 쿼리를 설정하면 retun null입니다.
return queryManager.executeQuery("from BranchBuildingEntity b where b.buildingAdr.blongitude = 51.6371154785156 AND b.buildingAdr.blatitude = 35.658412064282");
or
return queryManager.executeQuery("from BranchBuildingEntity b where b.buildingAdr.blongitude = ? AND b.buildingAdr.blatitude = ?", longit, latid);//longit and latid both are double
그러나 아래의 쿼리를 사용하면 올바른 결과를 반환합니다 (TABLE에서 LAT = 0, Long = 0으로 분기 빌딩을 삽입합니다).
return queryManager.executeQuery("from BranchBuildingEntity b where b.buildingAdr.blongitude = 0.0 AND b.buildingAdr.blatitude = 0.0");
내 문제가 어디에 있는지 아는 몸이 있습니까?
해결책
David M이 말했듯이, 복식을 직접 비교하지 마십시오. 다른 표현을 사용하거나 간접 비교를 수행하십시오.
abs(b.buildingAdr.blongitude - 51.6371154785156) < threshold
임계 값은 동일한 것으로 간주되도록 두 개의 종단이 (수치 적으로) 얼마나 가까워 야하는지 지시합니다. 따라서 귀하에게 가장 적합한 임계 값에 대한 값을 선택합니다 (예 : 0.000000001).
다른 팁
거의 확실히 최대 절전 모드 관련이 아니라 단순히 더블의 정밀도로 내려갑니다. 이 주제에 대해 이미 많은 질문이 있지만 본질적으로 51.6371154785156과 비교하려고 노력하고 있으며,이 값의 내부 저장은 정확히 같지 않을 수 있습니다. 이 좌표를 고정 정밀도에 저장하려면이 기능을 제공하는 소수점 데이터 유형을 고려하여 선택 문제를 해결할 수 있습니다.
제휴하지 않습니다 StackOverflow