本文整理汇总了C#中SelectQuery.Clone方法的典型用法代码示例。如果您正苦于以下问题:C# SelectQuery.Clone方法的具体用法?C# SelectQuery.Clone怎么用?C# SelectQuery.Clone使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SelectQuery
的用法示例。
在下文中一共展示了SelectQuery.Clone方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: RenderPage
/// <summary>
/// Renders a SELECT statement which a result-set page
/// </summary>
/// <param name="pageIndex">The zero based index of the page to be returned</param>
/// <param name="pageSize">The size of a page</param>
/// <param name="totalRowCount">Total number of rows the query would yeild if not paged</param>
/// <param name="query">Query definition to apply paging on</param>
/// <returns>Generated SQL statement</returns>
/// <remarks>
/// To generate pagination SQL you must supply <paramref name="totalRowCount"/>.
/// To aquire the total number of rows use the <see cref="RenderRowCount"/> method.
/// </remarks>
public virtual string RenderPage(int pageIndex, int pageSize, int totalRowCount, SelectQuery query)
{
if (query.OrderByTerms.Count == 0)
{
throw new InvalidQueryException("OrderBy must be specified for paging to work.");
}
int currentPageSize = pageSize;
if (pageSize*(pageIndex + 1) > totalRowCount)
{
currentPageSize = totalRowCount - pageSize*pageIndex;
}
if (currentPageSize < 0)
{
currentPageSize = 0;
}
SelectQuery baseQuery = query.Clone();
baseQuery.Top = (pageIndex + 1)*pageSize;
//baseQuery.Columns.Add(new SelectColumn("*"));
foreach (OrderByTerm term in baseQuery.OrderByTerms)
{
baseQuery.Columns.Add(
new SelectColumn(term.Field, term.Table, FormatSortFieldName(term.Field),
SqlAggregationFunction.None));
}
string baseSql = RenderSelect(baseQuery);
SelectQuery reverseQuery = new SelectQuery();
reverseQuery.Columns.Add(new SelectColumn("*"));
reverseQuery.Top = currentPageSize;
reverseQuery.FromClause.BaseTable = FromTerm.SubQuery(baseSql, "r");
ApplyOrderBy(baseQuery.OrderByTerms, reverseQuery, false, reverseQuery.FromClause.BaseTable);
string reverseSql = RenderSelect(reverseQuery);
SelectQuery forwardQuery = new SelectQuery();
foreach (SelectColumn originalCol in query.Columns)
{
FromTerm forwardTable = FromTerm.TermRef("f");
SqlExpression expr = null;
if (originalCol.ColumnAlias != null)
{
expr = SqlExpression.Field(originalCol.ColumnAlias, forwardTable);
}
else if (originalCol.Expression.Type == SqlExpressionType.Field ||
originalCol.Expression.Type == SqlExpressionType.Constant)
{
expr = SqlExpression.Field((string) originalCol.Expression.Value, forwardTable);
}
if (expr != null)
{
forwardQuery.Columns.Add(new SelectColumn(expr, originalCol.ColumnAlias));
}
}
forwardQuery.FromClause.BaseTable = FromTerm.SubQuery(reverseSql, "f");
ApplyOrderBy(baseQuery.OrderByTerms, forwardQuery, true, forwardQuery.FromClause.BaseTable);
return RenderSelect(forwardQuery);
}
示例2: RenderRowCount
/// <summary>
/// Renders a row count SELECT statement.
/// </summary>
/// <param name="query">Query definition to count rows for</param>
/// <returns>Generated SQL statement</returns>
/// <remarks>
/// Renders a SQL statement which returns a result set with one row and one cell which contains the number of rows <paramref name="query"/> can generate.
/// The generated statement will work nicely with <see cref="System.Data.IDbCommand.ExecuteScalar"/> method.
/// </remarks>
public override string RenderRowCount(SelectQuery query)
{
SelectQuery queryAddition = query.Clone();
queryAddition.Columns.Clear();
SelectColumn col = new SelectColumn("*", null, "", SqlAggregationFunction.Count);
queryAddition.Columns.Add(col);
queryAddition.OrderByTerms.Clear();
return RenderSelect(queryAddition);
}