2

私は次の設定をしています:

Listing.cfc

component persistent="true"
{
    property name="ListingId" column="ListingId" type="numeric" ormtype="int" fieldtype="id" generator="identity"; 
        ...
    property name="Features" type="array" hint="Array of features" singularname="Feature" fieldtype="many-to-many" cfc="Feature" linktable="Listing_Feature" FKColumn="ListingId" inversejoincolumn="FeatureId";    
} 

Feature.cfc

component persistent="true" table="Feature" schema="dbo" output="false"
{
    property name="FeatureId" column="FeatureId" type="numeric" ormtype="int" fieldtype="id" generator="identity"; 
    property name="FeatureDescription" column="FeatureDescription" type="string" ormtype="string";
    ...    
    /*property name="Listings" fieldtype="many-to-many" cfc="Listing" linktable="Listing_Feature" fkcolumn="FeatureId" inversejoincolumn="ListingId" lazy="true" cascade="all" orderby="GroupOrder";*/

} 

以下を使用して、特定の機能を持つすべてのリストを選択できます。

<cfset matchingListings = ormExecuteQuery("from Listing l left join l.Features as feature where feature.FeatureId = :feature",{feature = 110}) />

これは問題ありませんが、複数の機能を備えたすべてのリスト(たとえば、「食器洗い機」と「ガレージ」の両方を備えたリスト)を選択できるようにしたいと思います。

数時間グーグルして休止状態のドキュメントを調べても、エラーが発生しない解決策を見つけることができませんでした。私の推測では、解決策は非常に単純であり、私はそれを考えすぎています...誰かが何か提案がありますか?

4

2 に答える 2

4

これがこれを行うための最も効率的な方法であるとは思いませんが、それは私が望む結果を生み出します

<cfset matchingListings = ormExecuteQuery("Select l.ListingId from Listing l
  left join l.Features as featureone left join l.Features as featuretwo
  left join l.Features as featurethree 
  where featureone.FeatureId = 108
    and featuretwo.FeatureId = 110
    and featurethree.FeatureId = 113") />

これにより、私が探しているすべての機能を備えたリストのみが表示されますが、休止状態のSQLログが生成している多くの参加と確認が行われます。

select listing0_.ListingId as col_0_0_ 
from dbo.Listing listing0_ 
left outer join Listing_Feature features1_ on listing0_.ListingId=features1_.ListingId 
left outer join dbo.Feature feature2_ on features1_.FeatureId=feature2_.FeatureId
left outer join Listing_Feature features3_ on listing0_.ListingId=features3_.ListingId 
left outer join dbo.Feature feature4_ on features3_.FeatureId=feature4_.FeatureId 
left outer join Listing_Feature features5_ on listing0_.ListingId=features5_.ListingId 
left outer join dbo.Feature feature6_ on features5_.FeatureId=feature6_.FeatureId 
where 1=1 
and feature2_.FeatureId=108 
and feature4_.FeatureId=110 
and feature6_.FeatureId=113

HQLでこれを行うためのより効率的な方法が必要なようです


cf-orm-devメーリングリストのJonMesserは、この質問に対する最も正しい解決策であると私が信じていることを私に教えてくれました。

「私が知る限り、ORMExecuteQueryはリストパラメータを処理しないので、それらをパラメータ化してオブジェクトを返したい場合は、次のようなことを行う必要があります。

<cfset featureIds = [javaCast('int',108), javaCast('int',110), javaCast('int',113)] >

<cfset q = ormGetSession().createQuery("
    select l.ListingId 
    from Listing l 
        join l.features as f 
    where f.FeatureId in (:features)
    group by l.ListingId
    having count(*) = #arrayLen(featureIds)#
") /> 

<cfset q.setParameterList('features', featureIds) /> 

<cfset matchingListings = q.list() />

「」

ありがとうジョン!

于 2010-03-26T20:23:58.890 に答える
0

これは機能するはずです:

<cfset featurelist = "110,113,125"/>
<cfset matchingListings = ormExecuteQuery("from Listing l left join l.Features as feature where feature.FeatureId IN (#featurelist#)")/>

バインドされたパラメータを使用する場合、hibernateは今回バインドされたパラメータとしてColdFusionリストや配列を好まないため、追加の作業を行う必要があります。ここでいくつかの追加情報を見つけることができます

于 2010-03-26T17:58:59.067 に答える