forked from SchemaStore/schemastore
-
Notifications
You must be signed in to change notification settings - Fork 0
/
bigquery-table.json
92 lines (92 loc) · 2.07 KB
/
bigquery-table.json
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
{
"$schema": "http://json-schema.org/draft-07/schema#",
"$id": "https://json.schemastore.org/bigquery-table",
"definitions": {
"field_name": {
"type": "string"
},
"field_type": {
"type": "string",
"enum": [
"INT64",
"INTEGER",
"FLOAT64",
"FLOAT",
"NUMERIC",
"BIGNUMERIC",
"BOOL",
"BOOLEAN",
"STRING",
"BYTES",
"DATE",
"DATETIME",
"TIME",
"TIMESTAMP",
"STRUCT",
"RECORD",
"JSON",
"GEOGRAPHY"
]
},
"field_mode": {
"type": "string",
"enum": ["NULLABLE", "REQUIRED", "REPEATED"]
},
"field_description": {
"type": "string"
},
"field": {
"type": "object",
"required": ["name", "type"],
"properties": {
"name": {
"$ref": "#/definitions/field_name"
},
"type": {
"$ref": "#/definitions/field_type"
},
"mode": {
"$ref": "#/definitions/field_mode"
},
"description": {
"$ref": "#/definitions/field_description"
}
},
"if": {
"properties": {
"type": {
"enum": ["STRUCT", "RECORD"]
}
}
},
"then": {
"required": ["fields", "type", "name"],
"properties": {
"name": {
"$ref": "#/definitions/field_name"
},
"type": {
"$ref": "#/definitions/field_type"
},
"mode": {
"$ref": "#/definitions/field_mode"
},
"description": {
"$ref": "#/definitions/field_description"
},
"fields": {
"type": "array",
"items": {
"$ref": "#/definitions/field"
}
}
}
}
}
},
"description": "BigQuery lets you specify a table's schema when you load data into a table or when you create an empty table. A table schema is a JSON file.",
"items": {
"$ref": "#/definitions/field"
},
"type": "array"
}