{"id":7378,"date":"2015-06-01T19:46:06","date_gmt":"2015-06-01T10:46:06","guid":{"rendered":"http:\/\/www.techscore.com\/blog\/?p=7378"},"modified":"2018-11-14T16:33:48","modified_gmt":"2018-11-14T07:33:48","slug":"presto-connector-development-2","status":"publish","type":"post","link":"https:\/\/www.techscore.com\/blog\/2015\/06\/01\/presto-connector-development-2\/","title":{"rendered":"Presto \u30b3\u30cd\u30af\u30bf\u30fc\u3092\u5b9f\u88c5\u3059\u308b \u7b2c\u4e8c\u56de"},"content":{"rendered":"
\u3053\u3093\u306b\u3061\u306f\u3002\u677e\u672c\u3067\u3059\u3002<\/p>\n
\u524d\u56de<\/a>\u306b\u7d9a\u304d\u3001Presto \u306e\u30b3\u30cd\u30af\u30bf\u30fc\u5b9f\u88c5\u65b9\u6cd5\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002\u7b2c\u4e8c\u56de\u306e\u4eca\u56de\u306f\u30c6\u30fc\u30d6\u30eb\u306e\u30cf\u30f3\u30c9\u30eb\u30af\u30e9\u30b9\u3084\u30e1\u30bf\u30c7\u30fc\u30bf\u3092\u64cd\u4f5c\u3059\u308b\u30af\u30e9\u30b9\u3092\u6271\u3044\u307e\u3059\u3002<\/p>\n \u5b9f\u88c5\u3059\u308b\u4e3b\u306a\u30af\u30e9\u30b9\u306f\u6b21\u306e 4 \u3064\u3067\u3059\u3002<\/p>\n Presto \u30b3\u30cd\u30af\u30bf\u30fc\u3067\u306f\u3001 \u307e\u305a\u306f\u30ab\u30e9\u30e0\u30cf\u30f3\u30c9\u30eb\u3002<\/p>\n \u5b9f\u88c5\u306e\u30dd\u30a4\u30f3\u30c8\u3068\u3057\u3066\u3001Presto \u672c\u4f53\u5074\u3067\u672c\u30af\u30e9\u30b9\u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u304c\u30ad\u30e3\u30c3\u30b7\u30e5\u3055\u308c\u308b\u3088\u3046\u3001 Presto \u3067\u306f\u30b1\u30fc\u30b9\u7121\u8996\u3067\u30ab\u30e9\u30e0\u540d\u304c\u6271\u308f\u308c\u308b\u70ba\u3001 \u4e3b\u306a\u30c7\u30fc\u30bf\u578b\u3067\u3059\u3002<\/p>\n \u6700\u7d42\u7684\u306b\u3001\u3053\u308c\u3089\u306e\u60c5\u5831\u3092\u4f7f\u3044 \u6b21\u306b\u30c6\u30fc\u30d6\u30eb\u30cf\u30f3\u30c9\u30eb\u3002<\/p>\n \u4eca\u56de\u306e\u5b9f\u88c5\u3067\u306f \u3053\u3061\u3089\u3082 \u4eca\u56de\u306e\u5b9f\u88c5\u3067\u306f \u6b21\u306f\u91cd\u8981\u306a\u30e1\u30bf\u30c7\u30fc\u30bf\u30af\u30e9\u30b9\u3002Presto \u306f \u30b3\u30f3\u30b9\u30c8\u30e9\u30af\u30bf\u3067\u6ce8\u5165\u3057\u3066\u3044\u308b \n
\u30cf\u30f3\u30c9\u30eb\u30af\u30e9\u30b9<\/h2>\n
ConnectorTableHandle<\/code><\/a> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3068
ConnectorColumnHandle<\/code><\/a> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u3092\u4f7f\u3063\u3066\u3001\u30c6\u30fc\u30d6\u30eb\u3084\u30ab\u30e9\u30e0\u3092\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3057\u307e\u3059\u3002<\/p>\n
com.techscore.example.presto.plugin.TechscoreColumnHandle<\/h3>\n
\r\npackage com.techscore.example.presto.plugin;\r\n\r\nimport lombok.EqualsAndHashCode;\r\nimport lombok.NonNull;\r\nimport lombok.ToString;\r\n\r\nimport com.facebook.presto.spi.ColumnMetadata;\r\nimport com.facebook.presto.spi.ConnectorColumnHandle;\r\nimport com.facebook.presto.spi.type.Type;\r\nimport com.fasterxml.jackson.annotation.JsonCreator;\r\nimport com.fasterxml.jackson.annotation.JsonIgnore;\r\nimport com.fasterxml.jackson.annotation.JsonProperty;\r\nimport com.google.common.primitives.Ints;\r\n\r\n@EqualsAndHashCode\r\n@ToString\r\npublic class TechscoreColumnHandle implements ConnectorColumnHandle, Comparable
ConnectorColumnHandle<\/code> \u5b9f\u88c5\u30af\u30e9\u30b9\u306f\u3001\u30b3\u30cd\u30af\u30bf\u30fc\u5185\u3067\u30ab\u30e9\u30e0\u3092\u6271\u3044\u3084\u3059\u3044\u3088\u3046\u597d\u304d\u306b\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n
@JsonCreator<\/code> \u3084
@JsonProperty<\/code> \u30a2\u30ce\u30c6\u30fc\u30b7\u30e7\u30f3\u3092\u4f7f\u3063\u3066 JSON \u3067\u306e\u30b7\u30ea\u30a2\u30e9\u30a4\u30ba\uff0f\u30c7\u30b7\u30ea\u30a2\u30e9\u30a4\u30ba\u3092\u53ef\u80fd\u3068\u3059\u308b\u3053\u3068\u3067\u3059\u3002<\/p>\n
caseSensitiveName<\/code> \u3067\u6e21\u3055\u308c\u305f\u30ab\u30e9\u30e0\u540d\u3092\u5c0f\u6587\u5b57\u5316\u3057\u305f
name<\/code> \u30d7\u30ed\u30d1\u30c6\u30a3\u3082\u6301\u3064\u3088\u3046\u306b\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n
\r\n this.name = caseSensitiveName.toLowerCase();\r\n<\/pre>\n
type<\/code> \u30d7\u30ed\u30d1\u30c6\u30a3\u306f\u30ab\u30e9\u30e0\u306e\u30c7\u30fc\u30bf\u578b\u3092\u8868\u3059\u30af\u30e9\u30b9\u3067\u3001
com.facebook.presto.spi.type<\/a><\/code> \u30d1\u30c3\u30b1\u30fc\u30b8\u5185\u306b\u57fa\u672c\u7684\u306a\u30c7\u30fc\u30bf\u578b\u304c\u7528\u610f\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n
\n
ordinalPosition<\/code> \u30d7\u30ed\u30d1\u30c6\u30a3\u306f\u30c6\u30fc\u30d6\u30eb\u5185\u3067\u306e\u3053\u306e\u30ab\u30e9\u30e0\u306e\u9806\u5e8f\u3092\u8868\u3057\u307e\u3059\u3002\u3053\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\u306f Presto \u304c\u4f7f\u7528\u3059\u308b\u30ab\u30e9\u30e0\u30e1\u30bf\u30c7\u30fc\u30bf\u30af\u30e9\u30b9\u3067\u3042\u308b
ColumnMetadata<\/code> \u306b\u3082\u5f15\u304d\u7d99\u304c\u308c\u3001
SELECT *<\/code> \u7b49\u3067 SQL \u304c\u767a\u884c\u3055\u308c\u305f\u5834\u5408\u306e\u30ab\u30e9\u30e0\u306e\u4e26\u3073\u9806\u3068\u3057\u3066\u5229\u7528\u3055\u308c\u307e\u3059\u3002<\/p>\n
ColumnMetadata<\/code><\/a> \u3092\u751f\u6210\u3057\u307e\u3059\u3002<\/p>\n
com.techscore.example.presto.plugin.TechscoreTableHandle<\/h3>\n
\r\npackage com.techscore.example.presto.plugin;\r\n\r\nimport lombok.EqualsAndHashCode;\r\nimport lombok.NonNull;\r\nimport lombok.ToString;\r\n\r\nimport com.facebook.presto.spi.ConnectorTableHandle;\r\nimport com.facebook.presto.spi.SchemaTableName;\r\nimport com.fasterxml.jackson.annotation.JsonCreator;\r\nimport com.fasterxml.jackson.annotation.JsonIgnore;\r\nimport com.fasterxml.jackson.annotation.JsonProperty;\r\n\r\n@EqualsAndHashCode\r\n@ToString\r\npublic class TechscoreTableHandle implements ConnectorTableHandle {\r\n\r\n private final String connectorId;\r\n private final SchemaTableName schemaTableName;\r\n\r\n @JsonCreator\r\n public TechscoreTableHandle(\r\n @JsonProperty(\"connectorId\") @NonNull String connectorId,\r\n @JsonProperty(\"schemaTableName\") @NonNull SchemaTableName schemaTableName) {\r\n this.connectorId = connectorId;\r\n this.schemaTableName = schemaTableName;\r\n }\r\n\r\n @JsonProperty\r\n public String getConnectorId() {\r\n return connectorId;\r\n }\r\n\r\n @JsonProperty\r\n public SchemaTableName getSchemaTableName() {\r\n return schemaTableName;\r\n }\r\n\r\n @JsonIgnore\r\n public String getSchemaName() {\r\n return getSchemaTableName().getSchemaName();\r\n }\r\n\r\n @JsonIgnore\r\n public String getTableName() {\r\n return getSchemaTableName().getTableName();\r\n }\r\n}\r\n<\/pre>\n
ConnectorTableHandle<\/code> \u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u3082\u3001\u30b3\u30cd\u30af\u30bf\u30fc\u5185\u3067\u30c6\u30fc\u30d6\u30eb\u60c5\u5831\u304c\u6271\u3044\u3084\u3059\u3044\u3088\u3046\u597d\u304d\u306b\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n
connectorId<\/code> \u3068
SchemaTableName<\/code> \u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u3092\u6301\u3064\u3060\u3051\u3068\u3057\u3066\u3044\u307e\u3059\u3002
SchemaTableName<\/code><\/a> \u306f\u305d\u306e\u540d\u306e\u901a\u308a\u5bfe\u8c61\u30c6\u30fc\u30d6\u30eb\u306e\u30b9\u30ad\u30fc\u30de\u540d\u3068\u30c6\u30fc\u30d6\u30eb\u540d\u3092\u6301\u3064\u30af\u30e9\u30b9\u3067\u3059\u3002<\/p>\n
TechscoreColumnHandle<\/code> \u540c\u69d8\u3001JSON \u3067\u306e\u30b7\u30ea\u30a2\u30e9\u30a4\u30ba\uff0f\u30c7\u30b7\u30ea\u30a2\u30e9\u30a4\u30ba\u304c\u53ef\u80fd\u306b\u306a\u308b\u3088\u3046\u30a2\u30ce\u30c6\u30fc\u30b7\u30e7\u30f3\u3092\u4ed8\u3051\u3066\u3044\u307e\u3059\u3002
TechscoreTableHandle<\/code> \u3067\u306f JSON \u3067\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\u5316\u3092\u898b\u8fbc\u3093\u3067\u3001\u3042\u307e\u308a\u30d5\u30a1\u30c3\u30c8\u306a\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306b\u306a\u3089\u306a\u3044\u3088\u3046\u8003\u616e\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n
com.techscore.example.presto.plugin.TechscoreHandleResolver<\/h3>\n
\r\npackage com.techscore.example.presto.plugin;\r\n\r\nimport static com.google.common.base.Preconditions.checkArgument;\r\n\r\nimport javax.inject.Inject;\r\n\r\nimport lombok.NonNull;\r\nimport lombok.Value;\r\n\r\nimport com.facebook.presto.spi.ConnectorColumnHandle;\r\nimport com.facebook.presto.spi.ConnectorHandleResolver;\r\nimport com.facebook.presto.spi.ConnectorIndexHandle;\r\nimport com.facebook.presto.spi.ConnectorInsertTableHandle;\r\nimport com.facebook.presto.spi.ConnectorOutputTableHandle;\r\nimport com.facebook.presto.spi.ConnectorSplit;\r\nimport com.facebook.presto.spi.ConnectorTableHandle;\r\nimport com.google.inject.name.Named;\r\n\r\n@Value\r\npublic class TechscoreHandleResolver implements ConnectorHandleResolver {\r\n\r\n private final String connectorId;\r\n\r\n @Inject\r\n TechscoreHandleResolver(@Named(\"connectorId\") @NonNull String connectorId) {\r\n this.connectorId = connectorId;\r\n }\r\n\r\n @Override\r\n public boolean canHandle(ConnectorTableHandle tableHandle) {\r\n return tableHandle != null && tableHandle instanceof TechscoreTableHandle\r\n && getConnectorId().equals(((TechscoreTableHandle) tableHandle).getConnectorId());\r\n }\r\n\r\n @Override\r\n public boolean canHandle(ConnectorColumnHandle columnHandle) {\r\n return columnHandle != null && columnHandle instanceof TechscoreColumnHandle\r\n && getConnectorId().equals(((TechscoreColumnHandle) columnHandle).getConnectorId());\r\n }\r\n\r\n @Override\r\n public boolean canHandle(ConnectorSplit split) {\r\n return split != null && split instanceof TechscoreSplit\r\n && getConnectorId().equals(((TechscoreSplit) split).getConnectorId());\r\n }\r\n\r\n @Override\r\n public boolean canHandle(ConnectorIndexHandle indexHandle) {\r\n return false;\r\n }\r\n\r\n @Override\r\n public boolean canHandle(ConnectorOutputTableHandle tableHandle) {\r\n return false;\r\n }\r\n\r\n @Override\r\n public boolean canHandle(ConnectorInsertTableHandle tableHandle) {\r\n return false;\r\n }\r\n\r\n @Override\r\n public Class extends ConnectorTableHandle> getTableHandleClass() {\r\n return TechscoreTableHandle.class;\r\n }\r\n\r\n @Override\r\n public Class extends ConnectorColumnHandle> getColumnHandleClass() {\r\n return TechscoreColumnHandle.class;\r\n }\r\n\r\n @Override\r\n public Class extends ConnectorSplit> getSplitClass() {\r\n return TechscoreSplit.class;\r\n }\r\n\r\n @Override\r\n public Class extends ConnectorIndexHandle> getIndexHandleClass() {\r\n throw new UnsupportedOperationException();\r\n }\r\n\r\n @Override\r\n public Class extends ConnectorOutputTableHandle> getOutputTableHandleClass() {\r\n throw new UnsupportedOperationException();\r\n }\r\n\r\n @Override\r\n public Class extends ConnectorInsertTableHandle> getInsertTableHandleClass() {\r\n throw new UnsupportedOperationException();\r\n }\r\n\r\n TechscoreTableHandle convertTableHandle(ConnectorTableHandle tableHandle) {\r\n checkArgument(canHandle(tableHandle));\r\n return (TechscoreTableHandle) tableHandle;\r\n }\r\n\r\n TechscoreColumnHandle convertColumnHandle(ConnectorColumnHandle columnHandle) {\r\n checkArgument(canHandle(columnHandle));\r\n return (TechscoreColumnHandle) columnHandle;\r\n }\r\n\r\n TechscoreSplit convertSplit(ConnectorSplit split) {\r\n checkArgument(canHandle(split));\r\n return (TechscoreSplit) split;\r\n }\r\n}\r\n<\/pre>\n
ConnectorHandleResulver<\/code> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u306f\u3053\u3093\u306a\u3082\u306e\u3068\u898b\u3066\u9802\u3051\u3070\u5341\u5206\u3067\u3059\u3002\u5404\u7a2e\u30cf\u30f3\u30c9\u30eb\u30af\u30e9\u30b9\u3092\u6271\u3046\u30b7\u30f3\u30d7\u30eb\u306a\u30e1\u30bd\u30c3\u30c9\u3092\u6301\u3063\u3066\u3044\u308b\u3060\u3051\u306e\u30af\u30e9\u30b9\u3067\u3059\u3002<\/p>\n
ConnectorTableHandle<\/code>,
ConnectorColumnHandle<\/code>,
ConnectorSplit<\/code> \u4ee5\u5916\u306f\u6271\u308f\u306a\u3044\u306e\u3067\u3001\u3053\u308c\u3089\u306b\u95a2\u4fc2\u3057\u306a\u3044\u30e1\u30bd\u30c3\u30c9\u306f
UnsupportedOperationException<\/code> \u3092\u30b9\u30ed\u30fc\u3057\u305f\u308a\u3001
false<\/code> \u3092\u8fd4\u3059\u306e\u307f\u3068\u3057\u307e\u3057\u305f\u3002<\/p>\n
canHandle()<\/code> \u30e1\u30bd\u30c3\u30c9\u3084
getSplitClass()<\/code> \u7b49\u3067\u4f7f\u308f\u308c\u3066\u3044\u308b
ConnectorSplit<\/code><\/a> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3068\u305d\u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u3067\u3042\u308b
TechscoreSplit<\/code> \u306b\u3064\u3044\u3066\u306f\u6b21\u56de\u3001\u89e6\u308c\u308b\u4e88\u5b9a\u3067\u3059\u3002<\/p>\n
\u30e1\u30bf\u30c7\u30fc\u30bf\u64cd\u4f5c\u30af\u30e9\u30b9<\/h2>\n
ConnectorMetadata<\/code><\/a> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u3092\u901a\u3057\u3066\u3001\u30b3\u30cd\u30af\u30bf\u30fc\u304c\u6271\u3046\u5404\u7a2e\u30e1\u30bf\u30c7\u30fc\u30bf\u306b\u30a2\u30af\u30bb\u30b9\u3057\u307e\u3059\u3002<\/p>\n
com.techscore.example.presto.plugin.TechscoreMetadata<\/h3>\n
\r\npackage com.techscore.example.presto.plugin;\r\n\r\nimport static java.util.stream.Collectors.toList;\r\n\r\nimport java.util.ArrayList;\r\nimport java.util.HashMap;\r\nimport java.util.List;\r\nimport java.util.Map;\r\nimport java.util.stream.Collectors;\r\n\r\nimport javax.inject.Inject;\r\n\r\nimport lombok.Getter;\r\nimport lombok.NonNull;\r\nimport lombok.val;\r\n\r\nimport org.weakref.jmx.internal.guava.collect.ImmutableList;\r\n\r\nimport com.facebook.presto.spi.ColumnMetadata;\r\nimport com.facebook.presto.spi.ConnectorColumnHandle;\r\nimport com.facebook.presto.spi.ConnectorSession;\r\nimport com.facebook.presto.spi.ConnectorTableHandle;\r\nimport com.facebook.presto.spi.ConnectorTableMetadata;\r\nimport com.facebook.presto.spi.ReadOnlyConnectorMetadata;\r\nimport com.facebook.presto.spi.SchemaTableName;\r\nimport com.facebook.presto.spi.SchemaTablePrefix;\r\nimport com.google.common.collect.ImmutableMap;\r\nimport com.google.inject.name.Named;\r\n\r\npublic class TechscoreMetadata extends ReadOnlyConnectorMetadata {\r\n\r\n @Getter\r\n private final String connectorId;\r\n\r\n @Getter\r\n private final TechscoreClient tClient;\r\n\r\n @Getter\r\n private final TechscoreHandleResolver tHandleResolver;\r\n\r\n @Getter\r\n private final TechscoreConnectorConfig tConnectorConfig;\r\n\r\n @Inject\r\n public TechscoreMetadata(@Named(\"connectorId\") @NonNull String connectorId,\r\n @NonNull TechscoreClient tClient,\r\n @NonNull TechscoreHandleResolver tHandleResolver,\r\n @NonNull TechscoreConnectorConfig tConnectorConfig) {\r\n this.connectorId = connectorId;\r\n this.tClient = tClient;\r\n this.tHandleResolver = tHandleResolver;\r\n this.tConnectorConfig = tConnectorConfig;\r\n }\r\n\r\n @Override\r\n public List
ConnectorMetadata<\/code><\/a> \u306f\u3001
ConnectorTableHandle<\/code> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u304a\u3088\u3073
TechscoreColumnHandle<\/code> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u64cd\u4f5c\u3059\u308b\u91cd\u8981\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3067\u3059\u3002\u305d\u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u3067\u3042\u308b
TechscoreMetadata<\/code> \u306f\u3001
ConnectorMetadata<\/code> \u306e\u62bd\u8c61\u30af\u30e9\u30b9\u3067\u3042\u308b
ReadOnlyConnectorMetadata<\/code><\/a> \u306e\u30b5\u30d6\u30af\u30e9\u30b9\u3068\u3057\u3066\u5b9f\u88c5\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n
TechscoreClient<\/code> \u306f\u672c\u30b5\u30f3\u30d7\u30eb\u30b3\u30cd\u30af\u30bf\u30fc\u306e\u70ba\u306b\u7528\u610f\u3057\u305f POJO \u3067\u3001\u4eee\u60f3\u306e\u300cTECHSCORE \u30d6\u30ed\u30b0 API \u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u300d\u3067\u3059\u3002\u30b5\u30f3\u30d7\u30eb\u30b3\u30cd\u30af\u30bf\u30fc\u306f\u3053\u306e\u30af\u30e9\u30b9\u3092\u901a\u3057\u3066\u30c6\u30fc\u30d6\u30eb\u306e\u30e1\u30bf\u30c7\u30fc\u30bf\u3084\u30ec\u30b3\u30fc\u30c9\u3092\u53d6\u5f97\u3057\u307e\u3059\uff08\u4eca\u56de\u306f\u30b5\u30f3\u30d7\u30eb\u306a\u306e\u3067\u9759\u7684\u306b\u60c5\u5831\u3092\u8fd4\u3057\u3066\u3044\u308b\u3060\u3051\u306e\u30af\u30e9\u30b9\u3068\u306a\u3063\u3066\u3044\u307e\u3059\uff09\u3002
TechscoreClient<\/code> \u3068\u305d\u306e\u95a2\u9023\u30af\u30e9\u30b9\u306b\u3064\u3044\u3066\u306f\u672c\u8a18\u4e8b\u306e\u6700\u5f8c\u306b\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3092\u63b2\u8f09\u3057\u307e\u3059\u3002<\/p>\n
listSchemaNames()<\/code> \u30e1\u30bd\u30c3\u30c9\u306f\u30b3\u30cd\u30af\u30bf\u30fc\u304c\u6271\u3046\u30b9\u30ad\u30fc\u30de\u306e\u540d\u524d\u3092\u8fd4\u3059\u3082\u306e\u3067\u3001
show schemas from techscore;<\/code> \u7b49\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u305f\u5834\u5408\u306b\u5229\u7528\u3055\u308c\u307e\u3059\u3002<\/p>\n
getTableHandle()<\/code> \u30e1\u30bd\u30c3\u30c9\u3084
getColumnHandles()<\/code> \u30e1\u30bd\u30c3\u30c9\u306f\u6307\u5b9a\u3055\u308c\u305f\u30c6\u30fc\u30d6\u30eb\u306e\u30c6\u30fc\u30d6\u30eb\u30cf\u30f3\u30c9\u30eb\u3084\u30ab\u30e9\u30e0\u30cf\u30f3\u30c9\u30eb\u3092\u8fd4\u3059\u3082\u306e\u3067\u3059\u3002\u30b7\u30b0\u30cb\u30c1\u30e3\u7684\u306b\u306f\u623b\u308a\u5024\u306e\u578b\u304c
ConnectorTableHandle<\/code> \u3084
ConnectorColumnHandle<\/code> \u3068\u306a\u3063\u3066\u3044\u307e\u3059\u304c\u3001\u672c\u30b3\u30cd\u30af\u30bf\u30fc\u3067\u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u3067\u3042\u308b
TechscoreTableHandle<\/code>,
TechscoreColumnHandle<\/code> \u3092\u8fd4\u3059\u3088\u3046\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n
getTableMetadata()<\/code> \u30e1\u30bd\u30c3\u30c9\u3084
getColumnMetadata()<\/code> \u30e1\u30bd\u30c3\u30c9\u306f\u3001\u30cf\u30f3\u30c9\u30eb\u3092
ConnectorTableMetadata<\/code><\/a> \u3084
ColumnMetadata<\/code><\/a> \u3068\u3044\u3063\u305f\u30e1\u30bf\u30c7\u30fc\u30bf\u306b\u5909\u63db\u3059\u308b\u3082\u306e\u3067\u3059\u3002\u5f15\u6570\u306f\u578b\u3068\u3057\u3066
ConnectorTableHandle<\/code> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3084
ConnectorColumnHandle<\/code> \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u304c\u5b9a\u7fa9\u3055\u308c\u3066\u3044\u307e\u3059\u304c\u3001\u5b9f\u969b\u306b\u306f\u305d\u306e\u5b9f\u88c5\u30af\u30e9\u30b9\u3067\u3042\u308b
TechscoreTableHandle<\/code>,
TechscoreColumnHandle<\/code> \u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u304c\u6e21\u3055\u308c\u307e\u3059\u3002<\/p>\n
listTables()<\/code> \u30e1\u30bd\u30c3\u30c9\u306f\u30b3\u30cd\u30af\u30bf\u30fc\u304c\u6271\u3046\u30c6\u30fc\u30d6\u30eb\u306e
SchemaTableName<\/code> \u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306e\u30ea\u30b9\u30c8\u3092\u8fd4\u3059\u3082\u306e\u3067\u3001
show tables from techscore.schema1;<\/code> \u306e\u3088\u3046\u306a\u30b3\u30de\u30f3\u30c9\u767a\u884c\u6642\u306b\u5229\u7528\u3055\u308c\u307e\u3059\u3002\u3053\u3053\u3067\u8fd4\u3059
SchemaTableName<\/code> \u306e\u30ea\u30b9\u30c8\u306f\u3001\u5f15\u6570
String schemaNameOrNull<\/code> \u304c\u6307\u5b9a\u3059\u308b\u30b9\u30ad\u30fc\u30de\u306b\u5c5e\u3059\u30c6\u30fc\u30d6\u30eb\u306b\u3064\u3044\u3066\u3060\u3051\u3092\u6271\u3044\u307e\u3059\u304c\u3001
schemaNameOrNull<\/code> \u306e\u5024\u304c
null<\/code> \u306e\u5834\u5408\u306f\u30b9\u30ad\u30fc\u30de\u306b\u95a2\u4fc2\u306a\u304f\u5168\u3066\u306e\u30c6\u30fc\u30d6\u30eb\u306e
SchemaTableName<\/code> \u3092\u8fd4\u3059\u3088\u3046\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n