forked from qwazr/jdbc-cache-driver
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCachedResultSetMetaData.java
150 lines (122 loc) · 4.17 KB
/
CachedResultSetMetaData.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
/*
* Copyright 2016-2017 Emmanuel Keller / QWAZR
* <p>
* Licensed 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
* <p>
* http://www.apache.org/licenses/LICENSE-2.0
* <p>
* 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 com.qwazr.jdbc.cache;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.SQLFeatureNotSupportedException;
class CachedResultSetMetaData implements ResultSetMetaData {
final ResultSetWriter.ColumnDef[] columns;
CachedResultSetMetaData(ResultSetWriter.ColumnDef[] columns) {
this.columns = columns;
}
@Override
public int getColumnCount() throws SQLException {
return columns.length;
}
private ResultSetWriter.ColumnDef getColumns(final int column) throws SQLException {
if (column == 0 || column > columns.length)
throw new SQLException("Wrong column number: " + column);
return columns[column - 1];
}
@Override
public boolean isAutoIncrement(int column) throws SQLException {
return getColumns(column).isAutoIncrement;
}
@Override
public boolean isCaseSensitive(int column) throws SQLException {
return getColumns(column).isCaseSensitive;
}
@Override
public boolean isSearchable(int column) throws SQLException {
return getColumns(column).isSearchable;
}
@Override
public boolean isCurrency(int column) throws SQLException {
return getColumns(column).isCurrency;
}
@Override
public int isNullable(int column) throws SQLException {
return getColumns(column).isNullable;
}
@Override
public boolean isSigned(int column) throws SQLException {
return getColumns(column).isSigned;
}
@Override
public int getColumnDisplaySize(int column) throws SQLException {
return getColumns(column).displaySize;
}
@Override
public String getColumnLabel(int column) throws SQLException {
return getColumns(column).label;
}
@Override
public String getColumnName(int column) throws SQLException {
return getColumns(column).name;
}
@Override
public String getSchemaName(int column) throws SQLException {
return getColumns(column).schemaName;
}
@Override
public int getPrecision(int column) throws SQLException {
return getColumns(column).precision;
}
@Override
public int getScale(int column) throws SQLException {
return getColumns(column).scale;
}
@Override
public String getTableName(int column) throws SQLException {
return getColumns(column).tableName;
}
@Override
public String getCatalogName(int column) throws SQLException {
return getColumns(column).catalog;
}
@Override
public int getColumnType(int column) throws SQLException {
return getColumns(column).type;
}
@Override
public String getColumnTypeName(int column) throws SQLException {
return getColumns(column).typeName;
}
@Override
public boolean isReadOnly(int column) throws SQLException {
return getColumns(column).isReadOnly;
}
@Override
public boolean isWritable(int column) throws SQLException {
return getColumns(column).isWritable;
}
@Override
public boolean isDefinitelyWritable(int column) throws SQLException {
return getColumns(column).isDefinitelyWritable;
}
@Override
public String getColumnClassName(int column) throws SQLException {
return getColumns(column).className;
}
@Override
public <T> T unwrap(Class<T> iface) throws SQLException {
throw new SQLFeatureNotSupportedException();
}
@Override
public boolean isWrapperFor(Class<?> iface) throws SQLException {
throw new SQLFeatureNotSupportedException();
}
}