atitit..sql update语法的词法分析,与语法ast构建
atitit..sql update语法的词法分析,与语法ast构建
1. 要使用sql udpate语法的dsl ,需要写个解释器。。 1
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构建的更多相关文章
- 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 ...
- (转)ON DUPLICATE KEY UPDATE --mysql的一个有趣语法
转自:http://my.oschina.net/iceman/blog/53735?fromerr=3kAEPcQr 如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE, ...
- Atitit sql执行计划
Atitit sql执行计划 1.1. 首先要搞明白什么叫执行计划? 执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的 Oracle中的执行计划 ...
- SQL update select
SQL update select语句 最常用的update语法是: UPDATE TABLE_NAME SET column_name1 = VALUE WHRER column_name2 = V ...
- SQL Update 语句详解
SQL Update 语句详解 Update 语句 Update 语句用于修改表中的数据. 语法: UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 Person: L ...
- SQL update select结合语句详解及应用
QL update select语句 最常用的update语法是: 1 2 UPDATE TABLE_NAME SET column_name1 = VALUE WHRER column_name2 ...
- 170823、SQL Update多表联合更新的方法
SQL Update多表联合更新的方法 (1) sqlite 多表更新方法 update t1 set col1=t2.col1 from table1 t1 inner join table2 t2 ...
- sql update set from 的用法 (转)
关键字: update set from 下面是这样一个例子: 两个表a.b,想使b中的memo字段值等于a表中对应id的name值 表a:id, name 1 ...
- SQL update select语句
SQL update select语句 最常用的update语法是:UPDATE <table_name>SET <column_name1> = <value>, ...
随机推荐
- js复制兼容:ZeroClipboard复制到剪切板(支持IE、FF、Chrome)
注意:ZeroClipboard在本地测试无法直接使用,必须在服务器上测试,如http://localhost... 准备:ZeroClipboard.swf 和 ZeroClipboard.js 小 ...
- 常见C++内存池技术
原文:http://www.cppblog.com/weiym/archive/2013/04/08/199238.html 总结下常见的C++内存池,以备以后查询.应该说没有一个内存池适合所有的情况 ...
- poj2186 Popular Cows 题解——S.B.S.
Popular Cows Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 29642 Accepted: 11996 De ...
- Install Python+Django+Nginx+UWSGI
一.软件环境: CentOS6.6_64bit 需要用到的软件: [root@django tools]# ll 总用量 33336 -rw-r--r-- 1 root root 7497785 3月 ...
- apache环境 php开启intl扩展
将php目录下的icu开头的所有dll文件copy到apache/bin目录 再开启 extension=php_intl.dll 扩展,重启apache.
- 【Python】http.client库的用法
代码: # http.client测试,该库较底层,不常用 import http.client conn=None try: conn=http.client.HTTPSConnection(&qu ...
- 极客Web开发资源大荟萃
前端开发已经成为当前炙手可热的技术之一.此次我们总结的前端开发包含了相关技术和流行趋势,希望从中大家可以挖掘你们所需要的,并带给你们最有价值的帮助!原文来自:极客标签 使用代码回放来愉快地学习前端知识 ...
- C#应用视频教程3.2 Halcon软件测试
Halcon是图像处理比较牛逼的一个软件(德国人的东西,做的非常强大,里面集成的算法很多,可能你一辈子研究这个也做不过他),然而牛逼归牛逼,康耐视,基恩士也很牛逼,但是日本人的东西一般太过封闭,屌丝用 ...
- T-SQL 之 公用表表达式(CTE)
在编写T-SQL代码时,往往需要临时存储某些结果集.在CTE之前常用的两种临时存储结果集为:临时表和表变量.除此之外,还可以使用公用表表达式的方法. 公用表表达式(Common Table Expre ...
- 解决ARC下performselector-may-cause-a-leak-because-its-selector-is-unknown 警告
在ARC下使用 [theTarget performSelector:theTarget withObject:Nil]; 会出现警告:performselector-may-cause-a-leak ...