java 无法解析 out,或者它不是字段

千万别把类名设置成System!

找了一个小时,无语死了。。

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 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)); } ``` 该代码的基本思路是将建表语句中的单词按空格分隔开来,然后根据语法规则解析字段名、数据类型和约束信息。由于该代码只是一个简单示例,可能无法解析所有的建表语句,你可以根据具体情况进行修改和完善。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值