/
ColumnDescriptor.java
99 lines (83 loc) · 2.87 KB
/
ColumnDescriptor.java
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
93
94
95
96
97
98
99
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.hive.service.cli;
import org.apache.hadoop.hive.metastore.api.FieldSchema;
import org.apache.hive.service.cli.thrift.TColumnDesc;
/**
* ColumnDescriptor.
*
*/
public class ColumnDescriptor {
private final String name;
private final String comment;
private final TypeDescriptor type;
// ordinal position of this column in the schema
private final int position;
public ColumnDescriptor(String name, String comment, TypeDescriptor type, int position) {
this.name = name;
this.comment = comment;
this.type = type;
this.position = position;
}
public ColumnDescriptor(TColumnDesc tColumnDesc) {
name = tColumnDesc.getColumnName();
comment = tColumnDesc.getComment();
type = new TypeDescriptor(tColumnDesc.getTypeDesc());
position = tColumnDesc.getPosition();
}
public ColumnDescriptor(FieldSchema column, int position) {
name = column.getName();
comment = column.getComment();
type = new TypeDescriptor(column.getType());
this.position = position;
}
public static ColumnDescriptor newPrimitiveColumnDescriptor(String name, String comment, Type type, int position) {
// Current usage looks like it's only for metadata columns, but if that changes then
// this method may need to require a type qualifiers aruments.
return new ColumnDescriptor(name, comment, new TypeDescriptor(type), position);
}
public String getName() {
return name;
}
public String getComment() {
return comment;
}
public TypeDescriptor getTypeDescriptor() {
return type;
}
public int getOrdinalPosition() {
return position;
}
public TColumnDesc toTColumnDesc() {
TColumnDesc tColumnDesc = new TColumnDesc();
tColumnDesc.setColumnName(name);
tColumnDesc.setComment(comment);
tColumnDesc.setTypeDesc(type.toTTypeDesc());
tColumnDesc.setPosition(position);
return tColumnDesc;
}
public Type getType() {
return type.getType();
}
public boolean isPrimitive() {
return type.getType().isPrimitiveType();
}
public String getTypeName() {
return type.getTypeName();
}
}