本文整理汇总了C#中IOuterJoinLoadable.FromJoinFragment方法的典型用法代码示例。如果您正苦于以下问题:C# IOuterJoinLoadable.FromJoinFragment方法的具体用法?C# IOuterJoinLoadable.FromJoinFragment怎么用?C# IOuterJoinLoadable.FromJoinFragment使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IOuterJoinLoadable
的用法示例。
在下文中一共展示了IOuterJoinLoadable.FromJoinFragment方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: InitStatementString
private void InitStatementString(IOuterJoinLoadable elementPersister, string alias, int batchSize, SqlString subquery)
{
int joins = CountEntityPersisters(associations);
Suffixes = BasicLoader.GenerateSuffixes(joins + 1);
int collectionJoins = CountCollectionPersisters(associations) + 1;
CollectionSuffixes = BasicLoader.GenerateSuffixes(joins + 1, collectionJoins);
SqlStringBuilder whereString = WhereString(alias, oneToManyPersister.KeyColumnNames, subquery, batchSize);
string filter = oneToManyPersister.FilterFragment(alias, EnabledFilters);
whereString.Insert(0, StringHelper.MoveAndToBeginning(filter));
JoinFragment ojf = MergeOuterJoins(associations);
SqlSelectBuilder select =
new SqlSelectBuilder(Factory).SetSelectClause(
oneToManyPersister.SelectFragment(null, null, alias, Suffixes[joins], CollectionSuffixes[0], true)
+ SelectString(associations)).SetFromClause(elementPersister.FromTableFragment(alias)
+ elementPersister.FromJoinFragment(alias, true, true)).SetWhereClause(
whereString.ToSqlString()).SetOuterJoins(ojf.ToFromFragmentString,
ojf.ToWhereFragmentString
+ elementPersister.WhereJoinFragment(alias, true, true));
select.SetOrderByClause(OrderBy(associations, oneToManyPersister.GetSQLOrderByString(alias)));
if (Factory.Settings.IsCommentsEnabled)
{
select.SetComment("load one-to-many " + oneToManyPersister.Role);
}
SqlString = select.ToSqlString();
}
示例2: InitStatementString
private void InitStatementString(
IQueryableCollection collPersister,
IOuterJoinLoadable persister,
string alias,
IList associations,
int batchSize,
ISessionFactoryImplementor factory
)
{
int joins = associations.Count;
Suffixes = GenerateSuffixes( joins + 1 );
SqlStringBuilder whereSqlString = WhereString( factory, alias, collPersister.KeyColumnNames, collPersister.KeyType, batchSize );
if( collectionPersister.HasWhere )
{
whereSqlString
.Add( " and " )
.Add( collectionPersister.GetSQLWhereString( alias ) );
}
JoinFragment ojf = MergeOuterJoins( associations );
SqlSelectBuilder select = new SqlSelectBuilder( factory )
.SetSelectClause(
collectionPersister.SelectFragment( alias, Suffixes[ joins ], true ).ToString() +
SelectString( associations, factory )
)
.SetFromClause(
persister.FromTableFragment( alias ).Append(
persister.FromJoinFragment( alias, true, true )
)
)
.SetWhereClause( whereSqlString.ToSqlString() )
.SetOuterJoins(
ojf.ToFromFragmentString,
ojf.ToWhereFragmentString.Append(
persister.WhereJoinFragment( alias, true, true )
)
);
if( collectionPersister.HasOrdering )
{
select.SetOrderByClause( collectionPersister.GetSQLOrderByString( alias ) );
}
SqlString = select.ToSqlString();
}