/Users/deen/code/yugabyte-db/src/yb/master/yql_views_vtable.cc
Line | Count | Source |
1 | | // Copyright (c) YugaByte, Inc. |
2 | | // |
3 | | // Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except |
4 | | // in compliance with the License. You may obtain a copy of the License at |
5 | | // |
6 | | // http://www.apache.org/licenses/LICENSE-2.0 |
7 | | // |
8 | | // Unless required by applicable law or agreed to in writing, software distributed under the License |
9 | | // is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express |
10 | | // or implied. See the License for the specific language governing permissions and limitations |
11 | | // under the License. |
12 | | // |
13 | | #include "yb/master/yql_views_vtable.h" |
14 | | |
15 | | #include "yb/common/ql_type.h" |
16 | | #include "yb/common/schema.h" |
17 | | #include "yb/util/status_log.h" |
18 | | |
19 | | namespace yb { |
20 | | namespace master { |
21 | | |
22 | | YQLViewsVTable::YQLViewsVTable(const TableName& table_name, |
23 | | const NamespaceName& namespace_name, |
24 | | Master * const master) |
25 | 2.00k | : YQLEmptyVTable(table_name, namespace_name, master, CreateSchema()) { |
26 | 2.00k | } |
27 | | |
28 | 2.00k | Schema YQLViewsVTable::CreateSchema() const { |
29 | 2.00k | SchemaBuilder builder; |
30 | 2.00k | CHECK_OK(builder.AddHashKeyColumn("keyspace_name", QLType::Create(DataType::STRING))); |
31 | 2.00k | CHECK_OK(builder.AddKeyColumn("view_name", QLType::Create(DataType::STRING))); |
32 | 2.00k | CHECK_OK(builder.AddColumn("base_table_id", QLType::Create(DataType::UUID))); |
33 | 2.00k | CHECK_OK(builder.AddColumn("base_table_name", QLType::Create(DataType::STRING))); |
34 | 2.00k | CHECK_OK(builder.AddColumn("bloom_filter_fp_chance", QLType::Create(DataType::DOUBLE))); |
35 | | // TODO: caching needs to be a frozen map. |
36 | 2.00k | CHECK_OK(builder.AddColumn("caching", |
37 | 2.00k | QLType::CreateTypeMap(DataType::STRING, DataType::STRING))); |
38 | 2.00k | CHECK_OK(builder.AddColumn("cdc", QLType::Create(DataType::BOOL))); |
39 | 2.00k | CHECK_OK(builder.AddColumn("comment", QLType::Create(DataType::STRING))); |
40 | | // TODO: compaction needs to be a frozen map. |
41 | 2.00k | CHECK_OK(builder.AddColumn("compaction", |
42 | 2.00k | QLType::CreateTypeMap(DataType::STRING, DataType::STRING))); |
43 | | // TODO: compression needs to be a frozen map. |
44 | 2.00k | CHECK_OK(builder.AddColumn("compression", |
45 | 2.00k | QLType::CreateTypeMap(DataType::STRING, DataType::STRING))); |
46 | 2.00k | CHECK_OK(builder.AddColumn("crc_check_chance", QLType::Create(DataType::DOUBLE))); |
47 | 2.00k | CHECK_OK(builder.AddColumn("dclocal_read_repair_chance", QLType::Create(DataType::DOUBLE))); |
48 | 2.00k | CHECK_OK(builder.AddColumn("default_time_to_live", QLType::Create(DataType::INT32))); |
49 | 2.00k | CHECK_OK(builder.AddColumn("extensions", |
50 | 2.00k | QLType::CreateTypeMap(DataType::STRING, DataType::BINARY))); |
51 | 2.00k | CHECK_OK(builder.AddColumn("gc_grace_seconds", QLType::Create(DataType::INT32))); |
52 | 2.00k | CHECK_OK(builder.AddColumn("id", QLType::Create(DataType::UUID))); |
53 | 2.00k | CHECK_OK(builder.AddColumn("include_all_columns", QLType::Create(DataType::BOOL))); |
54 | 2.00k | CHECK_OK(builder.AddColumn("max_index_interval", QLType::Create(DataType::INT32))); |
55 | 2.00k | CHECK_OK(builder.AddColumn("memtable_flush_period_in_ms", QLType::Create(DataType::INT32))); |
56 | 2.00k | CHECK_OK(builder.AddColumn("min_index_interval", QLType::Create(DataType::INT32))); |
57 | 2.00k | CHECK_OK(builder.AddColumn("read_repair_chance", QLType::Create(DataType::DOUBLE))); |
58 | 2.00k | CHECK_OK(builder.AddColumn("speculative_retry", QLType::Create(DataType::STRING))); |
59 | 2.00k | CHECK_OK(builder.AddColumn("where_clause", QLType::Create(DataType::STRING))); |
60 | 2.00k | return builder.Build(); |
61 | 2.00k | } |
62 | | |
63 | | } // namespace master |
64 | | } // namespace yb |