Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataEntity / System / Data / SqlClient / SqlGen / SqlSelectClauseBuilder.cs / 1305376 / SqlSelectClauseBuilder.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; using System.Diagnostics; namespace System.Data.SqlClient.SqlGen { ////// This class is used for building the SELECT clause of a Sql Statement /// It is used to gather information about required and optional columns /// and whether TOP and DISTINCT should be specified. /// /// The underlying SqlBuilder is used for gathering the required columns. /// /// The list of OptionalColumns is used for gathering the optional columns. /// Whether a given OptionalColumn should be written is known only after the entire /// command tree has been processed. /// /// The IsDistinct property indicates that we want distinct columns. /// This is given out of band, since the input expression to the select clause /// may already have some columns projected out, and we use append-only SqlBuilders. /// The DISTINCT is inserted when we finally write the object into a string. /// /// Also, we have a Top property, which is non-null if the number of results should /// be limited to certain number. It is given out of band for the same reasons as DISTINCT. /// /// internal class SqlSelectClauseBuilder : SqlBuilder { #region Fields and Properties private Listm_optionalColumns; internal void AddOptionalColumn(OptionalColumn column) { if (m_optionalColumns == null) { m_optionalColumns = new List (); } m_optionalColumns.Add(column); } private TopClause m_top; internal TopClause Top { get { return m_top; } set { Debug.Assert(m_top == null, "SqlSelectStatement.Top has already been set"); m_top = value; } } /// /// Do we need to add a DISTINCT at the beginning of the SELECT /// internal bool IsDistinct { get; set; } ////// Whether any columns have been specified. /// public override bool IsEmpty { get { return (base.IsEmpty) && (this.m_optionalColumns == null || this.m_optionalColumns.Count == 0); } } private readonly Funcm_isPartOfTopMostStatement; #endregion #region Constructor internal SqlSelectClauseBuilder(Func isPartOfTopMostStatement) { this.m_isPartOfTopMostStatement = isPartOfTopMostStatement; } #endregion #region ISqlFragment Members /// /// Writes the string representing the Select statement: /// /// SELECT (DISTINCT) (TOP topClause) (optionalColumns) (requiredColumns) /// /// If Distinct is specified or this is part of a top most statement /// all optional columns are marked as used. /// /// Optional columns are only written if marked as used. /// In addition, if no required columns are specified and no optional columns are /// marked as used, the first optional column is written. /// /// /// /// public override void WriteSql(SqlWriter writer, SqlGenerator sqlGenerator) { writer.Write("SELECT "); if (IsDistinct) { writer.Write("DISTINCT "); } if (this.Top != null) { this.Top.WriteSql(writer, sqlGenerator); } if (this.IsEmpty) { Debug.Assert(false); // we have removed all possibilities of SELECT *. writer.Write("*"); } else { //Print the optional columns if any bool printedAny = WriteOptionalColumns(writer, sqlGenerator); if (!base.IsEmpty) { if (printedAny) { writer.Write(", "); } base.WriteSql(writer, sqlGenerator); } //If no optional columns were printed and there were no other columns, // print at least the first optional column else if (!printedAny) { this.m_optionalColumns[0].MarkAsUsed(); m_optionalColumns[0].WriteSqlIfUsed(writer, sqlGenerator, ""); } } } #endregion #region Private Helper Methods ////// Writes the optional columns that are used. /// If this is the topmost statement or distict is specifed as part of the same statement /// all optoinal columns are written. /// /// /// ///Whether at least one column got written private bool WriteOptionalColumns(SqlWriter writer, SqlGenerator sqlGenerator) { if (this.m_optionalColumns == null) { return false; } if (m_isPartOfTopMostStatement() || IsDistinct) { foreach (OptionalColumn column in this.m_optionalColumns) { column.MarkAsUsed(); } } string separator = ""; bool printedAny = false; foreach (OptionalColumn column in this.m_optionalColumns) { if (column.WriteSqlIfUsed(writer, sqlGenerator, separator)) { printedAny = true; separator = ", "; } } return printedAny; } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; using System.Diagnostics; namespace System.Data.SqlClient.SqlGen { ////// This class is used for building the SELECT clause of a Sql Statement /// It is used to gather information about required and optional columns /// and whether TOP and DISTINCT should be specified. /// /// The underlying SqlBuilder is used for gathering the required columns. /// /// The list of OptionalColumns is used for gathering the optional columns. /// Whether a given OptionalColumn should be written is known only after the entire /// command tree has been processed. /// /// The IsDistinct property indicates that we want distinct columns. /// This is given out of band, since the input expression to the select clause /// may already have some columns projected out, and we use append-only SqlBuilders. /// The DISTINCT is inserted when we finally write the object into a string. /// /// Also, we have a Top property, which is non-null if the number of results should /// be limited to certain number. It is given out of band for the same reasons as DISTINCT. /// /// internal class SqlSelectClauseBuilder : SqlBuilder { #region Fields and Properties private Listm_optionalColumns; internal void AddOptionalColumn(OptionalColumn column) { if (m_optionalColumns == null) { m_optionalColumns = new List (); } m_optionalColumns.Add(column); } private TopClause m_top; internal TopClause Top { get { return m_top; } set { Debug.Assert(m_top == null, "SqlSelectStatement.Top has already been set"); m_top = value; } } /// /// Do we need to add a DISTINCT at the beginning of the SELECT /// internal bool IsDistinct { get; set; } ////// Whether any columns have been specified. /// public override bool IsEmpty { get { return (base.IsEmpty) && (this.m_optionalColumns == null || this.m_optionalColumns.Count == 0); } } private readonly Funcm_isPartOfTopMostStatement; #endregion #region Constructor internal SqlSelectClauseBuilder(Func isPartOfTopMostStatement) { this.m_isPartOfTopMostStatement = isPartOfTopMostStatement; } #endregion #region ISqlFragment Members /// /// Writes the string representing the Select statement: /// /// SELECT (DISTINCT) (TOP topClause) (optionalColumns) (requiredColumns) /// /// If Distinct is specified or this is part of a top most statement /// all optional columns are marked as used. /// /// Optional columns are only written if marked as used. /// In addition, if no required columns are specified and no optional columns are /// marked as used, the first optional column is written. /// /// /// /// public override void WriteSql(SqlWriter writer, SqlGenerator sqlGenerator) { writer.Write("SELECT "); if (IsDistinct) { writer.Write("DISTINCT "); } if (this.Top != null) { this.Top.WriteSql(writer, sqlGenerator); } if (this.IsEmpty) { Debug.Assert(false); // we have removed all possibilities of SELECT *. writer.Write("*"); } else { //Print the optional columns if any bool printedAny = WriteOptionalColumns(writer, sqlGenerator); if (!base.IsEmpty) { if (printedAny) { writer.Write(", "); } base.WriteSql(writer, sqlGenerator); } //If no optional columns were printed and there were no other columns, // print at least the first optional column else if (!printedAny) { this.m_optionalColumns[0].MarkAsUsed(); m_optionalColumns[0].WriteSqlIfUsed(writer, sqlGenerator, ""); } } } #endregion #region Private Helper Methods ////// Writes the optional columns that are used. /// If this is the topmost statement or distict is specifed as part of the same statement /// all optoinal columns are written. /// /// /// ///Whether at least one column got written private bool WriteOptionalColumns(SqlWriter writer, SqlGenerator sqlGenerator) { if (this.m_optionalColumns == null) { return false; } if (m_isPartOfTopMostStatement() || IsDistinct) { foreach (OptionalColumn column in this.m_optionalColumns) { column.MarkAsUsed(); } } string separator = ""; bool printedAny = false; foreach (OptionalColumn column in this.m_optionalColumns) { if (column.WriteSqlIfUsed(writer, sqlGenerator, separator)) { printedAny = true; separator = ", "; } } return printedAny; } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ScaleTransform3D.cs
- WebPartZoneCollection.cs
- SystemBrushes.cs
- FileDialog.cs
- DependencyObjectValidator.cs
- BooleanFunctions.cs
- TypeGeneratedEventArgs.cs
- DataTemplateKey.cs
- RestHandler.cs
- PeerInvitationResponse.cs
- DataControlPagerLinkButton.cs
- StateRuntime.cs
- DetailsViewInsertedEventArgs.cs
- CustomWebEventKey.cs
- RepeatBehaviorConverter.cs
- MLangCodePageEncoding.cs
- MemberRelationshipService.cs
- NoneExcludedImageIndexConverter.cs
- HttpPostedFile.cs
- xsdvalidator.cs
- AutomationPeer.cs
- OrthographicCamera.cs
- XmlNamespaceMapping.cs
- FixedSOMPageConstructor.cs
- FormsAuthenticationModule.cs
- RunClient.cs
- CustomBindingCollectionElement.cs
- _ScatterGatherBuffers.cs
- SplayTreeNode.cs
- TemplatedAdorner.cs
- HtmlInputPassword.cs
- ApplicationContext.cs
- BamlLocalizableResourceKey.cs
- ButtonFieldBase.cs
- DataGridViewRowPrePaintEventArgs.cs
- MethodBody.cs
- SerializerProvider.cs
- DoubleCollectionConverter.cs
- SizeConverter.cs
- GridView.cs
- RecordsAffectedEventArgs.cs
- TextViewSelectionProcessor.cs
- ViewStateException.cs
- ColorAnimationUsingKeyFrames.cs
- AudioSignalProblemOccurredEventArgs.cs
- FragmentNavigationEventArgs.cs
- CodeDOMUtility.cs
- _CacheStreams.cs
- PackageRelationshipSelector.cs
- VectorCollectionValueSerializer.cs
- PageParserFilter.cs
- PasswordTextNavigator.cs
- DatatypeImplementation.cs
- ValidationHelper.cs
- CheckBox.cs
- SHA1.cs
- WaveHeader.cs
- OutOfMemoryException.cs
- Inline.cs
- ADMembershipUser.cs
- HttpFormatExtensions.cs
- ParserContext.cs
- DataGridViewRowContextMenuStripNeededEventArgs.cs
- SqlReferenceCollection.cs
- SpecialFolderEnumConverter.cs
- TableStyle.cs
- FilterableAttribute.cs
- AlternateViewCollection.cs
- UpdatePanelTriggerCollection.cs
- DataBindingCollectionConverter.cs
- VectorCollectionConverter.cs
- JsonQNameDataContract.cs
- ReferenceSchema.cs
- DataKey.cs
- DbReferenceCollection.cs
- EngineSite.cs
- Context.cs
- Mouse.cs
- DeviceContext2.cs
- DirtyTextRange.cs
- QueryContinueDragEventArgs.cs
- DataGridBoolColumn.cs
- SmiEventSink_Default.cs
- PropertyKey.cs
- NumberSubstitution.cs
- MailAddressCollection.cs
- LinearGradientBrush.cs
- DataContractJsonSerializerOperationFormatter.cs
- LinkLabelLinkClickedEvent.cs
- XomlDesignerLoader.cs
- RestHandlerFactory.cs
- HttpWriter.cs
- ComponentFactoryHelpers.cs
- ItemCheckedEvent.cs
- Version.cs
- ZoomPercentageConverter.cs
- LoginAutoFormat.cs
- BehaviorDragDropEventArgs.cs
- WeakReferenceKey.cs
- EditingMode.cs