Компонент ttable. Создание таблиц с помощью компонента ttable Содержание icon

Компонент ttable. Создание таблиц с помощью компонента ttable Содержание



НазваниеКомпонент ttable. Создание таблиц с помощью компонента ttable Содержание
Дата конвертации17.07.2012
Размер77.74 Kb.
ТипОбзор
1. /Введение в DELPHI/Alexs.rtf
2. /Введение в DELPHI/Les00.rtf
3. /Введение в DELPHI/Les11.rtf
4. /Введение в DELPHI/Les110.rtf
5. /Введение в DELPHI/Les12.rtf
6. /Введение в DELPHI/Les13.rtf
7. /Введение в DELPHI/Les14.rtf
8. /Введение в DELPHI/Les15.rtf
9. /Введение в DELPHI/Les16.rtf
10. /Введение в DELPHI/Les17.rtf
11. /Введение в DELPHI/Les18.rtf
12. /Введение в DELPHI/Les19.rtf
13. /Введение в DELPHI/Les21.rtf
14. /Введение в DELPHI/Les22.rtf
15. /Введение в DELPHI/Les23.rtf
16. /Введение в DELPHI/Les31.rtf
17. /Введение в DELPHI/Les310.rtf
18. /Введение в DELPHI/Les311.rtf
19. /Введение в DELPHI/Les32.rtf
20. /Введение в DELPHI/Les33.rtf
21. /Введение в DELPHI/Les34.rtf
22. /Введение в DELPHI/Les35.rtf
23. /Введение в DELPHI/Les36.rtf
24. /Введение в DELPHI/Les37.rtf
25. /Введение в DELPHI/Les38.rtf
26. /Введение в DELPHI/Les39.rtf
27. /Введение в DELPHI/Les41.rtf
28. /Введение в DELPHI/Les42.rtf
29. /Введение в DELPHI/Les43.rtf
30. /Введение в DELPHI/Les44.rtf
31. /Введение в DELPHI/Les45.rtf
32. /Введение в DELPHI/Menu.doc
HighWay Soft Group
Borland Delphi
Среда программирования Delphi Содержание
Средства создания мультимедийных приложений Содержание
html">Проект Delphi Пункт меню "File"
Обзор Палитры Компонент Содержание
Рисование и закраска Содержание
Печать текстовая и графическая Содержание
Свойства в Delphi Содержание Îáçîð -error: Reference source not found
Обзор
Обработка исключительных ситуаций в Delphi Содержание
События в Delphi Содержание
Dynamic Data Exchange получило свое имя потому, что позволяет двум приложениям обмениваться данными (текстовыми, через глобальную память) динамически во время выполнения. Связь между двумя программа
Ole содержание Обзор Основы ole объект tolecontainer Пример ole приложения Сохранение ole объекта в базе данных Обзор
Использование dll в Delphi Содержание
Обзор
Управление транзакциями Содержание
Local InterBase Содержание
Настройка bde содержание Обзор 2 Обзор
Создание таблиц с помощью Database Desktop Содержание
Создание таблиц с помощью sql-запросов Содержание
Содержание
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание
Содержание
Содержание
Управление соединением с базой данных (класс tdataBase,объект Session) Содержание
Создание собственных компонент Содержание
Редакторы свойств Содержание
Содержание
Урок 30: Основы языка sql содержание урока 30
Обзор Local InterBase 0 les311. rtf Подменю «Сложный материал» Создание собственных компонент les41. rtf Создание редакторов свойств компонент les42. rtf Генератор отчет

32 óðîêà ïî Delphi



Компонент TTable. Создание таблиц
с помощью компонента TTable



Содержание


Обзор

Создание таблиц с помощью компонента TTable

Заключение


Обзор


На этом небольшом уроке мы завершим изучение возможностей создания таблиц. Как Вы помните, мы уже освоили два способа создания таблиц - с помощью утилиты Database Desktop, входящей в поставку Delphi (урок 11) и с помощью SQL-запросов (урок 12), которые можно использовать как в WISQL (Windows Interactive SQL - клиентская часть Local InterBase), так и в компоненте TQuery. Теперь мы рассмотрим, как можно создавать локальные таблицы в режиме выполнения с помощью компонента TTable.

Создание таблиц с помощью компонента TTable


Для создания таблиц компонент TTable имеет метод CreateTable. Этот метод создает новую пустую таблицу заданной структуры. Данный метод (процедура) может создавать только локальные таблицы формата dBase или Paradox.

Компонент TTable можно поместить на форму в режиме проектирования или создать динамически во время выполнения. В последнем случае перед использованием его необходимо создать, например, с помощью следующей конструкции:


var

Table1: TTable;

...

Table1:=TTable.Create(nil);

...


Перед вызовом метода CreateTable необходимо установить значения свойств

TableType - тип таблицы

DatabaseName - база данных

TableName - имя таблицы

FieldDefs - массив описаний полей

IndexDefs - массив описаний индексов.


Свойство TableType имеет тип TTableType и определяет тип таблицы в базе данных. Если это свойство установлено в ttDefault, тип таблицы определяется по расширению файла, содержащего эту таблицу:

Расширение .DB или без расширения: таблица Paradox

Расширение .DBF : таблица dBASE

Расширение .TXT : таблица ASCII (текстовый файл).


Если значение свойства TableType не равно ttDefault, создаваемая таблица всегда будет иметь установленный тип, вне зависимости от расширения:

ttASCII: текстовый файл

ttDBase: таблица dBASE

ttParadox: таблица Paradox.


Свойство DatabaseName определяет базу данных, в которой находится таблица. Это свойство может содержать:

BDE алиас

директорий для локальных БД

директорий и имя файла базы данных для Local InterBase

локальный алиас, определенный через компонент TDatabase.


Свойство TableName определяет имя таблицы базы данных.


Свойство FieldDefs (имеющее тип TFieldDefs) для существующей таблицы содержит информацию обо всех полях таблицы. Эта информация доступна только в режиме выполнения и хранится в виде массива экземпляров класса TFieldDef, хранящих данные о физических полях таблицы (т.о. вычисляемые на уровне клиента поля не имеют своего объекта TFieldDef). Число полей определяется свойством Count, а доступ к элементам массива осуществляется через свойство Items:


property Items[Index: Integer]: TFieldDef;


При создании таблицы, перед вызовом метода CreateTable, нужно сформировать эти элементы. Для этого у класса TFieldDefs имеется метод Add:


procedure Add(const Name: string; DataType: TFieldType; Size: Word; Required: Boolean);


Параметр Name, имеющий тип string, определяет имя поля. Параметр DataType (тип TFieldType) обозначает тип поля. Он может иметь одно из следующих значений, смысл которых ясен из их наименования:

TFieldType = (ftUnknown, ftString, ftSmallint, ftInteger, ftWord, ftBoolean, ftFloat, ftCurrency, ftBCD, ftDate, ftTime, ftDateTime, ftBytes, ftVarBytes, ftBlob, ftMemo,

ftGraphic);

Параметр Size (тип word) представляет собой размер поля. Этот параметр имеет смысл только для полей типа ftString, ftBytes, ftVarBytes, ftBlob, ftMemo, ftGraphic, размер которых может сильно варьироваться. Поля остальных типов всегда имеют строго фиксированный размер, так что данный параметр для них не принимается во внимание. Четвертый параметр - Required - определяет, может ли поле иметь пустое значение при записи в базу данных. Если значение этого параметра - true, то поле является “требуемым”, т.е. не может иметь пустого значения. В противном случае поле не является “требуемым” и, следовательно, допускает запись значения NULL. Отметим, что в документации по Delphi и online-справочнике допущена ошибка - там отсутствует упоминание о четвертом параметре для метода Add.


Если Вы желаете индексировать таблицу по одному или нескольким полям, используйте метод Add для свойства IndexDefs, которое, как можно догадаться, также является объектом, т.е. экземпляром класса TIndexDefs. Свойство IndexDefs для существующей таблицы содержит информацию обо всех индексах таблицы. Эта информация доступна только в режиме выполнения и хранится в виде массива экземпляров класса TIndexDef, хранящих данные об индексах таблицы. Число индексов определяется свойством Count, а доступ к элементам массива осуществляется через свойство Items:


property Items[Index: Integer]: TIndexDef;


Метод Add класса TIndexDefs имеет следующий вид:


procedure Add(const Name, Fields: string;
Options: TIndexOptions);


Параметр Name, имеющий тип string, определяет имя индекса. Параметр Fields (также имеющий тип string) обозначает имя поля, которое должно быть индексировано, т.е. имя индексируемого поля. Составной индекс, использующий несколько полей, может быть задан списком имен полей, разделенных точкой с запятой “;”, например: ‘Field1;Field2;Field4’. Последний параметр - Options - определяет тип индекса. Он может иметь набор значений, описываемых типом TIndexOptions:


TIndexOptions = set of (ixPrimary, ixUnique, ixDescending,

ixCaseInsensitive, ixExpression);


Поясним эти значения. ixPrimary обозначает первичный ключ, ixUnique - уникальный индекс, ixDescending - индекс, отсортированный по уменьшению значений (для строк - в порядке, обратном алфавитному), ixCaseInsensitive - индекс, “нечувствительный” к регистру букв, ixExpression - индекс по выражению. Отметим, что упоминание о последнем значении также отсутствует в документации и online-справочнике. Опция ixExpression позволяет для таблиц формата dBase создавать индекс по выражению. Для этого достаточно в параметре Fields указать желаемое выражение, например: 'Field1*Field2+Field3'. Вообще говоря, не все опции индексов применимы ко всем форматам таблиц. Ниже мы приведем список допустимых значений для таблиц dBase и Paradox:


Îïöèè èíäåêñîâ dBASE Paradox

---------------------------------------

ixPrimary ü

ixUnique ü ü

ixDescending ü ü

ixCaseInsensitive ü

ixExpression ü


Необходимо придерживаться указанного порядка применения опций индексов во избежание некорректной работы. Следует отметить, что для формата Paradox опция ixUnique может использоваться только вместе с опцией ixPrimary (см. пример на диске - Error: Reference source not found).

Итак, после заполнения всех указанных выше свойств и вызова методов Add для FieldDefs и IndexDefs необходимо вызвать метод класса TTable - CreateTable:


with Table1 do

begin

DatabaseName:='dbdemos';

TableName:='mytest';

TableType:=ttParadox;

{Ñîçäàòü ïîëÿ}

with FieldDefs do

begin

Add('Surname', ftString, 30, true);

Add('Name', ftString, 25, true);

Add('Patronymic', ftString, 25, true);

Add('Age', ftInteger, 0, false);

Add('Weight', ftFloat, 0, false);

end;

{Ñãåíåðèðîâàòü èíäåêñû}

with IndexDefs do

begin

Add('I_Name', 'Surname;Name;Patronymic',
[ixPrimary, ixUnique]);

Add('I_Age', 'Age', [ixCaseInsensitive]);

end;

CreateTable;

end;





Рис. 0-: Программа CREATABL демонстрирует технику создания таблиц во время выполнения
Индексы можно сгенерировать и не только при создании таблицы. Для того чтобы сгенерировать индексы для существующей таблицы, нужно вызвать метод AddIndex класса TTable, набор параметров которого полностью повторяет набор параметров для метода Add класса TIndexDefs:


procedure AddIndex(const Name, Fields: string;
Options: TIndexOptions);


При этом для метода AddIndex справедливы все замечания по поводу записи полей и опций индексов, сделанные выше.

Заключение


Итак, мы познакомились с еще одним способом создания таблиц - способом, использующим метод CreateTable класса TTable. Использование данного способа придаст Вашему приложению максимальную гибкость, и Вы сможете строить локальные таблицы “на лету”. Сопутствующим методом является метод AddIndex класса TTable, позволяющий создавать индексы для уже существующей таблицы. Подчеркнем еще раз, что данный способ применим только для локальных таблиц. Более общий способ состоит в использовании SQL-запросов, который мы рассматривали на уроке 12.



Epsylon Technologies
Óðîê 20: Ñîçäàíèå òàáëèö ñ ïîìîùüþ êîìïîíåíòà TTable






Похожие:

Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconПрактическая работа 7 Создание вычислительных таблиц в Word Задание Клумбы с помощью таблицы решим следующую задачу
Четвертая клумба представляет собой равносторонний треугольник, длина стороны которого равна 4 метрам. Длины сторон пятой клумбы...
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconОткрытое занятие элективного курса «Компьютерная графика» в 10М классе по теме «Создание анимации с помощью графического редактора». Учитель – Газизова Л. Р. Тип урока
М классе по теме «Создание анимации с помощью графического редактора». Учитель – Газизова Л. Р
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconОткрытое занятие элективного курса «Компьютерная графика» в 10М классе по теме «Создание анимации с помощью графического редактора». Учитель – Газизова Л. Р. Тип урока
М классе по теме «Создание анимации с помощью графического редактора». Учитель – Газизова Л. Р
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconРешение задач оптимизации с помощью электронных таблиц
Имеется квадратный лист картона со стороной а см. Из этого листа делают коробку(вырезают по углам четыре квадрата и склеивают)
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconВ. Т. Безручко «Практикум…» из
В таблицах Word реализованы некоторые функции электронных таблиц. Подобно Excel, Word позволяет выполнять вычисления с помощью формул...
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconСоздание com-компонент "среднего слоя" в среде Microsoft Visual FoxPro Михаил Дроздов
Схема обращения клиента к серверу через soap (Simple Object Access Protocol) протокол
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconСоздание компьютерных игр
Самоучитель создания прикладных и игровых программ с помощью компилятора Borland C++ Builder 0
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconДокументы
1. /Виктор Солодчук - Создание анимационного фильма с помощью ПК.pdf
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconЛабораторная работа по теме «Построение таблиц истинности с помощью электронных таблиц Excel» Цель работы : познакомиться с логическими функциями Excel, научиться строить таблицы истинности сложных высказываний
Цель работы: познакомиться с логическими функциями Excel, научиться строить таблицы истинности сложных высказываний
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconДокументы
1. /Виктор Солодчук - Создание анимационных сцен с помощью Poser 4.pdf
Компонент ttable. Создание таблиц с помощью компонента ttable Содержание iconВведение 3 Создание новой базы данных 4
Иллюстрированное экспресс-руководство по заполнению аттестатов с помощью программы Certificate Printer 2010
Разместите кнопку на своём сайте:
Документы


База данных защищена авторским правом ©podelise.ru 2000-2014
При копировании материала обязательно указание активной ссылки открытой для индексации.
обратиться к администрации
Документы

Разработка сайта — Веб студия Адаманов