atitit..sql update语法的词法分析,与语法ast构建

1. 要使用sql udpate语法的dsl ,需要写个解释器。。 1

2. 词法分析的实现 1

2.1. 扫描器的实现 SqlUpExpTokener 1

2.2. 等号操作符的转态 EqxState 2

2.3. 单引号的转态 SingleQuoeState 3

2.4. 逗号操作的转态 CommaState 5

3. 构建语法树ast 6

4. 最终输出ast结构 8

1. 要使用sql udpate语法的dsl ,需要写个解释器。。

主要应用在orm框架上,使得update 跟个insert的语法统一

注意的要点::

单引号的转义实现

单引号内的逗号,等号的实现。

作者:: 老哇的爪子 Attilax 艾龙,  EMAIL:1466519819@qq.com

转载请注明来源: http://blog.csdn.net/attilax

2. 词法分析的实现

2.1. 扫描器的实现 SqlUpExpTokener

s = "fld1=1,fld2='at''t,lax',fld3='val3'";

public List getTokenList(String s) {

// DslPaserContext context = new DslPaserContext();

Context4sqlUpExp context = new Context4sqlUpExp();

context.setState(new iniState());

;

while (!(context.state instanceof FinishState)) {

// System.out.println(n);

// ����

context.request(s);

n++;

)

break;

}

for (Token tk : context.tokenList) {

// if(tk.value.trim().length()>0)

System.out.println(tk.value + "===");

}

return (List) context.tokenList;

}

2.2. 等号操作符的转态 EqxState

public class EqxState implements State {

@Override

public void handle(String sampleParameter, Context context) {

Context4sqlUpExp ctt = (Context4sqlUpExp) context;

char curchar = ctt.curchar;

if (ctt.lastKeystate instanceof CommaState || ctt.lastKeystate instanceof CommaState || ctt.lastKeystate instanceof com.attilax.dsm.state.iniState) {

Token tk = new Token();

tk.value = ctt.curToken.value.trim();

ctt.tokenList.add(tk);

ctt.tokenList.add(new Token() {

{

this.value = "=";

}

});

ctt.curToken = new Token();

ctt.lastKeystate=new EqxState();

} else

ctt.curToken.value += curchar;

ctt.curcharIndex++;

}

2.3. 单引号的转态 SingleQuoeState

public class SingleQuoeState implements State {

/* (non-Javadoc)

* @see com.attilax.designpatter.statepatter.State#handle(java.lang.String)

*/

@Override

public void handle(String sampleParameter) {

// TODO Auto-generated method stub

}

/* (non-Javadoc)

* @see com.attilax.designpatter.statepatter.State#handle(java.lang.String, com.attilax.designpatter.statepatter.Context)

*/

@Override

public void handle(String sampleParameter, Context context) {

Context4sqlUpExp ctt = (Context4sqlUpExp) context;

char curchar=ctt.curchar;

ctt. SingleQuoeCount++;

//   ctt.curToken.value+=curchar;

//sec queot

)

{

ctt.curToken.value=ctt.curToken.value+new StringBuffer().append(curchar).toString();

ctt.curcharIndex++;

return;

}

)

{

ctt.curToken.value=ctt.curToken.value+new StringBuffer().append(curchar).toString();

ctt.curcharIndex++;

return;

}

else if(ctt.lastKeystate instanceof EqxState)

{

ctt.curToken=new Token();

ctt.lastKeystate=new SingleQuoetStartState();

}

else if (ctt.lastKeystate instanceof SingleQuoetStartState )//first queot

{

Token tk=new Token();

tk.value=ctt.curToken.value;

ctt.tokenList.add(tk);

//    ctt.tokenList.add(new Token(){{ this.value="," ; }});

ctt.curToken=new Token();

ctt.lastKeystate=new SingleQuoeEndState();

}

ctt.curcharIndex++;

}

/**

@author attilax 老哇的爪子

@since   p2g m_n_5

*/

private boolean preAlsoSq(Context4sqlUpExp ctt) {

]=='\'')

return true;

else

return false;

}

/**

@author attilax 老哇的爪子

* @param ctt

@since   p2g m_c_s

*/

private boolean nextAlsoSq(Context4sqlUpExp ctt) {

try {

]=='\'')

return true;

else

return false;

} catch (ArrayIndexOutOfBoundsException e) {

return false;

}

}

}

2.4. 逗号操作的转态 CommaState

public void handle(String sampleParameter, Context context) {

Context4sqlUpExp ctt = (Context4sqlUpExp) context;

char curchar = ctt.curchar;

if(ctt.lastKeystate instanceof EqxState  )

{

//

Token tk=new Token();

tk.value=ctt.curToken.value.trim();

ctt.tokenList.add(tk);

ctt.tokenList.add(new Token() {

{

this.value = ",";

}

});

ctt.curToken = new Token();

ctt.lastKeystate = new CommaState();

}

else if(  ctt.lastKeystate instanceof SingleQuoeEndState)

{

ctt.tokenList.add(new Token() {

{

this.value = ",";

}

});

ctt.curToken = new Token();

ctt.lastKeystate = new CommaState();

;

}

else

{

ctt.curToken.value+=curchar;

}

// ctt.curToken.value+=curchar;

ctt.curcharIndex++;

}

3. 构建语法树ast

这里使用map作为Ast的存储格式。。最终序列化为json

public class AstBuilder {

public Context ctx = new Context();

// ����ı��ʽ

public AbstractExpression expression;

public Map astRoot = new HashMap();

private String expStr;

@SuppressWarnings("all")

public static void main(String[] args) throws CantFindRitBrack {

String expStr2 = " method1( param1;\r\n method2(param2);";

expStr2 = "fld1=1,fld2='at''t,lax',fld3='val3'";

AstBuilder clt = new AstBuilder(expStr2);

clt.tkr = new SqlUpExpTokener();

Object rzt = clt.build();// AST

));

//System.out.println(JsonUtil4jackjson.buildNormalBinder().toJson(rzt));

}

// ���캯������,������

public AstBuilder(String expStr) throws CantFindRitBrack {

this.expStr = expStr;

}

Tokener tkr;

List<Token> tokenList;

private Object build() throws CantFindRitBrack {

tokenList = tkr.getTokenList(this.expStr);

// ����һ����ջ������������Ⱥ�˳��

// Stack<AbstractExpression> stack = ctx.stack;

// ����

; i < tokenList.size(); i++) {

Token tk = tokenList.get(i);

if (tk.value.equals(",")   ) {

);

).value);

}

)

{

).value, tokenList.get(i).value);

}

}

return this.astRoot;

// ���������׳���

// this.expression = stack.pop();

}

4. 最终输出ast结构

{

"fld1": "1",

"fld3": "val3",

"fld2": "at''t,lax"

}

atitit..sql update语法的词法分析,与语法ast构建的更多相关文章

  1. Atitit.sql ast 表达式 语法树 语法 解析原理与实现 java php c#.net js python

    Atitit.sql ast 表达式 语法树 语法 解析原理与实现 java php c#.net js python 1.1. Sql语法树 ast 如下图锁死1 2. SQL语句解析的思路和过程3 ...

  2. (转)ON DUPLICATE KEY UPDATE --mysql的一个有趣语法

    转自:http://my.oschina.net/iceman/blog/53735?fromerr=3kAEPcQr 如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE, ...

  3. Atitit sql执行计划

    Atitit sql执行计划 1.1. 首先要搞明白什么叫执行计划? 执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的 Oracle中的执行计划 ...

  4. SQL update select

    SQL update select语句 最常用的update语法是: UPDATE TABLE_NAME SET column_name1 = VALUE WHRER column_name2 = V ...

  5. SQL Update 语句详解

    SQL Update 语句详解   Update 语句 Update 语句用于修改表中的数据. 语法: UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 Person: L ...

  6. SQL update select结合语句详解及应用

    QL update select语句 最常用的update语法是: 1 2 UPDATE TABLE_NAME SET column_name1 = VALUE WHRER column_name2 ...

  7. 170823、SQL Update多表联合更新的方法

    SQL Update多表联合更新的方法 (1) sqlite 多表更新方法 update t1 set col1=t2.col1 from table1 t1 inner join table2 t2 ...

  8. sql update set from 的用法 (转)

    关键字: update set from 下面是这样一个例子: 两个表a.b,想使b中的memo字段值等于a表中对应id的name值     表a:id, name               1   ...

  9. SQL update select语句

    SQL update select语句 最常用的update语法是:UPDATE <table_name>SET <column_name1> = <value>, ...

随机推荐

  1. unix简史及应用

    Unix 简史 1965年时,贝尔实验室(Bell Labs)加入一项由奇异电子(General Electric)和麻省理工学院(MIT)合作的计画:该计画要建立一套多使用者.多任务.多层次(mul ...

  2. 仿LOL项目开发第一天

    ---恢复内容开始--- 仿LOL项目开发第一天 by---草帽 项目源码研究群:539117825 最近看了一个类似LOL的源码,颇有心得,所以今天呢,我们就来自己开发一个类似于LOL的游戏demo ...

  3. Valgrind 内存泄漏工具

    Valgrind 是一款 Linux下(支持 x86.x86_64和ppc32)程序的内存调试工具,它可以对编译后的二进制程序进行内存使用监测(C语言中的malloc和free,以及C++中的new和 ...

  4. 8)Linux程序设计入门--线程操作

    )Linux程序设计入门--线程操作 前言:Linux下线程的创建 介绍在Linux下线程的创建和基本的使用. Linux下的线程是一个非常复杂的问题,由 于我对线程的学习不时很好,我在这里只是简单的 ...

  5. HTML学习要点

    目标 掌握HTML基本语法,了解HTML Document结构,能熟练使用HTML Element对象. 要点 基本概念:什么是HTML.HTML标签? 熟悉常用的HTML标签含义以及应用场合. ht ...

  6. List、Set、Map、数组之间各种转换

    刚学Java不久的时候,接到一个电面,然后问了一些java的知识,比如说Java的编码,Unicode等,但是最让我蛋疼的是怎么吗map转为set,那个时候对集合用的很少,对集合不是特别了解,map还 ...

  7. HDU 5025图论之BFS

    点击打开链接 题意:从K走到T,S为怪,走的时候就多花费一秒,走到T时收集m把不同的钥匙.可是规定收集n之前,必须1~n-1所有收集完成,怪最多有5个 思路:怪最多就有5个,然后钥匙是1~9把,我们每 ...

  8. cocos2d-x 音乐与音效

    1.背景音乐 要使用一个音乐,首先要预加载这个音乐,预加载的方法如下 SimpleAudioEngine::sharedEngine()->preloadBackgroundMusic( CCF ...

  9. PHP 5 时区

    PHP 5 时区 PHP 支持的时区 下面是 PHP 支持的时区的完整列表,这些对一些 PHP 日期函数很有用. 非洲 美洲 南极洲 北冰洋 亚洲 大西洋 大洋洲 欧洲 印度洋 太平洋 非洲 Afri ...

  10. hdu 1087 简单dp

    思路和2391一样的.. <span style="font-size:24px;">#include<stdio.h> #include<strin ...