Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / SqlClient / SqlGen / Symbol.cs / 2 / Symbol.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....], [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Text; using System.Data.SqlClient; using System.Data.Metadata.Edm; using System.Data.Common.CommandTrees; namespace System.Data.SqlClient.SqlGen { ////// internal class Symbol : ISqlFragment { private Dictionary/// This class represents an extent/nested select statement, /// or a column. /// /// The important fields are Name, Type and NewName. /// NewName starts off the same as Name, and is then modified as necessary. /// /// /// The rest are used by special symbols. /// e.g. NeedsRenaming is used by columns to indicate that a new name must /// be picked for the column in the second phase of translation. /// /// IsUnnest is used by symbols for a collection expression used as a from clause. /// This allows to add the column list /// after the alias. /// /// columns; internal Dictionary Columns { get { if (null == columns) { columns = new Dictionary (StringComparer.OrdinalIgnoreCase); } return columns; } } private bool needsRenaming; internal bool NeedsRenaming { get { return needsRenaming; } set { needsRenaming = value; } } private bool outputColumnsRenamed; internal bool OutputColumnsRenamed { get { return outputColumnsRenamed; } set { outputColumnsRenamed = value; } } private string name; public string Name { get { return name; } } private string newName; public string NewName { get { return newName; } set { newName = value; } } private TypeUsage type; internal TypeUsage Type { get { return type; } set { type = value; } } public Symbol(string name, TypeUsage type) { this.name = name; this.newName = name; this.Type = type; } /// /// Use this constructor the symbol represents a SqlStatement with renamed output columns. /// /// /// /// public Symbol(string name, TypeUsage type, Dictionarycolumns) { this.name = name; this.newName = name; this.Type = type; this.columns = columns; this.OutputColumnsRenamed = true; } #region ISqlFragment Members /// /// Write this symbol out as a string for sql. This is just /// the new name of the symbol (which could be the same as the old name). /// /// We rename columns here if necessary. /// /// /// public void WriteSql(SqlWriter writer, SqlGenerator sqlGenerator) { if (this.NeedsRenaming) { int i; if (sqlGenerator.AllColumnNames.TryGetValue(this.NewName, out i)) { string newNameCandidate; do { ++i; newNameCandidate = this.NewName + i.ToString(System.Globalization.CultureInfo.InvariantCulture); } while (sqlGenerator.AllColumnNames.ContainsKey(newNameCandidate)); sqlGenerator.AllColumnNames[this.NewName] = i; this.NewName = newNameCandidate; } // Add this column name to list of known names so that there are no subsequent // collisions sqlGenerator.AllColumnNames[this.NewName] = 0; // Prevent it from being renamed repeatedly. this.NeedsRenaming = false; } writer.Write(SqlGenerator.QuoteIdentifier(this.NewName)); } #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; using System.IO; using System.Text; using System.Data.SqlClient; using System.Data.Metadata.Edm; using System.Data.Common.CommandTrees; namespace System.Data.SqlClient.SqlGen { ////// internal class Symbol : ISqlFragment { private Dictionary/// This class represents an extent/nested select statement, /// or a column. /// /// The important fields are Name, Type and NewName. /// NewName starts off the same as Name, and is then modified as necessary. /// /// /// The rest are used by special symbols. /// e.g. NeedsRenaming is used by columns to indicate that a new name must /// be picked for the column in the second phase of translation. /// /// IsUnnest is used by symbols for a collection expression used as a from clause. /// This allows to add the column list /// after the alias. /// /// columns; internal Dictionary Columns { get { if (null == columns) { columns = new Dictionary (StringComparer.OrdinalIgnoreCase); } return columns; } } private bool needsRenaming; internal bool NeedsRenaming { get { return needsRenaming; } set { needsRenaming = value; } } private bool outputColumnsRenamed; internal bool OutputColumnsRenamed { get { return outputColumnsRenamed; } set { outputColumnsRenamed = value; } } private string name; public string Name { get { return name; } } private string newName; public string NewName { get { return newName; } set { newName = value; } } private TypeUsage type; internal TypeUsage Type { get { return type; } set { type = value; } } public Symbol(string name, TypeUsage type) { this.name = name; this.newName = name; this.Type = type; } /// /// Use this constructor the symbol represents a SqlStatement with renamed output columns. /// /// /// /// public Symbol(string name, TypeUsage type, Dictionarycolumns) { this.name = name; this.newName = name; this.Type = type; this.columns = columns; this.OutputColumnsRenamed = true; } #region ISqlFragment Members /// /// Write this symbol out as a string for sql. This is just /// the new name of the symbol (which could be the same as the old name). /// /// We rename columns here if necessary. /// /// /// public void WriteSql(SqlWriter writer, SqlGenerator sqlGenerator) { if (this.NeedsRenaming) { int i; if (sqlGenerator.AllColumnNames.TryGetValue(this.NewName, out i)) { string newNameCandidate; do { ++i; newNameCandidate = this.NewName + i.ToString(System.Globalization.CultureInfo.InvariantCulture); } while (sqlGenerator.AllColumnNames.ContainsKey(newNameCandidate)); sqlGenerator.AllColumnNames[this.NewName] = i; this.NewName = newNameCandidate; } // Add this column name to list of known names so that there are no subsequent // collisions sqlGenerator.AllColumnNames[this.NewName] = 0; // Prevent it from being renamed repeatedly. this.NeedsRenaming = false; } writer.Write(SqlGenerator.QuoteIdentifier(this.NewName)); } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
![Network programming in C#, Network Programming in VB.NET, Network Programming in .NET](/images/book.jpg)
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- Stream.cs
- IImplicitResourceProvider.cs
- SubclassTypeValidatorAttribute.cs
- EasingKeyFrames.cs
- ChameleonKey.cs
- OracleBoolean.cs
- FormViewUpdatedEventArgs.cs
- DynamicMethod.cs
- ImageSourceConverter.cs
- SelfIssuedTokenFactoryCredential.cs
- CodeDomConfigurationHandler.cs
- EventQueueState.cs
- ISAPIRuntime.cs
- TPLETWProvider.cs
- assertwrapper.cs
- DisplayNameAttribute.cs
- FigureHelper.cs
- GB18030Encoding.cs
- DocumentViewerConstants.cs
- XmlSchemaDatatype.cs
- Point3DCollection.cs
- DbReferenceCollection.cs
- ColorConverter.cs
- RenderCapability.cs
- SymbolTable.cs
- PropertyMetadata.cs
- DragAssistanceManager.cs
- RefreshEventArgs.cs
- SqlDataSourceConfigureSelectPanel.cs
- MaxValueConverter.cs
- DbProviderServices.cs
- EventArgs.cs
- MultiPageTextView.cs
- ExceptionUtil.cs
- ListParaClient.cs
- OleDbParameter.cs
- dtdvalidator.cs
- TableSectionStyle.cs
- SqlCommandBuilder.cs
- SapiInterop.cs
- WebPartConnectionsConnectVerb.cs
- dataobject.cs
- FieldNameLookup.cs
- HandleRef.cs
- GeometryDrawing.cs
- UnionExpr.cs
- DBNull.cs
- Crypto.cs
- ResourceDefaultValueAttribute.cs
- RSACryptoServiceProvider.cs
- CommandEventArgs.cs
- Missing.cs
- ContractCodeDomInfo.cs
- DataGridCell.cs
- EdmToObjectNamespaceMap.cs
- FontStyle.cs
- securitycriticaldataformultiplegetandset.cs
- UnsafeNativeMethodsTablet.cs
- JournalEntryListConverter.cs
- XmlSchemaSimpleTypeUnion.cs
- InputBinding.cs
- CodeGeneratorAttribute.cs
- XmlAnyElementAttribute.cs
- TemplateBaseAction.cs
- ListBoxItemAutomationPeer.cs
- Header.cs
- SvcMapFileLoader.cs
- AttributeProviderAttribute.cs
- MaskedTextProvider.cs
- Match.cs
- SuppressIldasmAttribute.cs
- SecurityHeaderElementInferenceEngine.cs
- TextBoxBase.cs
- InfoCardSymmetricCrypto.cs
- Label.cs
- CreateSequenceResponse.cs
- ReferenceSchema.cs
- JsonWriter.cs
- DbQueryCommandTree.cs
- ParenthesizePropertyNameAttribute.cs
- OleDbConnectionPoolGroupProviderInfo.cs
- Animatable.cs
- GroupByExpressionRewriter.cs
- DocumentApplication.cs
- TextDecorationUnitValidation.cs
- StrokeDescriptor.cs
- ScriptControlManager.cs
- CategoryAttribute.cs
- AssemblyAttributes.cs
- TransportSecurityHelpers.cs
- ExternalDataExchangeClient.cs
- DataSourceConverter.cs
- Double.cs
- SizeValueSerializer.cs
- AutomationAttributeInfo.cs
- ConnectionManagementElement.cs
- _DynamicWinsockMethods.cs
- CmsUtils.cs
- AppLevelCompilationSectionCache.cs
- PropertyPanel.cs