/
IStructure.php
78 lines (64 loc) 路 1.64 KB
/
IStructure.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<?php
/**
* This file is part of the Nette Framework (https://nette.org)
* Copyright (c) 2004 David Grudl (https://davidgrudl.com)
*/
declare(strict_types=1);
namespace Nette\Database;
/**
* Provides cached reflection for database structure.
*/
interface IStructure
{
public const
FIELD_TEXT = 'string',
FIELD_BINARY = 'bin',
FIELD_BOOL = 'bool',
FIELD_INTEGER = 'int',
FIELD_FLOAT = 'float',
FIELD_FIXED = 'fixed',
FIELD_DATE = 'date',
FIELD_TIME = 'time',
FIELD_DATETIME = 'datetime',
FIELD_UNIX_TIMESTAMP = 'timestamp',
FIELD_TIME_INTERVAL = 'timeint';
/**
* Returns tables list.
*/
function getTables(): array;
/**
* Returns table columns list.
*/
function getColumns(string $table): array;
/**
* Returns table primary key.
* @return string|string[]|null
*/
function getPrimaryKey(string $table): string|array|null;
/**
* Returns autoincrement primary key name.
*/
function getPrimaryAutoincrementKey(string $table): ?string;
/**
* Returns table primary key sequence.
*/
function getPrimaryKeySequence(string $table): ?string;
/**
* Returns hasMany reference.
* If a targetTable is not provided, returns references for all tables.
*/
function getHasManyReference(string $table, ?string $targetTable = null): ?array;
/**
* Returns belongsTo reference.
* If a column is not provided, returns references for all columns.
*/
function getBelongsToReference(string $table, ?string $column = null): ?array;
/**
* Rebuilds database structure cache.
*/
function rebuild(): void;
/**
* Returns true if database cached structure has been rebuilt.
*/
function isRebuilt(): bool;
}