Чтение онлайн

на главную - закладки

Жанры

C# для профессионалов. Том II

Ватсон Карли

Шрифт:

 dataGrid1.DataMember="products";

На следующем шаге генерируется XML. Вызывается метод

WriteXml
из класса
DataSet
.
WriteXml
генерирует документ XML. Существуют две перегружаемые версии
WriteXml
, одна получает строку с путем доступа и именем файла, а в другом методе добавлен параметр режима
mode
. Этот
mode
является перечислением
XmlWriteMode
. Возможными значениями являются
DiffGram
,
IgnoreSchema
, и
WriteSchema
. Обсудим
DiffGram
позже в этом разделе.
IgnoreSchema
используется,
если нежелательно, чтобы
WriteXml
записывал подставляемую (
inline
) схему в файл XML; используйте параметр
WriteSchema
, если это желательно. Чтобы получить именно схему, вызывается
WriteXmlSchema
. Этот метод имеет четыре перегружаемые версии. Одна получает строку, содержащую путь доступа и имя файла, куда записывается документ XML. Вторая версия использует объект, который основывается на классе
XmlWriter
. Третья версия использует объект, который основывается на классе
TextWriter
. Четвертая версия используется в примере, параметр в этом случае является производным от класса Stream:

 ds.WriteXml(strmWrite, XmlWriteMode.IgnoreSchema);

 memStrm.Seek(0, SeekOrigin, Begin);

 // читаем из потока в памяти в объект XmlDocument

 doc.load(strmRead);

 // получить все элементы продуктов

 XmlNodeList nodeLst=doc.GetElementsByTagName("ProductName");

 // загрузить их в окно списка

 foreach(XmlNode nd in nodeLst) listBox1.Items.Add(nd.InnerText);

}

private void listBox1_SelectedIndexChanged(object sender, System.EventArgs e) {

 // при щелчке в окне списка

 // появляется окно сообщения с ценой изделия

 string srch=

"XmlProducts/products[ProductName= " + '"' + listBox1.SelectedItem.ToString + "]";

 XmlNode foundNode=doc.SelectSingleNode(srch);

 if (foundNode!=null)

MessageBox.Show(foundNode.SelectSingleNode("UnitPrice").InnerText);

 else MessageBox.Show("Not found");

}

На следующем экране можно видеть данные в списке, а также в таблице данных:

Если желательно сохранить документ XML на диске, то нужно сделать примерно следующее:

string file = "с:\\test\\product.xml";

ds.WriteXml(file);

Это даст нам правильно сформированный документ XML на диске, который можно прочитать посредством другого потока, с помощью

DataSet
, или может использоваться другим приложением или web-сайтом. Так как никакого параметра
XmlMode
не определено, этот документ
XmlDocument
будет содержать схему. В нашем примере в качестве параметра для метода
XmlDocument.Load
используется поток.

Когда

XmlDocument
подготовлен, мы загружаем
listbox
с помощью того же объекта
XPath
, который использовался раньше. Если посмотреть внимательно, то можно заметить, что слегка изменено событие
listBox1_SelectedIndexChanged
. Вместо вывода
InnerText
элемента, выполняется другой поиск
XPath
с помощью
SelectSingleNode
, чтобы получить элемент
UnitPrice
. Каждый раз при щелчке на продукте в
listbox
будет появляться
MessageBox
для
UnitPrise
. Теперь у нас есть два представления данных, но более важно то, что
имеется возможность манипулировать данными с помощью двух различных моделей. Можно использовать пространство имен Data для данных или пространство имен XML через данные. Такой подход ведет к очень гибким конструкциям в приложениях, так как теперь при программировании нет жесткой связи только с одной объектной моделью. Таким образом, мы имеем несколько представлений одних и тех же данных и несколько способов доступа к данным.

Следующий пример будет упрощать процесс, удаляя три потока и используя некоторые возможности ADO, встроенные в пространство имен XML. Нам понадобится изменить строку кода на уровне модуля:

private XmlDocument doc=new XmlDocument;

на:

private XmlDataDocument doc;

Это нужно сделать, так как мы не собираемся использовать

XmlDataDocument
. Вот код, который можно найти в папке
ADOSample2
:

private void button1_Click(object sender, System.EventArgs e) {

 // создать множество данных (DataSet)

 DataSet ds=new DataSet("XMLProducts");

 // соединиться с базой данных northwind и

 //выбрать все строки из таблицы products

 //выполнить изменения в строке подключения с учетом имени пользователя и имени сервера

 SqlConnection conn=

new SqlConnection(@"server=GLYNNJ_CS\NetSDK;uid=sa;pwd=;database=northwind");

 SqlDataAdapter da=new SqlDataAdapter("select * from products", conn);

 // заполнить множество данных

 da.Fill(ds, "products");

 // загрузить данные в сетку

 dataGrid1.DataSource=ds;

 dataGrid1.DataMember="products";

 doc=new XmlDataDocument(ds);

 // извлечь все элементы продуктов

 XmlNodeList nodeLst=doc.GetElementsByTagName("ProductName");

 // загрузить их в окно списка

 // здесь используется цикл for

 for(int ctr=0; ctr<nodeLst.Count; ctr++) listBox1.Items.Add(nodeLst[ctr].InnerText);

}

Как можно видеть, код для загрузки

DataSet
в документ XML был упрощен. Вместо использования класса
XmlDocument
, используется класс
XmlDataDocument
. Этот класс был создан специально для использования данных с объектом
DataSet
.

XmlDataDocument
базируется на классе
XmlDocument
, поэтому он имеет всю функциональность класса
XmlDocument
. Одним из основных отличий является перегруженный конструктор для
XmlDataDocument
. Отметим строку кода, где создается экземпляр
XmlDataDocument
:

XmlDataDocument doc=new XmlDataDocument(ds);

Он передает в качестве параметра созданный объект

DataSet
,
ds
. Документ XML создается из множества данных, поэтому не требуется использование метода
Load
. Существует также свойство
DataSet
, которое может задаваться с помощью текущего свойства
DataSet
. Фактически, если создается новый объект
XmlDataDocument
без передачи
DataSet
в качестве параметра, то он содержит объект
DataSet
с именем
NewDataSet
, который не имеет
DataTables
в коллекции таблиц. Существует также свойство
DataSet
, которое можно установить после создания объекта на основе
XmlDataDocument
. Если после вызова
DataSet.Fill
добавляется следующая строка кода:

Поделиться:
Популярные книги

Газлайтер. Том 1

Володин Григорий
1. История Телепата
Фантастика:
попаданцы
альтернативная история
аниме
5.00
рейтинг книги
Газлайтер. Том 1

Варяг

Мазин Александр Владимирович
1. Варяг
Фантастика:
альтернативная история
9.10
рейтинг книги
Варяг

Черный дембель. Часть 4

Федин Андрей Анатольевич
4. Черный дембель
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Черный дембель. Часть 4

Черный Маг Императора 7 (CИ)

Герда Александр
7. Черный маг императора
Фантастика:
фэнтези
попаданцы
5.00
рейтинг книги
Черный Маг Императора 7 (CИ)

Охота на разведенку

Зайцева Мария
Любовные романы:
современные любовные романы
эро литература
6.76
рейтинг книги
Охота на разведенку

Бесприданница

Барох Лара
Фантастика:
попаданцы
фэнтези
5.00
рейтинг книги
Бесприданница

Блуждающие огни 4

Панченко Андрей Алексеевич
4. Блуждающие огни
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Блуждающие огни 4

Архил...? Книга 2

Кожевников Павел
2. Архил...?
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Архил...? Книга 2

Идеальный мир для Лекаря 16

Сапфир Олег
16. Лекарь
Фантастика:
боевая фантастика
юмористическая фантастика
аниме
5.00
рейтинг книги
Идеальный мир для Лекаря 16

Кодекс Охотника. Книга VIII

Винокуров Юрий
8. Кодекс Охотника
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Кодекс Охотника. Книга VIII

Лишняя дочь

Nata Zzika
Любовные романы:
любовно-фантастические романы
8.22
рейтинг книги
Лишняя дочь

На границе империй. Том 9. Часть 4

INDIGO
17. Фортуна дама переменчивая
Фантастика:
космическая фантастика
попаданцы
5.00
рейтинг книги
На границе империй. Том 9. Часть 4

Наследник павшего дома. Том I

Вайс Александр
1. Расколотый мир
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Наследник павшего дома. Том I

На границе империй. Том 6

INDIGO
6. Фортуна дама переменчивая
Фантастика:
боевая фантастика
космическая фантастика
попаданцы
5.31
рейтинг книги
На границе империй. Том 6