C#中的XML—将名称空间添加到新的XML元素
我发布的XML可能很大,但我的问题相当简单。请看一下第二个尺寸标签。第一个维度将自动生成。第二个是我用C#脚本创建的。 问题是:如何使我的维度标记具有与生成的名称空间完全相同的名称空间(“xsi:type=“RegularMeasureGroupDimension”)? 谢谢你的帮助 这是我用来生成维度的C代码:C#中的XML—将名称空间添加到新的XML元素,c#,xml,ssis,xml-namespaces,C#,Xml,Ssis,Xml Namespaces,我发布的XML可能很大,但我的问题相当简单。请看一下第二个尺寸标签。第一个维度将自动生成。第二个是我用C#脚本创建的。 问题是:如何使我的维度标记具有与生成的名称空间完全相同的名称空间(“xsi:type=“RegularMeasureGroupDimension”)? 谢谢你的帮助 这是我用来生成维度的C代码: XmlNode dimensions2 = doc.DocumentElement.ChildNodes[1].ChildNodes[0].ChildNodes[6].ChildNod
XmlNode dimensions2 = doc.DocumentElement.ChildNodes[1].ChildNodes[0].ChildNodes[6].ChildNodes[0].ChildNodes[5];
dimensions2.AppendChild(dimension2);
//dimension2.SetAttribute("xmlns","http://schemas.microsoft.com/analysisservices/2003/engine");
// dimension2.SetAttribute("xmlns:xsi", "http://www.w3.org/2001/XmlSchema-instance");
dimension2.SetAttribute("type", "http://www.w3.org/2001/XmlSchema-instance", "RegularMeasureGroupDimension");
这是XML文件:
<Create xmlns="http://schemas.microsoft.com/analysisservices/2003/engine">
<ParentObject>
<DatabaseID>test_szymon</DatabaseID>
</ParentObject>
<ObjectDefinition>
<Cube xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:ddl2="http://schemas.microsoft.com/analysisservices/2003/engine/2" xmlns:ddl2_2="http://schemas.microsoft.com/analysisservices/2003/engine/2/2" xmlns:ddl100_100="http://schemas.microsoft.com/analysisservices/2008/engine/100/100" xmlns:ddl200="http://schemas.microsoft.com/analysisservices/2010/engine/200" xmlns:ddl200_200="http://schemas.microsoft.com/analysisservices/2010/engine/200/200" xmlns:ddl300="http://schemas.microsoft.com/analysisservices/2011/engine/300" xmlns:ddl300_300="http://schemas.microsoft.com/analysisservices/2011/engine/300/300" xmlns:ddl400="http://schemas.microsoft.com/analysisservices/2012/engine/400" xmlns:ddl400_400="http://schemas.microsoft.com/analysisservices/2012/engine/400/400">
<ID>Test</ID>
<Name>Test</Name>
<Annotations>(...)</Annotations>
<Language>1033</Language>
<Collation>English</Collation>
<Dimensions>(...)</Dimensions>
<MeasureGroups>
<MeasureGroup>
<ID>FAKT</ID>
<Name>FAKT</Name>
<Measures>
<Measure>
<ID>Miara1</ID>
<Name>Miara1</Name>
<DataType>Integer</DataType>
<Source>
<DataType>Integer</DataType>
<Source xsi:type="ColumnBinding">
<TableID>dbo_FACT</TableID>
<ColumnID>measure1</ColumnID>
</Source>
</Source>
</Measure>
<Measure>
<ID>FACT</ID>
<Name>FACT</Name>
<AggregateFunction>Count</AggregateFunction>
<DataType>Integer</DataType>
<Source>
<DataType>Integer</DataType>
<DataSize>4</DataSize>
<Source xsi:type="RowBinding">
<TableID>dbo_FAKT</TableID>
</Source>
</Source>
</Measure>
</Measures>
<StorageMode>Molap</StorageMode>
<ProcessingMode>Regular</ProcessingMode>
<Dimensions>
<Dimension xsi:type="RegularMeasureGroupDimension">
<CubeDimensionID>WYMIAR</CubeDimensionID>
<Attributes>
<Attribute>
<AttributeID>Id Wymiar</AttributeID>
<KeyColumns>
<KeyColumn>
<DataType>Integer</DataType>
<NullProcessing>UnknownMember</NullProcessing>
<Source xsi:type="ColumnBinding">
<TableID>dbo_FAKT</TableID>
<ColumnID>id_wymiar</ColumnID>
</Source>
</KeyColumn>
</KeyColumns>
<Type>Granularity</Type>
</Attribute>
</Attributes>
</Dimension>
<Dimension d7p1:type="RegularMeasureGroupDimension" xmlns:d7p1="http://www.w3.org/2001/XmlSchema-instance">
<CubeDimensionID>WYMIAR2</CubeDimensionID>
<Attributes>
<Attribute>
<AttributeID>Id Wymiar2</AttributeID>
<KeyColumns>
<KeyColumn>
<DataType>Integer</DataType>
<NullProcessing>UnknownMember</NullProcessing>
<Source xmlns:xsi="http://www.w3.org/2001/XmlSchema-instance" xsi:type="ColumnBinding">
<TableID>dbo_FAKT</TableID>
<ColumnID>id_wymiar</ColumnID>
</Source>
</KeyColumn>
</KeyColumns>
<Type>Granularity</Type>
</Attribute>
</Attributes>
</Dimension>
</Dimensions>
斯兹蒙测试
试验
试验
(...)
1033
英语
(...)
法克特
法克特
米亚拉1
米亚拉1
整数
整数
dbo_事实
措施1
事实
事实
计数
整数
整数
4.
德博法克特
莫拉普
有规律的
威迈尔
维米亚尔酒店
整数
未知成员
德博法克特
维米亚尔酒店
粒度
WYMIAR2
Id Wymiar2
整数
未知成员
德博法克特
维米亚尔酒店
粒度
您可以尝试使用允许我们指定属性前缀的方法,例如:
var attr = doc.CreateAttribute("xsi", "type", "http://www.w3.org/2001/XmlSchema-instance");
attr.Value = "RegularMeasureGroupDimension";
dimension2.SetAttributeNode(attr);
您是如何生成XML的?@paul I从信息的角度编辑了我的帖子,它们是相同的。名称空间前缀仅在XML文档中本地定义,并且多个前缀可能引用同一名称空间。@Damien_不相信它们必须完全相同-这是处理此XMLA查询的唯一方法你确定吗?因为任何使用像样的库(而不是字符串损坏)处理XML的东西都应该到达该属性,并且知道它是
type的属性http://www.w3.org/2001/XmlSchema-instance
名称空间。