3. Добавьте в проект ссылку на класс SqlServerCE. Это можно сделать, щелкнув правой кнопкой мыши на узле References в элементе управления TreeView в окне Solution Explorer, а затем выбрав элемент System.Data. SqlServerCe.
Эта ссылка позволяет нашему приложению использовать классы из сборки System.Data.SqlServerCe, что открывает нам доступ к программной модели SQLCE
4. Добавьте в форму следующие элементы управления:
а. Кнопку (Button), переименовав ее в buttonCreateDataBase.
б. Кнопку (Button), переименовав ее в buttonLoadGameData
в. Текстовое окно (TextBox), оставив автоматически присвоенное ему имя textBox1.
5. Установите для свойства MultiLine элемента управления TextBox значение true.
6. Установите для свойства ScrollBar элемента управления TextBox значение vertical.
7. Для каждой из вышеупомянутых кнопок выполните следующие действия. Дважды щелкните на кнопке в окне конструктора форм. В автоматически сгенерированной и подключенной функции обработчика событий введите код функции button<ИмяКнопки>_Click() из листинга 14.5.
8. Установите для свойства MinimizeBox формы значение false. Благодаря этому во время выполнения в верхней правой части формы появится кнопка OK, с помощью которой вы легко сможете закрыть форму и выйти из приложения. Эта возможность оказывается очень полезной при многократном тестировании приложения.
9. Добавьте в проект класс DatabaseAccess, удалите из него весь добавленный по умолчанию код в окне редактора класса, и введите вместо него код из листинга 14.6.
10. Добавьте в проект класс GameData, удалите из него весь добавленный по умолчанию код в окне редактора класса, и введите вместо него код из листинга 14.7.
11. Добавьте в проект класс VocabularyWord, удалите из него весь добавленный по умолчанию код в окне редактора класса, и введите вместо него код из листинга 14.8.
12. Запустите приложение, нажав клавишу <F5>. Пользовательский интерфейс приложения должен выглядеть примерно так, как показано на рис. 14.4. Щелкните на кнопке buttonCreateDatabase для создания и наполнения данными базы данных SQL СЕ. Щелкните на кнопке buttonGameData с целью загрузки содержимого базы данных в память для последующего использования; в результате этого в текстовом окне должны отобразиться слова из словаря.
Рис. 14.4. Пример управления данными не с помощью объектов DataSet
Листинг 14.5. Пример пользовательского управления данными — код, помещаемый в форму Form1.cs//Создает базу данных
private void buttonCreateDatabase_Click(object sender, System.EventArgs e) {
DatabaseAccess.CreateAndFillDatabase();
}
//Загружает данные из базы данных и отображает их
private void buttonLoadGameData_Click(object sender, System.EventArgs e) {
//Очистить текстовое окно
textBox1.Text = "";
//Загрузить данные для слов
GameData.InitializeGameVocabulary();
//Обойти все слова и добавить их в текстовый список
System.Text.StringBuilder thisStringBuilder;
thisStringBuilder = new System.Text.StringBuilder();
foreach (VocabularyWord thisWord in GameData.AllWords) {
thisStringBuilder.Append(thisWord.EnglishWord);
thisStringBuilder.Append(" = ");
thisStringBuilder.Append(thisWord.GermanWordWithArticleIfExists);
thisStringBuilder.Append("\r\n"); //Новая строка
}
//Отобразить список слов в текстовом окне
textBox1.Text = thisStringBuilder.ToString();
}
Листинг 14.6. Пример кода управления данными для DatabaseAccess.cs//------------------------------------------------------------
//Код доступа к базе данных
//
//Этот класс управляет доступом к базе данных наших приложений
//------------------------------------------------------------
using System;
internal class DatabaseAccess {
const string DATABASE_NAME = "LearnGerman.sdf";
const string CONNECT_STRING = "Data Source = " + DATABASE_NAME + "; Password = ''";
const string TRANSLATIONTABLE_NAME = "TranslationDictionary";
const string TRANSLATIONTABLE_ENGLISH_COLUMN = "EnglishWord";
const string TRANSLATIONTABLE_GERMAN_COLUMN = "GermanWord";
const string TRANSLATIONTABLE_GERMANGENDER_COLUMN = "GermanGender";
const string TRANSLATIONTABLE_ WORDFUNCTION_COLUMN = "WordFunction";
internal const int DS_WORDS_COLUMNINDEX_ENGLISHWORD = 0;
internal const int DS_WORDS_COLUMNINDEX_GERMANWORD = 1;
internal const int DS_WORDS_COLUMNINDEX_GERMANGENDER = 2;
internal const int DS_WORDS_COLUMNINDEX_WORDFUNCTION = 3;
static public System.Data.IDataReader GetListOfWords() {
System.Data.SqlServerCe.SqlCeConnection conn = null;
conn = new System.Data.SqlServerCe.SqlCeConnection(CONNECT_STRING);
conn.Open();
System.Data.SqlServerCe.SqlCeCommand cmd = conn.CreateCommand();
cmd.ConmandText = "select " +
TRANSLATIONTABLE_ENGLISH_COLUMN + ", " +
TRANSLATIONTABLE_GERMAN_COLUMN + ", " +
TRANSLATIONTABLE_GERMANGENDER_COLUMN + ", " +
TRANSLATIONTABLE_WORDFUNCTION_COLUMN + " " + "from " +
TRANSLATIONTABLE_NAME;
//Выполнить команду базы данных
System.Data.SqlServerCe.SqlCeDataReader myReader =
cmd.ExecuteReader(System.Data.CommandBehavior.SingleResult);