Рефлексия структуры
Nette Database предоставляет инструменты для интроспекции структуры базы данных с помощью класса Nette\Database\Reflection. Он позволяет получать информацию о таблицах, столбцах, индексах и внешних ключах. Рефлексию можно использовать для генерации схем, создания гибких приложений, работающих с базой данных, или общих инструментов для работы с базами данных.
Объект рефлексии можно получить из экземпляра подключения к базе данных:
Получение таблиц
Свойство только для чтения $reflection->tables
содержит
ассоциативный массив всех таблиц в базе данных:
Доступны еще два метода:
Информация о таблице
Таблица представлена объектом Table, который предоставляет следующие свойства только для чтения:
$name: string
– имя таблицы$view: bool
– является ли представлением$fullName: ?string
– полное имя таблицы, включая схему (БД) (если существует)$columns: array<string, Column>
– ассоциативный массив столбцов таблицы$indexes: Index[]
– массив индексов таблицы$primaryKey: ?Index
– первичный ключ таблицы или null$foreignKeys: ForeignKey[]
– массив внешних ключей таблицы
Столбцы
Свойство columns
таблицы предоставляет ассоциативный массив
столбцов, где ключом является имя столбца, а значением — экземпляр Column со следующими
свойствами:
$name: string
– имя столбца$table: ?Table
– ссылка на таблицу столбца$nativeType: string
– нативный тип данных базы данных$size: ?int
– размер/длина типа$nullable: bool
– может ли столбец содержать NULL$default: mixed
– значение по умолчанию столбца$autoIncrement: bool
– является ли столбец автоинкрементным$primary: bool
– является ли частью первичного ключа$vendor: array
– дополнительные метаданные, специфичные для данной системы баз данных
Индексы
Свойство indexes
таблицы предоставляет массив индексов, где
каждый индекс является экземпляром Index со следующими
свойствами:
$columns: Column[]
– массив столбцов, составляющих индекс$unique: bool
– является ли индекс уникальным$primary: bool
– является ли первичным ключом$name: ?string
– имя индекса
Первичный ключ таблицы можно получить с помощью свойства
primaryKey
, которое возвращает либо объект Index
, либо null
в случае, если таблица не имеет первичного ключа.
Внешние ключи
Свойство foreignKeys
таблицы предоставляет массив внешних ключей,
где каждый внешний ключ является экземпляром ForeignKey со следующими
свойствами:
$foreignTable: Table
– таблица, на которую ссылается ключ$localColumns: Column[]
– массив локальных столбцов$foreignColumns: Column[]
– массив столбцов, на которые ссылается ключ$name: ?string
– имя внешнего ключа