外国のプライマリキーによるキーフィールドとグループでのmax()投影を使用した冬眠基準クエリ
-
01-10-2019 - |
質問
Hibernate(バージョン3.2.5)の基準クエリとして、このクエリ(データベースで直接動作する)を表すのが困難です。
SELECT s.*
FROM ftp_status s
WHERE (s.datetime,s.connectionid) IN (SELECT MAX(f.datetime),
f.connectionid
FROM ftp_status f
GROUP BY f.connectionid);
これまでのところ、これは私が思いついたものではありません。 could not resolve property: datetime of: common.entity.FtpStatus
エラーメッセージ:
Criteria crit = s.createCriteria(FtpStatus.class);
crit = crit.createAlias("connections", "c");
crit = crit.createAlias("id", "f");
ProjectionList proj = Projections.projectionList();
proj = proj.add(Projections.max("f.datetime"));
proj = proj.add(Projections.groupProperty("c.connectionid"));
crit = crit.setProjection(proj);
List<FtpStatus> dtlList = crit.list();
NetBeans 6.8がデータベースから直接生成した関連する参照構成は次のとおりです。
ftpstatus.hbm.xml-
<hibernate-mapping>
<class name="common.entity.FtpStatus" table="ftp_status" catalog="common">
<composite-id name="id" class="common.entity.FtpStatusId">
<key-property name="siteid" type="int">
<column name="siteid" />
</key-property>
<key-property name="connectionid" type="int">
<column name="connectionid" />
</key-property>
<key-property name="datetime" type="timestamp">
<column name="datetime" length="19" />
</key-property>
</composite-id>
<many-to-one name="connections" class="common.entity.Connections" update="false" insert="false" fetch="select">
<column name="connectionid" not-null="true" />
</many-to-one>
<many-to-one name="sites" class="common.entity.Sites" update="false" insert="false" fetch="select">
<column name="siteid" not-null="true" />
</many-to-one>
<property name="upInd" type="boolean">
<column name="up_ind" not-null="true" />
</property>
<property name="lastMessage" type="string">
<column name="last_message" length="65535" not-null="true" />
</property>
</class>
</hibernate-mapping>
connections.hbm.xml-
<hibernate-mapping>
<class name="common.entity.Connections" table="connections" catalog="common">
<id name="connectionid" type="java.lang.Integer">
<column name="connectionid" />
<generator class="identity" />
</id>
<property name="ip" type="string">
<column name="ip" length="15" not-null="true" />
</property>
<property name="port" type="int">
<column name="port" not-null="true" />
</property>
<property name="user" type="string">
<column name="user" length="8" not-null="true" />
</property>
<property name="password" type="string">
<column name="password" length="50" not-null="true" />
</property>
<set name="ftpStatuses" inverse="true">
<key>
<column name="connectionid" not-null="true" />
</key>
<one-to-many class="common.entity.FtpStatus" />
</set>
</class>
</hibernate-mapping>
私は何かが足りないことを知っていますが、私のhibernateでのグーグルはまだそれを明らかにしていません。または、SQLクエリを直接使用します s.createSQLQuery()
また s.createQuery()
また、受け入れられますが、それを書くことはさらに成功しませんでした.....
解決
Criteria
あなたが提供したように、内側のクエリパーツのみを生成するようです。 EGを使用して内部クエリを組み合わせることができます DetachedCriteria
:
DetachedCriteria maxDateQuery = DetachedCriteria.forClass(FtpStatus.class);
ProjectionList proj = Projections.projectionList();
proj.add(Projections.max("datetime"));
proj.add(Projections.groupProperty("connectionid"));
maxDateQuery.setProjection(proj);
Criteria crit = s.createCriteria(FtpStatus.class);
crit.add(Subqueries.propertiesEq(new String[] {"datetime", "connectionid"}, maxDateQuery));
List<FtpStatus> dtlList = crit.list();
マルチコラムサブ征服のサポートは、 Hibernate 4.0.0.cr5(HHH-6766).
ネイティブSQLクエリに何が来るか、冬眠 createSQLString
指定したクエリ文字列、または追加されたクエリに関与するエンティティで、結果のクエリに明示的な列名が必要な場合は、すぐに動作する必要があります。
String queryString = "SELECT {status.*}"
+ " FROM ftp_status status"
+ " WHERE (datetime, connectionid) IN ("
+ " SELECT MAX(datetime), connectionid"
+ " FROM ftp_status"
+ " GROUP BY connectionid"
+ " )";
SQLQuery query = s.createSQLQuery(queryString).addEntity("status", FtpStatus.class);
List<FtpStatus> dtlList = query.list();
所属していません StackOverflow