249
新东方
简单上传示例__SDK示例_批量数据通道_大数据计算服务-阿里云
import java.io.IOException;
import java.util.Date;
import com.aliyun.odps.Column;
import com.aliyun.odps.Odps;
import com.aliyun.odps.PartitionSpec;
import com.aliyun.odps.TableSchema;
import com.aliyun.odps.account.Account;
import com.aliyun.odps.account.AliyunAccount;
import com.aliyun.odps.data.Record;
import com.aliyun.odps.data.RecordWriter;
import com.aliyun.odps.tunnel.TableTunnel;
import com.aliyun.odps.tunnel.TunnelException;
import com.aliyun.odps.tunnel.TableTunnel.UploadSession;
public class UploadSample {
private static String accessId = "<your access id>";
private static String accessKey = "<your access Key>";
private static String odpsUrl = "https://service.odps.aliyun.com/api";
private static String project = "<your project>";
private static String table = "<your table name>";
private static String partition = "<your partition spec>";
public static void main(String args[]) {
Account account = new AliyunAccount(accessId, accessKey);
Odps odps = new Odps(account);
odps.setEndpoint(odpsUrl);
odps.setDefaultProject(project);
try {
TableTunnel tunnel = new TableTunnel(odps);
PartitionSpec partitionSpec = new PartitionSpec(partition);
UploadSession uploadSession = tunnel.createUploadSession(project,
table, partitionSpec);
System.out.println("Session Status is : "
+ uploadSession.getStatus().toString());
TableSchema schema = uploadSession.getSchema();
RecordWriter recordWriter = uploadSession.openRecordWriter(0);
Record record = uploadSession.newRecord();
for (int i = 0; i < schema.getColumns().size(); i++) {
Column column = schema.getColumn(i);
switch (column.getType()) {
case BIGINT:
record.setBigint(i, 1L);
break;
case BOOLEAN:
record.setBoolean(i, true);
break;
case DATETIME:
record.setDatetime(i, new Date());
break;
case DOUBLE:
record.setDouble(i, 0.0);
break;
case STRING:
record.setString(i, "sample");
break;
default:
throw new RuntimeException("Unknown column type: "
+ column.getType());
}
}
for (int i = 0; i < 10; i++) {
recordWriter.write(record);
}
recordWriter.close();
uploadSession.commit(new Long[]{0L});
System.out.println("upload success!");
} catch (TunnelException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
构造器举例说明:PartitionSpec(String spec):通过字符串构造此类对象。参数:spec: 分区定义字符串,比如: pt=’1’,ds=’2’。因此程序中应该这样配置:private static String partition = “pt=’XXX’,ds=’XXX’”;
最后更新:2016-07-12 15:32:02
上一篇:
示例概要__SDK示例_批量数据通道_大数据计算服务-阿里云
下一篇:
简单下载示例__SDK示例_批量数据通道_大数据计算服务-阿里云
查询物理专线列表__高速通道相关接口_API 参考_云服务器 ECS-阿里云
云邮集团版创建邮件域__控制台操作_产品使用问题_企业邮箱-阿里云
登录 Linux 实例__远程连接_实例_用户指南_云服务器 ECS-阿里云
便捷的数据操作__应用场景_产品简介_数据管理-阿里云
什么是对象存储 OSS_阿里云帮助中心-阿里云,领先的云计算服务提供商
使用counter示例__示例程序_MapReduce_大数据计算服务-阿里云
删除自定义转码模板__自定义转码模板接口_API使用手册_媒体转码-阿里云
如何减少或杜绝违法信息出现?__规则FAQ_常见问题_阿里云规则-阿里云
[4]授权策略示例__子账号访问MNS_控制台使用帮助_消息服务-阿里云
开启Pipeline__Pipeline管理_Console参考手册_数据集成-阿里云
相关内容
常见错误说明__附录_大数据计算服务-阿里云
发送短信接口__API使用手册_短信服务-阿里云
接口文档__Android_安全组件教程_移动安全-阿里云
运营商错误码(联通)__常见问题_短信服务-阿里云
设置短信模板__使用手册_短信服务-阿里云
OSS 权限问题及排查__常见错误及排除_最佳实践_对象存储 OSS-阿里云
消息通知__操作指南_批量计算-阿里云
设备端快速接入(MQTT)__快速开始_阿里云物联网套件-阿里云
查询API调用流量数据__API管理相关接口_API_API 网关-阿里云
使用STS访问__JavaScript-SDK_SDK 参考_对象存储 OSS-阿里云