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

目录
相关文章
|
9月前
|
SQL 安全 Java
使用Java根据表名导出与导入Sql
使用Java根据表名导出与导入Sql
|
9月前
|
Java
【Java每日一题,字符串正则匹配】Andy‘s First Dictionary
【Java每日一题,字符串正则匹配】Andy‘s First Dictionary
|
Java
Java后端,正则匹配
Java后端,正则匹配
97 0
|
算法 Java
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配
✨今日三剑 JZ17 打印从1到最大的n位数 JZ18 删除链表的节点 JZ19 正则表达式匹配
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配
|
Java 开发者 Windows
Java—正则匹配
Java—正则匹配
146 0
|
Java
java中的正则匹配
Pattern类、Matcher类
132 0
|
Java
java正则匹配并提取字串
Pattern p = Pattern.compile("\\(.*\\)"); Matcher m = p.matcher("1.2.0(23)"); if(m.
968 0
|
Java
Java 正则匹配html标签
java 正则匹配html标签
3338 0
|
Java 数据安全/隐私保护
一个通用的Java正则匹配工具(检查邮箱名、电话号码、用户密码、邮政编码等合法性的工具类)
一个通用的Java正则匹配工具(检查邮箱名、电话号码、用户密码、邮政编码等合法性的工具类)。 一个通用且常用的Java正则匹配工具,用以检查邮箱名、电话号码、用户密码、邮政编码等合法性。
1502 0