|
22 | 22 | import com.google.cloud.spanner.Type; |
23 | 23 | import java.io.Serializable; |
24 | 24 | import java.util.List; |
| 25 | +import java.util.Map; |
25 | 26 | import org.apache.beam.vendor.guava.v32_1_2_jre.com.google.common.annotations.VisibleForTesting; |
26 | 27 | import org.apache.beam.vendor.guava.v32_1_2_jre.com.google.common.collect.ImmutableList; |
27 | 28 | import org.apache.beam.vendor.guava.v32_1_2_jre.com.google.common.collect.ImmutableListMultimap; |
@@ -161,47 +162,50 @@ static Column create(String name, String spannerType, Dialect dialect) { |
161 | 162 |
|
162 | 163 | public abstract Type getType(); |
163 | 164 |
|
| 165 | + private static final Map<String, Type> GOOGLE_STANDARD_SQL_TYPE_MAP = |
| 166 | + ImmutableMap.<String, Type>builder() |
| 167 | + .put("BOOL", Type.bool()) |
| 168 | + .put("INT64", Type.int64()) |
| 169 | + .put("FLOAT32", Type.float32()) |
| 170 | + .put("FLOAT64", Type.float64()) |
| 171 | + .put("UUID", Type.string()) |
| 172 | + .put("TOKENLIST", Type.bytes()) |
| 173 | + .put("TIMESTAMP", Type.timestamp()) |
| 174 | + .put("DATE", Type.date()) |
| 175 | + .put("NUMERIC", Type.numeric()) |
| 176 | + .put("JSON", Type.json()) |
| 177 | + .build(); |
| 178 | + private static final Map<String, Type> POSTGRES_TYPE_MAP = |
| 179 | + ImmutableMap.<String, Type>builder() |
| 180 | + .put("BOOLEAN", Type.bool()) |
| 181 | + .put("BIGINT", Type.int64()) |
| 182 | + .put("REAL", Type.float32()) |
| 183 | + .put("DOUBLE PRECISION", Type.float64()) |
| 184 | + .put("CHARACTER VARYING", Type.string()) |
| 185 | + .put("TEXT", Type.string()) |
| 186 | + .put("BYTEA", Type.bytes()) |
| 187 | + .put("TIMESTAMP WITH TIME ZONE", Type.timestamp()) |
| 188 | + .put("DATE", Type.date()) |
| 189 | + .put("SPANNER.COMMIT_TIMESTAMP", Type.timestamp()) |
| 190 | + .put("SPANNER.TOKENLIST", Type.bytes()) |
| 191 | + .put("UUID", Type.string()) |
| 192 | + .build(); |
| 193 | + |
164 | 194 | private static Type parseSpannerType(String spannerType, Dialect dialect) { |
165 | 195 | String originalSpannerType = spannerType; |
166 | 196 | spannerType = spannerType.toUpperCase(); |
167 | 197 | switch (dialect) { |
168 | 198 | case GOOGLE_STANDARD_SQL: |
169 | | - if ("BOOL".equals(spannerType)) { |
170 | | - return Type.bool(); |
171 | | - } |
172 | | - if ("INT64".equals(spannerType)) { |
173 | | - return Type.int64(); |
174 | | - } |
175 | | - if ("FLOAT32".equals(spannerType)) { |
176 | | - return Type.float32(); |
177 | | - } |
178 | | - if ("FLOAT64".equals(spannerType)) { |
179 | | - return Type.float64(); |
| 199 | + Type type = GOOGLE_STANDARD_SQL_TYPE_MAP.get(spannerType); |
| 200 | + if (type != null) { |
| 201 | + return type; |
180 | 202 | } |
181 | 203 | if (spannerType.startsWith("STRING")) { |
182 | 204 | return Type.string(); |
183 | 205 | } |
184 | | - if ("UUID".equals(spannerType)) { |
185 | | - return Type.string(); |
186 | | - } |
187 | 206 | if (spannerType.startsWith("BYTES")) { |
188 | 207 | return Type.bytes(); |
189 | 208 | } |
190 | | - if ("TOKENLIST".equals(spannerType)) { |
191 | | - return Type.bytes(); |
192 | | - } |
193 | | - if ("TIMESTAMP".equals(spannerType)) { |
194 | | - return Type.timestamp(); |
195 | | - } |
196 | | - if ("DATE".equals(spannerType)) { |
197 | | - return Type.date(); |
198 | | - } |
199 | | - if ("NUMERIC".equals(spannerType)) { |
200 | | - return Type.numeric(); |
201 | | - } |
202 | | - if ("JSON".equals(spannerType)) { |
203 | | - return Type.json(); |
204 | | - } |
205 | 209 | if (spannerType.startsWith("ARRAY")) { |
206 | 210 | // Substring "ARRAY<xxx>" |
207 | 211 | String spannerArrayType = |
@@ -230,42 +234,16 @@ private static Type parseSpannerType(String spannerType, Dialect dialect) { |
230 | 234 | Type itemType = parseSpannerType(spannerArrayType, dialect); |
231 | 235 | return Type.array(itemType); |
232 | 236 | } |
233 | | - if ("BOOLEAN".equals(spannerType)) { |
234 | | - return Type.bool(); |
235 | | - } |
236 | | - if ("BIGINT".equals(spannerType)) { |
237 | | - return Type.int64(); |
238 | | - } |
239 | | - if ("REAL".equals(spannerType)) { |
240 | | - return Type.float32(); |
241 | | - } |
242 | | - if ("DOUBLE PRECISION".equals(spannerType)) { |
243 | | - return Type.float64(); |
244 | | - } |
245 | | - if (spannerType.startsWith("CHARACTER VARYING") || "TEXT".equals(spannerType)) { |
246 | | - return Type.string(); |
247 | | - } |
248 | | - if ("BYTEA".equals(spannerType)) { |
249 | | - return Type.bytes(); |
250 | | - } |
251 | | - if ("TIMESTAMP WITH TIME ZONE".equals(spannerType)) { |
252 | | - return Type.timestamp(); |
253 | | - } |
254 | | - if ("DATE".equals(spannerType)) { |
255 | | - return Type.date(); |
| 237 | + type = POSTGRES_TYPE_MAP.get(spannerType); |
| 238 | + if (type != null) { |
| 239 | + return type; |
256 | 240 | } |
257 | 241 | if (spannerType.startsWith("NUMERIC")) { |
258 | 242 | return Type.pgNumeric(); |
259 | 243 | } |
260 | | - if ("SPANNER.COMMIT_TIMESTAMP".equals(spannerType)) { |
261 | | - return Type.timestamp(); |
262 | | - } |
263 | 244 | if (spannerType.startsWith("JSONB")) { |
264 | 245 | return Type.pgJsonb(); |
265 | 246 | } |
266 | | - if ("UUID".equals(spannerType)) { |
267 | | - return Type.string(); |
268 | | - } |
269 | 247 | throw new IllegalArgumentException("Unknown spanner type " + spannerType); |
270 | 248 | default: |
271 | 249 | throw new IllegalArgumentException("Unrecognized dialect: " + dialect.name()); |
|
0 commit comments