Подключить xml файл в xml
8. Лекция: Отображение XML-документов с использованием связывания данных
Связывание данных является первым из методов отображения XML-документа с традиционной HTML-страницы, с которым вы познакомитесь. Отображение XML с HTML-страниц дает вам возможность воспользоваться как преимуществами хранения данных в XML-документе, с его гибким синтаксисом для структурирования данных и маркировки каждого фрагмента информации, так и имеющееся богатство форматирования и динамическое программирование HTML.
При связывании данных вы соединяете XML-документ с HTML-страницей, а затем встраиваете стандартные HTML-элементы, такие как SPAN или TABLE, в отдельные XML-элементы. HTML-элементы затем автоматически отображают содержимое XML-элементов, в которые они встроены.
Связывание данных, как и другие методы, о которых вы узнаете в этой лекции, работает только с XML-документом, который симметрично структурирован, например, как базы данных, – а именно, элементы документа могут быть интерпретированы как набор записей и полей. В простейшем случае такой документ состоит из корневого элемента, содержащего множество элементов одинакового типа (записи), каждый из которых имеет одинаковый набор дочерних элементов, все из которых содержат символьные данные (поля). В качестве примера можно привести документ Inventory.xml, который представлен в Листинге 8.1. Элементы BOOK этого документа могут быть интерпретированы как записи, а элементы, вложенные в каждый элемент BOOK (TITLE, AUTHOR и т.д.), могут быть интерпретированы как поля. Далее в этой лекции вы подробнее узнаете о специфических структурах документа, которые подходят для связывания данных. Если структура документа такова, что не допускает связывание данных, можно использовать метод создания сценариев, о котором пойдет речь в лекции 9.
В этой лекции вы прежде всего получите сведения о двух основных шагах при связывании данных. Затем вы узнаете в подробностях, как привязать XML-документ к HTML-странице (первый основной шаг) и как сцеплять элементы HTML с элементами XML (второй основной шаг). Наконец, вы узнаете, как программировать Web-страницу с помощью сценариев, которые используют в качестве базового объекта программирования связанные данные (а именно, Data Source Object, или DSO). Вы можете применять эти сценарии совместно со связыванием данных – либо независимо.
В лекции 9 вы познакомитесь с совершенно иным способом для доступа управления и отображения XML-документа с HTML-страницей. Этот метод вы можете использовать для XML-документов любого типа, независимо от вида его логической структуры.
Основные шаги
Вот два основных этапа при связывании данных:
Установка связи XML-документа с HTML-страницей, на которой вы хотите отобразить данные XML. Этот шаг обычно реализуется включением HTML элемента с именем XML в HTML-страницу. Например, следующий элемент на HTML-странице связывает XML-документ Book.xml со страницей:
Сцепление HTML элементов с XML-элементами. Когда вы сцепляете HTML элементы с XML-элементом, HTML-элемент автоматически отображает содержимое XML-элемента. Например, следующий элемент SPAN на HTML-странице сцеплен с элементом AUTHOR связанного XML-документа:
В результате HTML-элемент SPAN отображает содержимое XML-элемента AUTHOR.
Базовая технология связывания данных в действительности столь же проста, как в этом примере, хотя в дальнейшем вы познакомитесь с различными вариациями и способами использования этой технологии.
Шаг первый: установка связи XML-документа с HTML страницей
Чтобы отобразить XML-документ на HTML странице, вы должны установить его связь со страницей. Самый простой путь сделать это в Microsoft Internet Explorer – включить в страницу HTML-элемент с именем XML, так называемый фрагмент данных. Вы можете использовать одну из двух различных форм записи для фрагмента данных.
В первой форме весь текст XML-документа помещается между начальным и конечным тегами XML. Вот пример фрагмента данных на следующей HTML-странице:
Во второй форме записи HTML-элемент с именем XML остается пустым и содержит только URL XML-документа. Вот пример фрагмента данных на HTML-странице:
В предыдущем примере текст XML-документа должен содержаться в отдельном файле Book.xml:
Вторая форма более соответствует основам философии XML, согласно которой собственно данные (XML-документ) хранятся отдельно от информации по их форматированию и обработке (таблицы стилей или, в данном случае, HTML-страницы). Вторая форма облегчает работу с XML-документом, особенно если один документ отображается на нескольких различных HTML-страницах. В рассматриваемых в этом курсе примерах вы будете иметь дело только со второй формой.
Примечание. Имейте в виду, что элемент с именем XML, используемый для создания фрагмента данных, не является собственно XML-элементом. Это просто HTML-элемент, который содержит XML-элементы. Следовательно, использование синтаксиса XML для пустого элемента, <XML />, недопустимо
Вы должны присвоить атрибуту ID фрагмента данных уникальный идентификатор, который используете для доступа к XML-документу с HTML-страницы. (В предыдущем примере в качестве значения для ID выступает "dsoBook".)
При второй форме записи фрагмента данных вы присваиваете атрибуту SRC URL файла, содержащего данные XML. Вы можете использовать полный URL, как в следующем примере:
Чаще, однако, вы используете частичный URL, который задает местонахождение относительно местонахождения HTML-страницы, содержащей фрагмент данных. Например, атрибут SRC в следующем фрагменте данных указывает, что файл Book.xml находится в той же папке, что и HTML-страница:
Относительные URL более распространены, потому что XML-документ обычно содержится в той же папке, что и HTML-страница, либо в одной из вложенных папок.
Как хранятся данные XML
Когда Internet Explorer открывает HTML-страницу, его встроенный XML-процессор синтаксически анализирует XML-документ. Internet Explorer также создает программный объект, который носит название Объект исходных данных (Data Source Object DSO), который хранит данные XML и обеспечивает доступ к этим данным. DSO хранит данные XML как набор записей – т.е. множество записей и их полей. Например, если вы включите документ Inventory.xml (см. Листинг 8.1) в страницу как фрагмент данных, DSO будет хранить каждый элемент BOOK как запись, а каждый дочерний элемент внутри BOOK (TITLE, AUTHOR и т.д.) как поле.
Когда вы сцепляете HTML-элемент с XML-элементом, DSO автоматически предоставляет значение XML-элемента и управляет всеми его свойствами. DSO также позволяет вам напрямую осуществлять доступ и манипулирование имеющимся набором записей посредством ряда методов, свойств и событий. Методы представляют собой функции, которые вы можете вызывать со страницы для доступа или модификации набора записей. (Например, вы можете использовать методы для перемещения между записями.) Свойства представляют собой установленные на данный момент параметры, которые вы можете считывать и в ряде случаев изменять со страницы. (Например, вы можете считать свойство, которое сообщает вам, достигли ли вы последней записи.) События представляют собой определенные смены состояний (например, изменение значений записи), которыми вы можете управлять посредством функции сценария, который вы создаете для страницы.
На странице идентификатор, который вы присваиваете атрибуту ID во фрагменте данных, представляет DSO. (В предыдущем разделе в рассмотренном примере таким идентификатором является dsoBook.)
Проверка на наличие ошибок XML
Чтобы увидеть описание какой-либо ошибки, имеющейся в связанном XML-документе, вы можете протестировать документ с использованием сценариев проверки на корректность и валидность, представленных в разделе "Проверка валидности XML-документа" в лекции 9.
Шаг второй: сцепление HTML-элементов с XML-элементами
Вы можете осуществлять сцепление HTML-элементов с XML-элементами двумя основными способами.
Табличное сцепление , что означает сцепление HTML-элемента TABLE с данными XML, так что в таблице автоматически отображается весь набор записей, принадлежащих XML-документу.
Сцепление по отдельным записям , что означает сцепление не табличных элементов HTML (например, элементов SPAN) с XML-элементами таким образом, что за один раз отображается только одна запись.
Использование табличного сцепления данных
Самый простой способ отобразить XML-документ, который состоит из группы записей (такой как Inventory.xml, представленный в Листинге 8.1), – это сцепить HTML-элемент TABLE с данными XML таким образом, чтобы в таблице автоматически отображались сразу все записи (или одна страница записей за раз, если вы установили режим постраничного отображения). При таком подходе Internet Explorer берет на себя большую часть работы; вам не нужно писать сценарии или вызывать методы (функции). (Одно исключение состоит в том, что если вы выбрали режим пролистывания, вам потребуется включить несколько вызовов простых функций, о чем пойдет речь далее в этой лекции.)
Вы можете использовать одну таблицу HTML для отображения XML-документа, структурированного как набор записей, либо вы можете использовать вложенные HTML-таблицы для отображения XML-документа, содержащего иерархический набор записей (более сложную структуру записей).
Использование одной HTML-таблицы для отображения простого набора записей
Вы можете использовать один HTML-элемент TABLE для отображения XML-документа, в котором данные организованы в виде простого набора записей – т.е. XML-документа, составленного следующим образом:
корневой элемент содержит множество элементов типа запись (record) (в этой лекции подобные элементы иногда называются просто записями);
каждый элемент типа запись содержит одинаковый набор элементов типа поле (field) (в этой лекции подобные элементы иногда называются просто полями);
каждый элемент типа поле содержит только символьные данные. (Если дочерний элемент элемента запись содержит один или несколько своих собственных дочерних элементов, DSO интерпретирует его как вложенную запись, а не как поле. О том, как отображать вложенные поля, вы узнаете в разделе "Использование вложенных таблиц для отображения иерархической структуры записей" далее в этой лекции.)
Примером такого типа XML-документов является документ Inventory.xml, который вы использовали в предыдущих лекциях. Он представлен в Листинге 8.1. В этом документе корневой элемент (INVENTORY) содержит набор из восьми элементов-записей (элементы BOOK), и каждый из элементов-записей имеет одинаковый набор элементов-полей, которые содержат только символьные данные (TITLE, AUTHOR, BINDING, PAGES, PRICE).
Листинг 8.1. Inventory.xml
Когда вы связываете таблицу с XML-документом, данные, принадлежащие каждому из элементов записей, отображаются в отдельной строке таблицы, а каждый из дочерних элементов полей – в отдельном столбце.
В качестве примера возьмем HTML-страницу из Листинга 8.2, которая содержит таблицу, сцепленную с данными документа Inventory.xml из Листинга 8.1.
Листинг 8.2. Inventory Table.htm
XML-документ из Листинга 8.1 связан с HTML-страницей из Листинга 8.2 посредством фрагмента данных на этой странице, имеющего ID dsoInventory:
Таблица определена со стандартным заголовком (элемент THEAD) и с одной строкой (элемент TR). Каждая ячейка в этой строке (т.е., каждый элемент TD) состоит из элемента SPAN, который сцеплен с одним из полей XML-документа таким образом, что этот элемент отображает содержимое поля. Например, первая ячейка содержит элемент SPAN, сцепленный с полем TITLE:
Элемент SPAN связывается с полем XML путем присвоения имени поля (в данном примере TITLE) атрибуту DATAFLD элемента.
Вот как работает связывание данных: даже если в элементе TABLE определена только одна строка, когда браузер отображает таблицу, он повторяет строковый элемент для каждой записи в XML-документе. Т.е., в первой строке, следующей за заголовком, отображены поля (TITLE, AUTHOR и т.д.), принадлежащие первой записи (элемент BOOK для книги Adventures of Huckleberry Finn). В следующей строке отображены поля для второй записи (элемент BOOK для книги Leaves of Grass) и т.д. На рисунке 8.1 показано как выглядит документ в Internet Explorer.
У вас может возникнуть вопрос, почему ячейки (элементы TD) не сцеплены непосредственно с полями XML. Ответ заключается в том, что элемент TD не является связываемым HTML-элементом. (Связываемые элементы перечислены в таблице 8.3 в разделе "Другие способы связывания данных".) Следовательно, вы должны включить внутрь каждого элемента TD связываемый элемент (обычно SPAN).
Использование постраничного отображения
Если XML-документ содержит много записей, вы можете использовать постраничный вывод группы записей за один раз вместо отображения всех записей одновременно в огромной таблице. Для активизации постраничного отображения в обычной связанной таблице, выполните следующие действия.
Установите для атрибута DATAPAGESIZE сцепленного элемента TABLE значение, равное максимальному числу записей, которые вы хотите отобразить за раз. Каждая страница записей будет содержать заданное вами число записей. Например, следующий начальный тег для элемента TABLE присваивает число "5" атрибуту DATAPAGESIZE, в результате чего в таблице будет отображено пять записей за раз:
Присвойте уникальный идентификатор атрибуту ID элемента TABLE, как для следующего начального тега:
Чтобы перемещаться между записями, вызывайте методы элемента TABLE, приведенные в таблице 8.1. Для приведенных в последнем столбце примеров предполагается, что таблица имеет идентификатор InventoryTable.
Если вы ранее создали карту XML,вы можете использовать ее для импорта данных XML в ячейки, которые соеряду, но существуют также несколько способов и команд импорта данных XML без карты XML.
При наличии карты XML сделайте следующее для импорта данных XML в сопоставленные ячейки:
В карте XML выберите одну из сопоставленных ячеек.
На вкладке Разработчик нажмите кнопку Импорт.
Если вкладка Разработчик не отображается, см. раздел Отображение вкладки "Разработчик".
В диалоговом окне Импорт XML найдите и выберите файл данных XML (XML-файл), который вы хотите импортировать, и нажмите кнопку Импорт.
Другие способы импорта данных XML
Дополнительные сведения о проблемах см. в разделе Типичные проблемы при импорте данных XML в конце этой статьи.
Импорт файла данных XML в качестве XML-таблицы
На вкладке Разработчик нажмите кнопку Импорт.
Если вкладка Разработчик не отображается, см. раздел Отображение вкладки "Разработчик".
В диалоговом окне Импорт XML найдите и выберите файл данных XML (XML-файл), который вы хотите импортировать, и нажмите кнопку Импорт.
Если файл данных XML не ссылается ни на какую схему, Excel создает ее на основе этого файла.
В диалоговом окне Импорт данных выполните одно из следующих действий:
Выберите XML-таблицу на существующем компьютере, чтобы импортировать содержимое файла данных XML в XML-таблицу на вашем компьютере в указанной ячейке.
Чтобы импортировать содержимое файла в XML-таблицу на новом, начиная с ячейки A1, выберите XML-таблицу на новом. Карта файла данных XML отобразится в области задач Источник XML.
Если файл данных XML не ссылается ни на какую схему, Excel создает ее на основе этого файла.
Чтобы контролировать поведение данных XML (например, привязку данных, форматирование и макет), нажмите кнопку Свойства ,чтобы отобразить диалоговое окно Свойства карты XML. Например, при импорте данных по умолчанию существующие данные в диапазоне будут перезаписаны, но это можно изменить.
Импорт нескольких файлов данных XML
Выберите сопоставленную ячейку, чтобы импортировать несколько XML-файлов в один набор сопоставленных ячеек.
Если вы хотите импортировать несколько XML-файлов в несколько наборов сопоставленных ячеек, щелкните любую несопоставленную ячейку листа.
На вкладке Разработчик нажмите кнопку Импорт.
Если вкладка Разработчик не отображается, см. раздел Отображение вкладки "Разработчик".
В диалоговом окне Импорт XML найдите и выберите файл данных XML (XML-файл), который вы хотите импортировать.
Если файлы являются смежными, нажмите клавишу SHIFT, а затем щелкните первый и последний файл в списке. Все данные из XML-файлов будут импортированы и добавлены в сопоставленные ячейки.
Если файлы не являются смежными, нажмите клавишу CTRL, а затем щелкните все файлы списка, которые вы хотите импортировать.
Если вы выбрали несколько файлов, появится диалоговое окно Импорт <>.xml файл. Выберите карту XML, соответствующую импортируемому файлу данных XML.
Чтобы использовать одну карту для всех выделенных файлов, которые еще не были импортированы, установите флажок Использовать эту карту XML для всех выбранных файлов этой схемы.
Импорт нескольких файлов данных XML в качестве внешних данных
Если нужно импортировать несколько XML-файлов с одним пространством имен, но с разными схемами XML, вы можете воспользоваться командой Из импорта данных XML. Excel создаст уникальную карты XML для каждого импортируемого файла данных XML.
Примечание: При импорте нескольких XML-файлов, в которых не определено пространство имен, считается, что они используют одно пространство имен.
Если вы используете Excel с подпиской наMicrosoft 365, щелкните Данные > Получить данные > из файла > из XML.
Если вы используете Excel 2016 или более раннюю версию, на вкладке Данные нажмите кнопку Из других источников, а затем щелкните Из импорта данных XML.
Выберите диск, папку или расположение в Интернете, где находится файл данных XML (XML-файл), который вы хотите импортировать.
Выберите файл и нажмите кнопку Открыть.
В диалоговом окне Импорт данных выберите один из следующих параметров:
В XML-таблицу в существующей книге. Содержимое файла импортируется в новую таблицу XML на новом листе. Если файл данных XML не ссылается ни на какую схему, Excel создает ее на основе этого файла.
Существующий таблица Данные XML импортируется в двумерную таблицу со строками и столбцами, где теги XML показаны как заголовки столбцов, а данные — в строках под заголовками столбцов. Первый элемент (корневой узел) используется как заголовок и отображается в указанном расположении ячейки. Остальные теги отсортировали по алфавиту во второй строке. В этом случае схема не создается и вы не можете использовать карту XML.
На новый лист. Excel добавляет в книгу новый лист и автоматически помещает данные XML в его левый верхний угол. Если файл данных XML не ссылается ни на какую схему, Excel создает ее на основе этого файла.
Чтобы контролировать поведение данных XML, таких как привязка, форматирование и макет, нажмите кнопку Свойства ,чтобы отобразить диалоговое окно Свойства карты XML. Например, при импорте данных по умолчанию существующие данные в соеченом диапазоне перезаписываются, но это можно изменить.
Открытие файла данных XML для импорта данных
Выберите команду Файл > Открыть.
Если вы используете Excel 2007, нажмите Microsoft Office кнопку >открыть.
В диалоговом окне Открытие файла выберите диск, папку или веб-адрес, где расположен нужный файл.
Выберите файл и нажмите кнопку Открыть.
Если появится диалоговое окно Импорт XML, открытый файл ссылается на одну или несколько таблиц стилей XSLT, поэтому можно щелкнуть один из следующих параметров:
Открытие файла без применения таблицы стилей Данные XML импортируется в двумерную таблицу со строками и столбцами, где теги XML показаны как заголовки столбцов, а данные — в строках под заголовками столбцов. Первый элемент (корневой узел) используется как заголовок и отображается в указанном расположении ячейки. Остальные теги отсортировали по алфавиту во второй строке. В этом случае схема не создается и вы не можете использовать карту XML.
Открыть файл, применив следующую таблицу стилей (выберите одну). Выберите таблицу стилей, которую вы хотите применить, и нажмите кнопку ОК. Данные XML будут отформатированы в соответствии с выбранным листом стилей.
Примечание: Данные XML будут открыты в Excel в режиме "только для чтения", что позволяет предотвратить случайное сохранение первоначального исходного файла в формате книги Excel с поддержкой макросов (XLSM). В этом случае схема не создается и вы не можете использовать карту XML.
Если появится диалоговое окно Открыть XML, в XML-файле не будет ссылок на таблицу стилей XSLT. Чтобы открыть файл, выберите один из следующих параметров:
Щелкните XML-таблица для создания XML-таблицы в новой книге.
Содержимое файла импортируется в XML-таблицу. Если файл данных XML не ссылается ни на какую схему, Excel создает ее на основе этого файла.
Выберите в качестве книги, которая будет работать только для чтения.
Данные XML импортируется в двумерную таблицу со строками и столбцами, где теги XML показаны как заголовки столбцов, а данные — в строках под заголовками столбцов. Первый элемент (корневой узел) используется как заголовок и отображается в указанном расположении ячейки. Остальные теги отсортировали по алфавиту во второй строке. В этом случае схема не создается и вы не можете использовать карту XML.
Данные XML будут открыты в Excel в режиме "только для чтения", что позволяет предотвратить случайное сохранение первоначального исходного файла в формате книги Excel с поддержкой макросов (XLSM). В этом случае схема не создается и вы не можете использовать карту XML.
Щелкните Использовать область задач XML-источника.
Карта файла данных XML отобразится в области задач Источник XML. Для сопоставления элементов схемы с листом их можно перетащить на лист.
Если файл данных XML не ссылается ни на какую схему, Excel создает ее на основе этого файла.
Распространенные проблемы при импорте данных XML
Excel отображает диалоговое окно Ошибка импорта XML, если не может проверить данные в соответствии с картой XML. Чтобы получить дополнительные сведения об ошибке, нажмите кнопку Сведения в этом диалоговом окне. В следующей ниже таблице описаны ошибки, которые часто возникают при импорте данных.
Ошибка при проверке схемы
Когда вы выбрали в диалоговом окне Свойства карты XML параметр Проверять данные на соответствие схеме при импорте и экспорте, данные были импортированы, но не проверены на соответствие указанной карте XML.
Некоторые данные были импортированы как текст
Часть импортированных данных или все данные были преобразованы из объявленного типа в текст. Чтобы использовать эти данные в вычислениях, необходимо преобразовать их в числа или даты. Например, значение даты, преобразованное в текст, не будет работать должным образом в функции ГОД, пока вы не преобразуйте его в тип данных "Дата". Excel преобразует данные в текст в следующих случаях:
Данные в формате, который Excel не поддерживается.
Ошибка разбора XML
Средству синтаксического анализа XML не удается открыть указанный XML-файл. Убедитесь, что в XML-файле отсутствуют синтаксические ошибки и XML построен правильно.
Не удается найти карту XML, соответствующую этим данным
Эта проблема может возникнуть в том случае, если для импорта выбрано несколько файлов данных XML и Excel не удается найти соответствующую карту XML для одного из них. Импортируйте схему для файла, указанного в строке заголовка этого диалогового окна, сначала следует, а затем повторно выполните импорт файла.
Не удается изменить размер XML-таблицы для включения данных
Указанный XML-файл не ссылается на схему
XML-файл, который вы пытаетесь открыть, не ссылается на схему XML. Для работы с данными XML, содержащимися в файле, Excel требуется схема, основанная на его содержимом. Если такая схема неверна или не отвечает вашим требованиям, удалите ее из книги. Затем создайте файл схемы XML и измените файл данных XML так, чтобы он ссылался на схему. Дополнительные сведения см. в статье Сопоставление XML-элементов с ячейками карты XML.
Примечание: Схему, созданную Excel, невозможно экспортировать в качестве отдельного файла данных схемы XML (XSD-файла). Хотя существуют редакторы схем XML и другие способы создания файлов схемы XML, возможно, вы не имеете к ним доступа или не знаете, как ими пользоваться.
Выполните следующие действия, чтобы удалить из книги схему, созданную Excel:
На вкладке Разработчик выберите команду Источник.
Если вкладка Разработчик не отображается, см. раздел Отображение вкладки "Разработчик".
В области задач Источник XML выберите пункт Карты XML.
В диалоговом окне Карты XML щелкните карту XML, созданную Excel ,и нажмите кнопку Удалить.
Возникают проблемы при импорте нескольких XML-файлов, которые используют одно пространство имен, но разные схемы
При работе с несколькими файлами данных XML и несколькими схемами XML стандартным подходом является создание карты XML для каждой схемы, сопоставление нужных элементов, а затем импорт каждого из файлов данных XML в соответствующую карту XML. При использовании команды Импорт для открытия нескольких XML-файлов с одним пространством имен можно использовать только одну схему XML. Если эта команда используется для импорта нескольких XML-файлов, использующих одно пространство имен при разных схемах, можно получить непредсказуемые результаты. Например, это может привести к тому, что данные будут перезаписаны или файлы перестанут открываться.
Если нужно импортировать несколько XML-файлов с одним пространством имен, но с разными схемами XML, вы можете воспользоваться командой Из импорта данных XML (выберите Данные > Из других источников). Эта команда позволяет импортировать несколько XML-файлов с одним пространством имен и разными схемами XML. Excel создаст уникальную карты XML для каждого импортируемого файла данных XML.
Примечание: При импорте нескольких XML-файлов, в которых не определено пространство имен, считается, что они используют одно пространство имен.
Отображение вкладки "Разработчик"
Если вкладка Разработчик недоступна, выполните следующие действия, чтобы открыть ее.
В Excel 2013 и Excel 2010
Выберите Файл > Параметры.
Щелкните категорию Настроить ленту.
В разделе Основные вкладки установите флажок Разработчик и нажмите кнопку ОК.
Выберите категорию Основные.
В разделе Основные параметры работы с Excel установите флажок Показывать вкладку "Разработчик" на ленте и нажмите кнопку ОК.
Итак в статье Сохранение и загрузка в XML я показал каким образом создать таблицу в виде XML файла. Следующим шагом нужно добавить простые инструменты ( методы ) с помощью которых можно будет добавлять записи в таблицу. Просто передав в нее данные. Данная схемы выгладила следующим образом:
Задача хоть и проста но она будет разбита на несколько возможных ситуаций.
1) Самое простое мы добавляем данные в таблицу не заботясь о том наличии повторяющихся значений в таблице.
2) Добавление записей с указанием того что нужно проверить наличие уникального ID в таблице и если он найден то не добавлять данные с этим же ID
3) Можно проверять всю строку на совпадение данных в таблице.
На самом деле этот шаг не работает на прямую с XML файлом а работает уже с загруженными данными в класс DataTable поэтому логичнее вынести эти функции в отдельный новый класс который будет работать именно с классом DataTable. И при необходимости передавать команды в класс DBXML чтобы тот записал или прочитал данные из файла.
Таким образом мы сможем полностью отвлечься от процесса загрузки и сохранения данных а сосредоточится лишь на работе с загруженными таблицами данных. Итак создаем новый класс для работы с таблицами я его назвал DataTableAction. Для этого в обозревателе решения щелкаем правой кнопкой мыши и добавляем класс. Задаем ему имя и говорим добавить.
После данных манипуляций создается класс. В котором будем описывать всю работу с таблицами на классов DataTable.
Первым делом объявим класс DBXML который позволяет нам работать с файлами, загружать и сохранять таблицы а так же с помощью него мы можем создавать новые таблицы. А так же добавим библиотеку для работы с типами Data в которые входят все компоненты для работы с данными в виде таблиц.
Добавляем класс для работы с виртуальными таблицами
Итак опишем первую функцию insert которая будет получать на вход набор строк а далее будет добавлять их в таблицу с указанным именем.
функция добавит записи в таблицу
Допустим мы захотели добавить данные в таблицу которая еще не сохранена как файл. Тут может быть несколько вариантов решения.
1) Любимый всеми это послать разработчика лесом типа нет такой таблицы. Конечно этот путь более правильный потому что пользователь мог просто ошибиться с именем таблицы а мы сохраним данные которые он больше никогда в жизни не увидит.
2) Создать таблицу и положить в нее данные и не мучить разработчика. И просто помнить об этом.
В любом случае нам нужно узнать, есть ли данная таблица у нас в виде файла. Для этого вернемся обратно в класс DBXML и напишем функцию ExistXMLTable которая будет возвращать правду если таблица существует и ложь если ее нет.
Функция проверки существования таблицы
Теперь перед добавлением данных в таблицу мы сможем понять существует ли она вообще или такое таблицы нет. Добавим данную проверку в нашу функцию insert.
Теперь когда мы знаем что таблица существует нужно загрузить ее в DataTable. Добавить в нее строку данных DataRow Record и сохранить ее обратно в файле.
Давайте проверим как работает наша функция. Для этого перейдем в главный модуль программы ( в файл Program.cs и в функции Main опишем добавление данных в таблицу. Для этого нам нужно сначала сделать таблицу в которую будем добавлять данные. Следующим шагом сохранить ее в виде файла. А потом уже добавить в нее новую строку.
Благодаря данному коду, у нас создается пустая таблица test и сохраняется в виде XML схемы в отдельный файл с именем test.xml
Для того чтобы данные можно было добавить в правильные столбцы нам нужно будет загрузить таблицу из файла. Далее создать пустую запись и заполнить ее значения с помощью указания имен столбцов или индексов. Индексы я бы не советовал использовать так как таблица может формироваться из запроса и если вы смените порядок столбцов в результате то можете напороться что у вас данные будут записаны в неправильные столбцы.
Когда мы заполним значения то просто вызовем функцию добавления записей в таблицу и передадим в нее имя таблицы в которую нужно добавить запись и саму запись. Итак изменим главную функцию программы для реализации данного процесса.
После запуска проекта можно увидеть что наша функция добавила запись в таблицу создав при этом кучу XML разметки самостоятельно.
Если запустить программу несколько раз то в таблицу запишутся столько строк сколько мы раз запустили программу.Допустим запустив 3 раза мы получим в XML три записи.
На данном шаге можно было бы все закончить и радостно пойти отдыхать но вот незадача. Каждая запись у нас добавилась одинаковая. А хочется симулировать счетчик как в любой уважающей себя базе данных. Итак давайте добавим в функцию insert флаг который будет обозначать какое из полей рассчитывать с помощью счетчика. В него будем передавать имя поля. Если оно пустое то не будем считать ничего если поле будет указано то будем в его значении рассчитывать инкрементное значение.
Итак добавляем в функцию Insert новый флаг. Описывающий какое из полей будем рассчитывать. Для создания этого функционала просто создадим копию функции и добавим в нее флаг.
Итак в статье Сохранение и загрузка в XML я показал каким образом создать таблицу в виде XML файла. Следующим шагом нужно добавить простые инструменты ( методы ) с помощью которых можно будет добавлять записи в таблицу. Просто передав в нее данные. Данная схемы выгладила следующим образом:
Задача хоть и проста но она будет разбита на несколько возможных ситуаций.
1) Самое простое мы добавляем данные в таблицу не заботясь о том наличии повторяющихся значений в таблице.
2) Добавление записей с указанием того что нужно проверить наличие уникального ID в таблице и если он найден то не добавлять данные с этим же ID
3) Можно проверять всю строку на совпадение данных в таблице.
На самом деле этот шаг не работает на прямую с XML файлом а работает уже с загруженными данными в класс DataTable поэтому логичнее вынести эти функции в отдельный новый класс который будет работать именно с классом DataTable. И при необходимости передавать команды в класс DBXML чтобы тот записал или прочитал данные из файла.
Таким образом мы сможем полностью отвлечься от процесса загрузки и сохранения данных а сосредоточится лишь на работе с загруженными таблицами данных. Итак создаем новый класс для работы с таблицами я его назвал DataTableAction. Для этого в обозревателе решения щелкаем правой кнопкой мыши и добавляем класс. Задаем ему имя и говорим добавить.
После данных манипуляций создается класс. В котором будем описывать всю работу с таблицами на классов DataTable.
Первым делом объявим класс DBXML который позволяет нам работать с файлами, загружать и сохранять таблицы а так же с помощью него мы можем создавать новые таблицы. А так же добавим библиотеку для работы с типами Data в которые входят все компоненты для работы с данными в виде таблиц.
Добавляем класс для работы с виртуальными таблицами
Итак опишем первую функцию insert которая будет получать на вход набор строк а далее будет добавлять их в таблицу с указанным именем.
функция добавит записи в таблицу
Допустим мы захотели добавить данные в таблицу которая еще не сохранена как файл. Тут может быть несколько вариантов решения.
1) Любимый всеми это послать разработчика лесом типа нет такой таблицы. Конечно этот путь более правильный потому что пользователь мог просто ошибиться с именем таблицы а мы сохраним данные которые он больше никогда в жизни не увидит.
2) Создать таблицу и положить в нее данные и не мучить разработчика. И просто помнить об этом.
В любом случае нам нужно узнать, есть ли данная таблица у нас в виде файла. Для этого вернемся обратно в класс DBXML и напишем функцию ExistXMLTable которая будет возвращать правду если таблица существует и ложь если ее нет.
Функция проверки существования таблицы
Теперь перед добавлением данных в таблицу мы сможем понять существует ли она вообще или такое таблицы нет. Добавим данную проверку в нашу функцию insert.
Теперь когда мы знаем что таблица существует нужно загрузить ее в DataTable. Добавить в нее строку данных DataRow Record и сохранить ее обратно в файле.
Давайте проверим как работает наша функция. Для этого перейдем в главный модуль программы ( в файл Program.cs и в функции Main опишем добавление данных в таблицу. Для этого нам нужно сначала сделать таблицу в которую будем добавлять данные. Следующим шагом сохранить ее в виде файла. А потом уже добавить в нее новую строку.
Благодаря данному коду, у нас создается пустая таблица test и сохраняется в виде XML схемы в отдельный файл с именем test.xml
Для того чтобы данные можно было добавить в правильные столбцы нам нужно будет загрузить таблицу из файла. Далее создать пустую запись и заполнить ее значения с помощью указания имен столбцов или индексов. Индексы я бы не советовал использовать так как таблица может формироваться из запроса и если вы смените порядок столбцов в результате то можете напороться что у вас данные будут записаны в неправильные столбцы.
Когда мы заполним значения то просто вызовем функцию добавления записей в таблицу и передадим в нее имя таблицы в которую нужно добавить запись и саму запись. Итак изменим главную функцию программы для реализации данного процесса.
После запуска проекта можно увидеть что наша функция добавила запись в таблицу создав при этом кучу XML разметки самостоятельно.
Если запустить программу несколько раз то в таблицу запишутся столько строк сколько мы раз запустили программу.Допустим запустив 3 раза мы получим в XML три записи.
На данном шаге можно было бы все закончить и радостно пойти отдыхать но вот незадача. Каждая запись у нас добавилась одинаковая. А хочется симулировать счетчик как в любой уважающей себя базе данных. Итак давайте добавим в функцию insert флаг который будет обозначать какое из полей рассчитывать с помощью счетчика. В него будем передавать имя поля. Если оно пустое то не будем считать ничего если поле будет указано то будем в его значении рассчитывать инкрементное значение.
Итак добавляем в функцию Insert новый флаг. Описывающий какое из полей будем рассчитывать. Для создания этого функционала просто создадим копию функции и добавим в нее флаг.
Читайте также: