java使用正则匹配DDL表名和特定列名

简介: java使用正则匹配DDL表名和特定列名
    public static void main(String[] args) {
        String item = "CREATE TABLE \"cloud\".\"version\"\n" +
                "(\n" +
                " \"id\" BIGINT IDENTITY(43,1) NOT NULL,\n" +
                " \"version\" VARCHAR(50) NOT NULL,\n" +
                " \"updated\" TIMESTAMP(0) NOT NULL,\n" +
                " \"step\" CHAR(32) NOT NULL\n" +
                ");";
 
        // 使用正则表达式匹配表名
        Pattern tablePattern = Pattern.compile("\"\\w+\"\\.\"\\w+\"");
        Matcher tableMatcher = tablePattern.matcher(item);
        String tableName = "";
        while (tableMatcher.find()) {
            tableName = tableMatcher.group();
        }
 
        // 使用正则表达式匹配列名和长度
        Pattern columnPattern = Pattern.compile("\"(\\w+)\" CHAR\\((\\d+)\\)");
        Matcher tableColumnMatcher = columnPattern.matcher(item);
        while (tableColumnMatcher.find()) {
            String column = tableColumnMatcher.group(1);
            String charLength = tableColumnMatcher.group(2);
            System.out.println(tableName + " " + column + " " + charLength);
        }
    }
"cloud"."version" step 32

相关文章
|
6月前
|
Java 数据处理
Java 正则详解
Java 正则详解
63 1
Java 正则详解
|
6月前
|
Java 计算机视觉
【Java 正则表达式】简单用法,注意点,我学不会正则
【Java 正则表达式】简单用法,注意点,我学不会正则
|
SQL 安全 Java
使用Java根据表名导出与导入Sql
使用Java根据表名导出与导入Sql
【Java每日一题,字符串正则匹配】Andy‘s First Dictionary
【Java每日一题,字符串正则匹配】Andy‘s First Dictionary
|
Java 编译器 Windows
关于Java正则和转义中\\和\\\\的理解
关于Java正则和转义中\\和\\\\的理解
129 0
|
Java
Java后端,正则匹配
Java后端,正则匹配
114 0
|
Java
java身份证、手机号、邮箱正则校验工具类
java身份证、手机号、邮箱正则校验工具类
656 0
|
算法 Java
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配
✨今日三剑 JZ17 打印从1到最大的n位数 JZ18 删除链表的节点 JZ19 正则表达式匹配
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配
|
Java 开发者 Windows
Java—正则匹配
Java—正则匹配
160 0
|
Java API
Java的正则表达式原理及使用场景(上)
Java的正则表达式原理及使用场景(上)
194 0
Java的正则表达式原理及使用场景(上)