Entry入口 main中自顶向下手动创建了sql语法树

package com.hy;

// 构建SQL语法树
public class Entry {
    public static void main(String[] args) throws Exception {

        Node query=new SetNode(" ");
        query.addChild(new KeywordNode("Select"));

        Node fields=new SetNode(",");
        fields.addChild(new ValueNode("name"));
        fields.addChild(new ValueNode("ismale"));
        query.addChild(fields);

        query.addChild(new KeywordNode("From"));

        Node tables=new SetNode(",");
        tables.addChild(new ValueNode("userinfo"));
        query.addChild(tables);

        query.addChild(new KeywordNode("Where"));

        Node condistions=new SetNode(" and ");
        Node ageCompare=new CompareNode(">=");
        ageCompare.addChild(new ValueNode("age"));
        ageCompare.addChild(new ValueNode("41"));
        condistions.addChild(ageCompare);

        Node levelCompare=new CompareNode("<");
        levelCompare.addChild(new ValueNode("level"));
        levelCompare.addChild(new ValueNode("9"));
        condistions.addChild(levelCompare);

        Node likeCompare=new CompareNode(" like ");
        likeCompare.addChild(new ValueNode("name"));
        likeCompare.addChild(new ValueNode("'王%'"));
        condistions.addChild(likeCompare);

        query.addChild(condistions);

        query.addChild(new KeywordNode("order by"));

        Node orders=new SetNode(",");
        orders.addChild(new ValueNode("sn asc"));
        orders.addChild(new ValueNode("level desc"));
        query.addChild(orders);

        System.out.println(query.getSql());
    }
}

先把输出秀一下:

Select name,ismale From userinfo Where age>=41 and level<9 and name like '王%' order by sn asc,level desc

再看诸节点类写法:

Node类:

package com.hy;

import java.util.ArrayList;
import java.util.List;

// 节点抽象类,作为各种节点的基类
public abstract class Node {
    // 此节点的子节点
    protected List<Node> children;

    // 表示此节点的文字
    protected String text="";

    public Node() {
        children=new ArrayList<Node>();
    }

    // 添加一个子节点
    public Node addChild(Node n) {
        children.add(n);

        return this;
    }

    // 取得节点在sql中该有的文字
    public String getSql() throws Exception{
        String retval=this.text+"";

        for(int i=0;i<children.size();i++) {
            Node child=children.get(i);
            retval+=child.getSql();
        }

        return retval;
    }
}

KeywordNode类:

package com.hy;

// 关键字节点,比如用来表示SQL中select,from,where,order by等关键字的节点
// 此类节点下面没有子节点
public class KeywordNode extends Node {

    public KeywordNode(String keyword) {
        this.text=keyword;
    }
}

ValueNode类:

package com.hy;

// 值节点,比如用来表示字段,表,条件,数值等节点
// 此类节点下面如果存在查询也可能存在多个子节点
public class ValueNode extends Node {

    public ValueNode(String value) {
        this.text=value;
    }
}

SetNode类:

package com.hy;

import java.util.ArrayList;
import java.util.List;

// 集合节点,比如用来表示SQL中字段组,表组,条件组,and组等容纳多个子节点的的节点,整条SQL也是这个节点
// 此类节点下面一般有多个子节点,如查询多个字段,从多个表查询,包含多个条件,按多种情况排序等
public class SetNode extends Node {
    // 子节点之间的分隔符
    protected String seperator;

    public SetNode() {
        seperator="";
    }

    public SetNode(String seperator) {
        this.seperator=seperator;
    }

    public String getSql() throws Exception{
        String retval=this.text+"";

        List<String> ls=new ArrayList<String>();
        for(int i=0;i<children.size();i++) {
            Node child=children.get(i);
            ls.add(child.getSql());
        }

        retval+=String.join(seperator, ls);

        return retval;
    }
}

CompareNode类:

package com.hy;

// 比较节点,用来表示条件比较的节点,如age>41,level>9
// 此类节点下面理论上存在左右两个节点,如果存在查询也可能存在多个子节点
public class CompareNode extends Node {

    public CompareNode(String value) {
        this.text=value;
    }

    public String getSql() throws Exception{
        Node left=getLeftChild();
        Node right=getRightChild();

        String retval=left.getSql()+this.text+right.getSql()+"";

        return retval;
    }

    private Node getLeftChild() throws Exception {
        try {
            return children.get(0);
        }catch(Exception e) {
            throw new Exception("No found left node under node'"+this.text+"' ");
        }
    }

    private Node getRightChild() throws Exception {
        try {
            return children.get(1);
        }catch(Exception e) {
            throw new Exception("No found Right node under node'"+this.text+"' ");
        }
    }
}

与前作相比加了异常,这在一定程度上能爆出构建时错误。

--END--2019年9月6日18点46分

[Java]手动构建SQL语法树(sql简单无嵌套)并输出与之对应的SQL语句之二的更多相关文章

  1. sql语法值ORACLE简单介绍

    版权声明:本文为[博主](https://zhangkn.github.io)原创文章,未经博主同意不得转载.https://creativecommons.org/licenses/by-nc-sa ...

  2. sql 语法树 常量

    SELECT id,'|',url,'|',update_time FROM tab LIMIT 10;SELECT COUNT(1) AS parent,(SELECT COUNT(1) FROM ...

  3. Sql语法树示例 select username, ismale from userinfo where age > 20 and level > 5 and 1 = 1

    select username, ismale from userinfo where age > 20 and level > 5 and 1 = 1 --END-2019年9月5日17 ...

  4. [Java]手动构建表达式二叉树,求值,求后序表达式

    Inlet类,这颗二叉树是”人力运维“的: package com.hy; public class Inlet { public static void main(String[] args) th ...

  5. SQL抽象语法树及改写场景应用

    1 背景 我们平时会写各种各样或简单或复杂的sql语句,提交后就会得到我们想要的结果集.比如sql语句,"select * from t_user where user_id > 10 ...

  6. NoSQL 数据库概览及其与 SQL 语法的比较

    NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用的难题. 本文对NoSQL数据库的定义.分类.特征.当前比较流行的NoSQL数据库系统等进行了简单的介绍,并对N ...

  7. NoSQL数据库概览及其与SQL语法的比較

    [文章摘要] HBase是一个高可靠性.高性能.面向列.可伸缩的分布式存储系统.同一时候也是知名的NoSQL数据库之中的一个.NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤 ...

  8. [数据库] SQL 语法之基础篇

    一.什么是 SQL ? SQL 是 Structured Query Language(结构化查询语言)的缩写,是一种专门用来与数据库沟通的语言.与其他语言(如英语或 C.C++.Java 这样的编程 ...

  9. mysql中SQL执行过程详解与用于预处理语句的SQL语法

    mysql中SQL执行过程详解 客户端发送一条查询给服务器: 服务器先检查查询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果.否则进入下一阶段. 服务器段进行SQL解析.预处理,在优化器生成对应的 ...

随机推荐

  1. windows环境下,kafka常用命令

    创建topics kafka-topics.bat --create --zookeeper localhost:2181 --replication-factor 1 --partition 3 - ...

  2. 图片上传(3)(组件 -- 图片大小宽高限制)base64图片宽高读取

    1.上传组件(可上传多个文件) <template> <div class="attachmentN"> <span class="btnS ...

  3. VMwarevSphere Client 链接 vCenter Server中的主机,开启虚拟机提示:在主机当前连接状况下不允许执行该操作

    VMwarevSphere Client 链接 vCenter Server中的主机,开启虚拟机提示:在主机当前连接状况下不允许执行该操作很多原因都可以导致该问题出现,例如 vCenter Serve ...

  4. 《python解释器源码剖析》第3章--python中的str对象

    3.0 序 我们知道python中的字符串属于变长对象,当然和int也是一样,底层的结构体实例所维护的数据的长度,在对象没有定义的时候是不知道的.当然如果是python2的话,底层PyIntObjec ...

  5. kubernetes管理机密信息

    一.启动应用安全信息的保护: Secret介绍: 应用启动过程中可能需要一些敏感信息,比如访问数据库的用户名密码或者秘钥.将这些信息直接保存在容器镜像中显然不妥,Kubernetes 提供的解决方案是 ...

  6. 关于boost::asio

    // BoostServer.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #incl ...

  7. Linux系统用户权限管理

    Linux系统中三种基本权限 用户属主.用户属组及其它人权限 -rw-r--r-- 1 root root 762 11-11 20:34 a.out 文件类型 ls命令中的缩写 应用 一般文件 - ...

  8. 第六章 组件 67 使用ref获取DOM元素和组件引用

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  9. Java 实现的 简单WordCount功能

    githup 链接:https://gitee.com/iy2524/WordCount.git PSP表格  psp2.1  psp阶段 估计耗时(分钟)  实际耗时(分钟) Planning  计 ...

  10. 小程序开发之后台mybatis逆向工程(二)

    上一节搭建好了SSM后台框架,这一节将根据表结构创建实体及映射文件以及mapper接口.如果表过多,会很麻烦,所以mybatis提供了逆向工程来解决这个问题. 上一节 SSM搭建后台管理系统 逆向工程 ...