Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / ndp / fx / src / DataEntity / System / Data / Query / PlanCompiler / ProviderCommandInfoUtils.cs / 2 / ProviderCommandInfoUtils.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....], [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; //using System.Diagnostics; // Please use PlanCompiler.Assert instead of Debug.Assert in this class... using System.Data.Common.CommandTrees; using System.Data.Common; using md = System.Data.Metadata.Edm; using System.Data.Query.InternalTrees; using System.Data.Query.PlanCompiler; namespace System.Data.Query.PlanCompiler { ////// Helper class for creating a ProviderCommandInfo given an Iqt Node. /// internal static class ProviderCommandInfoUtils { #region Public Methods ////// Creates a ProviderCommandInfo for the given node. /// This method should be called when the keys, foreign keys and sort keys are known ahead of time. /// Typically it is used when the original command is factored into multiple commands. /// /// The owning command, used for creating VarVecs, etc /// The root of the sub-command for which a ProviderCommandInfo should be generated /// A list of ProviderCommandInfos that were created for the child sub-commands. ///The resulting ProviderCommandInfo internal static ProviderCommandInfo Create( Command command, Node node, Listchildren) { PhysicalProjectOp projectOp = node.Op as PhysicalProjectOp; PlanCompiler.Assert(projectOp != null, "Expected root Op to be a physical Project"); // build up the CQT DbCommandTree ctree = CTreeGenerator.Generate(command, node); DbQueryCommandTree cqtree = ctree as DbQueryCommandTree; PlanCompiler.Assert(cqtree != null, "null query command tree"); // Get the rowtype for the result cqt md.CollectionType collType = TypeHelpers.GetEdmType (cqtree.Query.ResultType); PlanCompiler.Assert(md.TypeSemantics.IsRowType(collType.TypeUsage), "command rowtype is not a record"); // Build up a mapping from Vars to the corresponding output property/column Dictionary outputVarMap = BuildOutputVarMap(projectOp, collType.TypeUsage); return new ProviderCommandInfo(ctree, children); } /// /// Creates a ProviderCommandInfo for the given node. /// This method should be called when the keys and the sort keys are not known ahead of time. /// Typically it is used when there is only one command, that is no query factoring is done. /// This method also has the option of pulling up keys and sort information. /// /// The owning command, used for creating VarVecs, etc /// The root of the sub-command for which a ProviderCommandInfo should be generated ///The resulting ProviderCommandInfo internal static ProviderCommandInfo Create( Command command, Node node) { return Create( command, node, new List() //children ); } #endregion #region Private Methods /// /// Build up a mapping from Vars to the corresponding property of the output row type /// /// the physical projectOp /// output type ///a map from Vars to the output type member private static Dictionary BuildOutputVarMap(PhysicalProjectOp projectOp, md.TypeUsage outputType) { Dictionary outputVarMap = new Dictionary(); PlanCompiler.Assert(md.TypeSemantics.IsRowType(outputType), "PhysicalProjectOp result type is not a RowType?"); IEnumeratorpropertyEnumerator = TypeHelpers.GetEdmType (outputType).Properties.GetEnumerator(); IEnumerator varEnumerator = projectOp.Outputs.GetEnumerator(); while (true) { bool foundProp = propertyEnumerator.MoveNext(); bool foundVar = varEnumerator.MoveNext(); if (foundProp != foundVar) { throw EntityUtil.InternalError(EntityUtil.InternalErrorCode.ColumnCountMismatch, 1); } if (!foundProp) { break; } outputVarMap[varEnumerator.Current] = propertyEnumerator.Current; } return outputVarMap; } #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; // Please use PlanCompiler.Assert instead of Debug.Assert in this class... using System.Data.Common.CommandTrees; using System.Data.Common; using md = System.Data.Metadata.Edm; using System.Data.Query.InternalTrees; using System.Data.Query.PlanCompiler; namespace System.Data.Query.PlanCompiler { ////// Helper class for creating a ProviderCommandInfo given an Iqt Node. /// internal static class ProviderCommandInfoUtils { #region Public Methods ////// Creates a ProviderCommandInfo for the given node. /// This method should be called when the keys, foreign keys and sort keys are known ahead of time. /// Typically it is used when the original command is factored into multiple commands. /// /// The owning command, used for creating VarVecs, etc /// The root of the sub-command for which a ProviderCommandInfo should be generated /// A list of ProviderCommandInfos that were created for the child sub-commands. ///The resulting ProviderCommandInfo internal static ProviderCommandInfo Create( Command command, Node node, Listchildren) { PhysicalProjectOp projectOp = node.Op as PhysicalProjectOp; PlanCompiler.Assert(projectOp != null, "Expected root Op to be a physical Project"); // build up the CQT DbCommandTree ctree = CTreeGenerator.Generate(command, node); DbQueryCommandTree cqtree = ctree as DbQueryCommandTree; PlanCompiler.Assert(cqtree != null, "null query command tree"); // Get the rowtype for the result cqt md.CollectionType collType = TypeHelpers.GetEdmType (cqtree.Query.ResultType); PlanCompiler.Assert(md.TypeSemantics.IsRowType(collType.TypeUsage), "command rowtype is not a record"); // Build up a mapping from Vars to the corresponding output property/column Dictionary outputVarMap = BuildOutputVarMap(projectOp, collType.TypeUsage); return new ProviderCommandInfo(ctree, children); } /// /// Creates a ProviderCommandInfo for the given node. /// This method should be called when the keys and the sort keys are not known ahead of time. /// Typically it is used when there is only one command, that is no query factoring is done. /// This method also has the option of pulling up keys and sort information. /// /// The owning command, used for creating VarVecs, etc /// The root of the sub-command for which a ProviderCommandInfo should be generated ///The resulting ProviderCommandInfo internal static ProviderCommandInfo Create( Command command, Node node) { return Create( command, node, new List() //children ); } #endregion #region Private Methods /// /// Build up a mapping from Vars to the corresponding property of the output row type /// /// the physical projectOp /// output type ///a map from Vars to the output type member private static Dictionary BuildOutputVarMap(PhysicalProjectOp projectOp, md.TypeUsage outputType) { Dictionary outputVarMap = new Dictionary(); PlanCompiler.Assert(md.TypeSemantics.IsRowType(outputType), "PhysicalProjectOp result type is not a RowType?"); IEnumeratorpropertyEnumerator = TypeHelpers.GetEdmType (outputType).Properties.GetEnumerator(); IEnumerator varEnumerator = projectOp.Outputs.GetEnumerator(); while (true) { bool foundProp = propertyEnumerator.MoveNext(); bool foundVar = varEnumerator.MoveNext(); if (foundProp != foundVar) { throw EntityUtil.InternalError(EntityUtil.InternalErrorCode.ColumnCountMismatch, 1); } if (!foundProp) { break; } outputVarMap[varEnumerator.Current] = propertyEnumerator.Current; } return outputVarMap; } #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
- MethodToken.cs
- List.cs
- TemplateLookupAction.cs
- RequiredFieldValidator.cs
- TableLayoutPanelBehavior.cs
- ModuleBuilder.cs
- CompensateDesigner.cs
- ListViewSortEventArgs.cs
- ToolCreatedEventArgs.cs
- ReadOnlyDictionary.cs
- DeploymentSectionCache.cs
- ErrorItem.cs
- UInt32.cs
- SystemBrushes.cs
- SearchForVirtualItemEventArgs.cs
- SendingRequestEventArgs.cs
- DbConnectionFactory.cs
- SecurityKeyEntropyMode.cs
- RuleSettings.cs
- UrlMappingsModule.cs
- CodeTypeDelegate.cs
- AssemblyHash.cs
- ObservableDictionary.cs
- HttpBrowserCapabilitiesWrapper.cs
- SoapObjectWriter.cs
- LicenseException.cs
- DefaultPropertyAttribute.cs
- Win32Exception.cs
- DataGridColumnCollection.cs
- HTMLTextWriter.cs
- ProcessManager.cs
- PerformanceCounterPermissionEntry.cs
- MsmqElementBase.cs
- ResourceDictionary.cs
- FirstMatchCodeGroup.cs
- WinInetCache.cs
- PanelDesigner.cs
- StylusSystemGestureEventArgs.cs
- Content.cs
- _OverlappedAsyncResult.cs
- RuntimeWrappedException.cs
- RichListBox.cs
- BindStream.cs
- WebPartDescription.cs
- MyContact.cs
- GeometryConverter.cs
- XsdCachingReader.cs
- ColumnTypeConverter.cs
- AnonymousIdentificationSection.cs
- _TLSstream.cs
- XmlILModule.cs
- PageSettings.cs
- ReliableMessagingVersion.cs
- FontUnit.cs
- Zone.cs
- DependentTransaction.cs
- FormatSettings.cs
- AttributedMetaModel.cs
- DiscoveryClientDocuments.cs
- OracleNumber.cs
- ISAPIRuntime.cs
- relpropertyhelper.cs
- ZipPackage.cs
- Evaluator.cs
- Brush.cs
- GridLength.cs
- MessageUtil.cs
- SymDocumentType.cs
- AutomationPatternInfo.cs
- UndoManager.cs
- PreservationFileWriter.cs
- NodeFunctions.cs
- OleDbConnectionInternal.cs
- HijriCalendar.cs
- OperationResponse.cs
- CssClassPropertyAttribute.cs
- WebFaultException.cs
- ObjectAssociationEndMapping.cs
- MessageFilter.cs
- DependentList.cs
- DbConnectionPoolGroupProviderInfo.cs
- HiddenField.cs
- DataGridViewColumnStateChangedEventArgs.cs
- InteropAutomationProvider.cs
- BehaviorDragDropEventArgs.cs
- EncryptedPackage.cs
- CryptoConfig.cs
- GPPOINTF.cs
- HealthMonitoringSection.cs
- ZeroOpNode.cs
- ECDiffieHellmanCng.cs
- CryptoHandle.cs
- ValidationSummary.cs
- DashStyle.cs
- XsltOutput.cs
- ConnectionManagementElementCollection.cs
- ToolStripRenderEventArgs.cs
- WebServiceBindingAttribute.cs
- WindowsButton.cs
- WpfKnownTypeInvoker.cs