KUDU表的增删改查

一、创建kudu表

CREATE TABLE IOV_DAILY (
	`DID` string,
	`START_GEAR` INT,
	`DATA_TIME` BIGINT,
	`DATA_DAY` string,
	`POINTS` INT,
	PRIMARY KEY ( DID, START_GEAR, DATA_TIME ) 
) PARTITION BY HASH ( DID ) PARTITIONS 15,
RANGE ( DATA_TIME ) ( PARTITION VALUES < 1577808000000, 
PARTITION 1577808000000 <= VALUES < 1609430400000,
PARTITION 1609430400000 <= VALUES < 1640966400000 ) STORED AS KUDU

二、查看建表语句

show create table `表名`

三、删除表

drop table `表名`

四、新增列

alter TABLE `表名` add columns(open_time bigint, STORAGE_TIME bigint);

五、删除列

alter TABLE `表名` DROP COLUMN open_time;
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
你可以使用 Java 提供的字符串处理函数来解析 Kudu SQL 语句中的字段信息。以下是一个简单的示例代码,可以解析出建语句中的字段名、数据类型和约束信息: ```java String createTableSQL = "CREATE TABLE my_table (id INT PRIMARY KEY, name STRING NOT NULL, age INT)"; String[] tokens = createTableSQL.split("\\s+"); // 使用空格分隔建语句中的单词 List<String> columnNames = new ArrayList<>(); List<String> columnTypes = new ArrayList<>(); List<String> columnConstraints = new ArrayList<>(); for (int i = 0; i < tokens.length; i++) { String token = tokens[i]; if (token.equals("(")) { // 左括号后面是字段定义 while (!tokens[i + 1].equals(")")) { String columnName = tokens[i + 1]; columnNames.add(columnName); String columnType = tokens[i + 2]; columnTypes.add(columnType); if (i + 3 < tokens.length && tokens[i + 3].equals("PRIMARY")) { // 主键约束 columnConstraints.add("PRIMARY KEY"); i += 4; } else if (i + 3 < tokens.length && tokens[i + 3].equals("NOT")) { // 非空约束 columnConstraints.add("NOT NULL"); i += 4; } else { // 没有约束 columnConstraints.add(""); i += 2; } } } } // 输出解析结果 for (int i = 0; i < columnNames.size(); i++) { System.out.println("Column name: " + columnNames.get(i)); System.out.println("Column type: " + columnTypes.get(i)); System.out.println("Column constraint: " + columnConstraints.get(i)); } ``` 该代码的基本思路是将建语句中的单词按空格分隔开来,然后根据语法规则解析出字段名、数据类型和约束信息。由于该代码只是一个简单示例,可能无法解析所有的建语句,你可以根据具体情况进行修改和完善。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值