1
//$Id: OneToManyJoinWalker.java 7627 2005-07-24 06:53:06Z oneovthafew $
2
package org.hibernate.loader.collection;
4
import java.util.ArrayList;
5
import java.util.Arrays;
9
import org.hibernate.LockMode;
10
import org.hibernate.MappingException;
11
import org.hibernate.engine.SessionFactoryImplementor;
12
import org.hibernate.loader.BasicLoader;
13
import org.hibernate.loader.OuterJoinableAssociation;
14
import org.hibernate.persister.collection.QueryableCollection;
15
import org.hibernate.persister.entity.OuterJoinLoadable;
16
import org.hibernate.sql.JoinFragment;
17
import org.hibernate.sql.Select;
18
import org.hibernate.util.CollectionHelper;
19
import org.hibernate.util.StringHelper;
22
* Walker for one-to-many associations
24
* @see OneToManyLoader
27
public class OneToManyJoinWalker extends CollectionJoinWalker {
29
private final QueryableCollection oneToManyPersister;
31
protected boolean isDuplicateAssociation(
32
final String foreignKeyTable,
33
final String[] foreignKeyColumns
35
//disable a join back to this same association
36
final boolean isSameJoin = oneToManyPersister.getTableName().equals(foreignKeyTable) &&
37
Arrays.equals( foreignKeyColumns, oneToManyPersister.getKeyColumnNames() );
39
super.isDuplicateAssociation(foreignKeyTable, foreignKeyColumns);
42
public OneToManyJoinWalker(
43
QueryableCollection oneToManyPersister,
46
SessionFactoryImplementor factory,
48
throws MappingException {
50
super(factory, enabledFilters);
52
this.oneToManyPersister = oneToManyPersister;
54
final OuterJoinLoadable elementPersister = (OuterJoinLoadable) oneToManyPersister.getElementPersister();
55
final String alias = generateRootAlias( oneToManyPersister.getRole() );
57
walkEntityTree(elementPersister, alias);
59
List allAssociations = new ArrayList();
60
allAssociations.addAll(associations);
61
allAssociations.add( new OuterJoinableAssociation(
62
oneToManyPersister.getCollectionType(),
66
JoinFragment.LEFT_OUTER_JOIN,
68
CollectionHelper.EMPTY_MAP
71
initPersisters(allAssociations, LockMode.NONE);
72
initStatementString(elementPersister, alias, batchSize, subquery);
76
private void initStatementString(
77
final OuterJoinLoadable elementPersister,
80
final String subquery)
81
throws MappingException {
83
final int joins = countEntityPersisters( associations );
84
suffixes = BasicLoader.generateSuffixes( joins + 1 );
86
final int collectionJoins = countCollectionPersisters( associations ) + 1;
87
collectionSuffixes = BasicLoader.generateSuffixes( joins + 1, collectionJoins );
89
StringBuffer whereString = whereString(
91
oneToManyPersister.getKeyColumnNames(),
95
String filter = oneToManyPersister.filterFragment( alias, getEnabledFilters() );
96
whereString.insert( 0, StringHelper.moveAndToBeginning(filter) );
98
JoinFragment ojf = mergeOuterJoins(associations);
99
Select select = new Select( getDialect() )
101
oneToManyPersister.selectFragment(null, null, alias, suffixes[joins], collectionSuffixes[0], true) +
102
selectString(associations)
105
elementPersister.fromTableFragment(alias) +
106
elementPersister.fromJoinFragment(alias, true, true)
108
.setWhereClause( whereString.toString() )
110
ojf.toFromFragmentString(),
111
ojf.toWhereFragmentString() +
112
elementPersister.whereJoinFragment(alias, true, true)
115
select.setOrderByClause( orderBy( associations, oneToManyPersister.getSQLOrderByString(alias) ) );
117
if ( getFactory().getSettings().isCommentsEnabled() ) {
118
select.setComment( "load one-to-many " + oneToManyPersister.getRole() );
121
sql = select.toStatementString();
124
public String toString() {
125
return getClass().getName() + '(' + oneToManyPersister.getRole() + ')';