У меня есть следующий файл XML (с фиктивными данными)
<Query>
<QuerySQL Source="Dbname" Sql="SQL statement" />
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="SQL statement" />
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="SQL statement" />
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="SQL statement" />
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="SQL statement" />
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="Sql statement">
<Parameters>
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
</Parameters>
</QuerySQL>
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="Sql statement">
<Parameters>
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
</Parameters>
</QuerySQL>
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="Sql statement">
<Parameters>
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
</Parameters>
</QuerySQL>
</Query>
<Query>
<QuerySQL Source="Dbname" Sql="Sql statement">
<Parameters>
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
<Parameter Type="Type" />
</Parameters>
</QuerySQL>
</Query>
Проблема в том, что первые элементы запроса отлично читаются в моем XMLReader.
Затем, когда он попадает те, у которых есть параметры, пропускает все остальные запросы.
Я не могу понять почему. Это просто вообще не отображается в ридере.
Вот мой метод чтения:
StringReader stringReader = new StringReader(xmlString.ToString());
using (XmlReader reader = XmlReader.Create(stringReader, GetXmlReaderSettings())) {
while (reader.Read() && !reader.EOF) {
if ((reader.NodeType == XmlNodeType.Element) && (reader.Name == "Query")) {
if (reader.ReadToDescendant("QuerySQL")) {
m_sqlQuery = reader.GetAttribute("Sql");
m_doublePointCounter = m_sqlQuery.Split(':').Length - 1;
m_source = reader.GetAttribute("Source");
if (reader.ReadToDescendant("Parameters")) {
while (reader.ReadToFollowing("Parameter") && m_parameterCount < m_doublePointCounter) {
m_parameterCount++;
var types = reader.GetAttribute("Type");
m_paramList.Add(types);
}
}
}
}
}
Надеюсь, кто-нибудь может помочь мне разобраться в этом.
Что мне нужно, так это способ прочитать каждый элемент запроса и прочитать его.