java getscale_Java MajorType.getScale方法代碼示例

import org.apache.drill.common.types.TypeProtos.MajorType; //導入方法依賴的package包/類

public void updateColumnMetaData(String catalogName, String schemaName,

String tableName, BatchSchema schema,

List> getObjectClasses ) {

final List newColumns =

new ArrayList(schema.getFieldCount());

for (int colOffset = 0; colOffset < schema.getFieldCount(); colOffset++) {

final MaterializedField field = schema.getColumn(colOffset);

Class> objectClass = getObjectClasses.get( colOffset );

final String columnName = field.getPath().getRootSegment().getPath();

final MajorType rpcDataType = field.getType();

final AvaticaType bundledSqlDataType = getAvaticaType(rpcDataType);

final String columnClassName = objectClass.getName();

final int nullability;

switch ( field.getDataMode() ) {

case OPTIONAL: nullability = ResultSetMetaData.columnNullable; break;

case REQUIRED: nullability = ResultSetMetaData.columnNoNulls; break;

// Should REPEATED still map to columnNoNulls? or to columnNullable?

case REPEATED: nullability = ResultSetMetaData.columnNoNulls; break;

default:

throw new AssertionError( "Unexpected new DataMode value '"

+ field.getDataMode().name() + "'" );

}

final boolean isSigned = Types.isJdbcSignedType( rpcDataType );

// TODO(DRILL-3355): TODO(DRILL-3356): When string lengths, precisions,

// interval kinds, etc., are available from RPC-level data, implement:

// - precision for ResultSetMetadata.getPrecision(...) (like

// getColumns()'s COLUMN_SIZE)

// - scale for getScale(...), and

// - and displaySize for getColumnDisplaySize(...).

final int precision =

rpcDataType.hasPrecision() ? rpcDataType.getPrecision() : 0;

final int scale = rpcDataType.hasScale() ? rpcDataType.getScale() : 0;

final int displaySize = 10;

ColumnMetaData col = new ColumnMetaData(

colOffset, // (zero-based ordinal (for Java arrays/lists).)

false, /* autoIncrement */

false, /* caseSensitive */

true, /* searchable */

false, /* currency */

nullability,

isSigned,

displaySize,

columnName, /* label */

columnName, /* columnName */

schemaName,

precision,

scale,

tableName,

catalogName,

bundledSqlDataType,

true, /* readOnly */

false, /* writable */

false, /* definitelyWritable */

columnClassName

);

newColumns.add(col);

}

columns = newColumns;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值