Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/339.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C#中的XML—将名称空间添加到新的XML元素_C#_Xml_Ssis_Xml Namespaces - Fatal编程技术网

C#中的XML—将名称空间添加到新的XML元素

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

我发布的XML可能很大,但我的问题相当简单。请看一下第二个尺寸标签。第一个维度将自动生成。第二个是我用C#脚本创建的。 问题是:如何使我的维度标记具有与生成的名称空间完全相同的名称空间(“xsi:type=“RegularMeasureGroupDimension”)? 谢谢你的帮助

这是我用来生成维度的C代码:

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
名称空间。