Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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
- FileCodeGroup.cs
- ConfigsHelper.cs
- DocumentSequence.cs
- XhtmlConformanceSection.cs
- SignatureHelper.cs
- StringInfo.cs
- IsolatedStoragePermission.cs
- InvokeBase.cs
- DataGridViewColumn.cs
- PropertyMapper.cs
- SettingsBindableAttribute.cs
- MouseGesture.cs
- BackgroundFormatInfo.cs
- RegexMatch.cs
- ObjectItemConventionAssemblyLoader.cs
- COM2Enum.cs
- Comparer.cs
- ElasticEase.cs
- DataGridItemEventArgs.cs
- MultipleViewProviderWrapper.cs
- TableRowGroup.cs
- EventArgs.cs
- AvTrace.cs
- BuildProvidersCompiler.cs
- AppDomainEvidenceFactory.cs
- MultitargetingHelpers.cs
- BeginEvent.cs
- LockCookie.cs
- GradientStop.cs
- ScrollProviderWrapper.cs
- PropertyGridView.cs
- ConnectionProviderAttribute.cs
- DataGridViewCellValidatingEventArgs.cs
- StylusButtonCollection.cs
- HtmlWindowCollection.cs
- FormatException.cs
- MsmqAppDomainProtocolHandler.cs
- BreakRecordTable.cs
- CompressStream.cs
- DesignParameter.cs
- ResolveMatchesMessage11.cs
- ApplicationSecurityManager.cs
- DataObjectMethodAttribute.cs
- x509store.cs
- EventLogEntry.cs
- SystemColorTracker.cs
- EditorZoneDesigner.cs
- SQLMoneyStorage.cs
- GroupStyle.cs
- Evaluator.cs
- RoutedEventHandlerInfo.cs
- DocobjHost.cs
- HttpApplicationFactory.cs
- AssemblyCache.cs
- JsonUriDataContract.cs
- TableFieldsEditor.cs
- StylusPointPropertyId.cs
- SpeechEvent.cs
- BamlBinaryReader.cs
- OperatorExpressions.cs
- base64Transforms.cs
- ArgumentValueSerializer.cs
- FilterFactory.cs
- HelpKeywordAttribute.cs
- NetTcpBindingCollectionElement.cs
- JoinTreeSlot.cs
- ImageConverter.cs
- PeerServiceMessageContracts.cs
- TableSectionStyle.cs
- PrimaryKeyTypeConverter.cs
- TypeLoadException.cs
- NavigationFailedEventArgs.cs
- ProxyDataContractResolver.cs
- TypeHelper.cs
- ToolTip.cs
- BorderSidesEditor.cs
- TemplateControlCodeDomTreeGenerator.cs
- MsdtcClusterUtils.cs
- IssuedTokenClientBehaviorsElementCollection.cs
- DataListItemCollection.cs
- ViewGenerator.cs
- Array.cs
- DrawListViewSubItemEventArgs.cs
- RegionIterator.cs
- XsltCompileContext.cs
- DirectoryLocalQuery.cs
- GeometryCollection.cs
- ChooseAction.cs
- PageSetupDialog.cs
- ItemList.cs
- FeatureAttribute.cs
- DropShadowBitmapEffect.cs
- ControlCachePolicy.cs
- SHA512Cng.cs
- StylusPoint.cs
- X509ThumbprintKeyIdentifierClause.cs
- WsdlBuildProvider.cs
- ExpressionCopier.cs
- EntityCollection.cs
- DbConnectionHelper.cs