CN102222108A - 脚本处理方法和脚本处理装置 - Google Patents

脚本处理方法和脚本处理装置 Download PDF

Info

Publication number
CN102222108A
CN102222108A CN 201110177234 CN201110177234A CN102222108A CN 102222108 A CN102222108 A CN 102222108A CN 201110177234 CN201110177234 CN 201110177234 CN 201110177234 A CN201110177234 A CN 201110177234A CN 102222108 A CN102222108 A CN 102222108A
Authority
CN
China
Prior art keywords
expression formula
batch
script
query
result
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN 201110177234
Other languages
English (en)
Other versions
CN102222108B (zh
Inventor
程操红
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Yonyou Network Technology Co Ltd
Original Assignee
Yonyou Software Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Yonyou Software Co Ltd filed Critical Yonyou Software Co Ltd
Priority to CN 201110177234 priority Critical patent/CN102222108B/zh
Publication of CN102222108A publication Critical patent/CN102222108A/zh
Application granted granted Critical
Publication of CN102222108B publication Critical patent/CN102222108B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Abstract

本发明提供一种脚本处理方法和一种脚本处理装置。其中,脚本处理方法包括:步骤102,从脚本中解析出表达式,并根据运算性质,将表达式分类,以及获取表达式之间的依赖关系;步骤104,根据表达式的类别以及依赖关系,对表达式进行分批,并确定每批次表达式的执行顺序;步骤106,按执行顺序执行每批次表达式,取得每批次表达式的运算结果;步骤108,将所有批次表达式的运算结果返回给脚本,以获取脚本的运算结果。通过本发明,对表达进行分批,每批次表达式可以一次计算出结果,不会因需依赖其他表达式,而不能计算出结果或者增加后台实现的复杂程度。

Description

脚本处理方法和脚本处理装置
技术领域
本发明涉及计算机技术领域,具体而言,涉及一种脚本处理方法和一种脚本处理装置。
背景技术
在网络分布式计算的环境下,运行在一台机器的上程序需要调用运行在另外一台计算机上的子程序,这个过程被称为远端程序调用。一般发起调用的程序称为客户端,而远程计算机的程序被称为服务器。远端程序调用的时间开销,即从调用发起开始到获取到返回值所花费的时间,等于被调用程序运行所花的时间再加上数据在两台计算机之间传递所花费的时间。
根据这两项时间占总的时间开销的比例,可以把远端程序调用分成三类,一类是运算密集型,即程序运行时间占大部分比例;另一类是数据密集型,即数据传输的时间占较大比例;最后一类是平均型,即二者比例相当。
在互联网环境下,两台计算机的物理距离可能相隔遥远,其网络状况速度也往往不很理想。怎样降低上述列举的后两种类型的远端程序调用的时间开销是一个值得研究的问题。
常见的程序都存在一类需要反复被调用且返回来的数据量会比较大的远端过程。比如说:一个销售终端程序需要经常调用服务器上的商品库存情况查询程序,以得到商品的库存信息。这类反复调用且数据量又很大的远端过程都属于前述的后两种类型的远程调用。其程序运行的时间已经很难降低,所以解决问题的入口就是降低数据传输时间。
为了降低数据传输时间,一个有效的办法是在客户端做一个缓存,把调用返回来的结果保存下来。如果下次还需要调用同样的远端过程,就直接利用上次保存的结果就好了,不用再去和另外一台计算机通信了,这样提高了程序的运行效率。
但是缓存的方法存在局限性,那就是:对于不经常变化的非交易型数据,配合一些精细设计的缓存同步和更新方法,可以很好的保证数据实时性、一致性及完整性,从而有效的控制远程调用的发生,提高远端程序调用的效率。但是实际的业务场景中存在大量的交易型数据,这些数据具备两个特征:
一是会频繁的随业务发生变化,比如销售***中的销售订单;
二是数据量非常大,比如电信***里的用户通话明细记录。
这两个特征会导致缓存交易型的数据非常困难,如果要保证数据实时性和一致性,那么就必须频繁的做数据同步;而如果要保证数据完整性,则客户端会使用到的数据都必须进行同步,缓存的数据量会急剧增长,一般来说客户端的内存相对有限,急剧增加的缓存数据会引起内存问题,另外客户端缓存数据查询一般来说都采用的是轻量级数据库实现,所以随着数据量的增长,查询效率会急剧下降,最终导致缓存失效。
另一方面,为提高客户端界面的交互性,增加客户端界面的动态可配置性,以满足各种客户的应用需求,脚本技术常常被引入到客户端的界面配置中,可在产品实施阶段修改脚本实现业务规则的变化。这些脚本不可避免的要从服务端获取数据,产生远程调用。
因为上述原因,目前的各种技术方案中一般不会对交易型数据进行缓存,这样一来,客户端在需要查询交易型数据时就不可避免的产生远程调用,尤其是一些在客户端通过脚本方式动态组织数据的场景,远程调用次数随着业务复杂度的提高会快速增长,客户端进行远端调用的时间相应增加,导致用户体验效果不佳。
因此,需求一种适用于针对大量数据传输的处理方案,尤其适用于处理交易型数据,既不需要其在远端调用过程占用大量的时间和资源,又不必占用大量内存空间保存调用的结果数据,且能够保证所需数据的准确性。
发明内容
本发明所要解决的技术问题在于,提供一种适用于针对大量数据传输的处理方案,尤其适用于处理交易型数据,既不需要其在远端调用过程占用大量的时间和资源,又不必占用大量内存空间保存调用的结果数据,且能够保证所需数据的准确性。
有鉴于此,本发明提供一种脚本处理方法,包括:步骤102,从脚本中解析出表达式,并根据运算性质,将表达式分类,以及获取表达式之间的依赖关系;步骤104,根据表达式的类别以及依赖关系,对表达式进行分批,并确定每批次表达式的执行顺序;步骤106,按执行顺序执行每批次表达式,取得每批次表达式的运算结果;步骤108,将所有批次表达式的运算结果返回给脚本,以获取脚本的运算结果。通过该技术方案,对表达进行分批,每批次表达式可以一次计算出结果,不会因需依赖其他表达式,而不能计算出结果或者增加后台计算结果的复杂程度。
在上述技术方案中,优选地,运算性质包括:表达式是否需要进行数据查询;表达式需要进行数据查询时,数据查询是否是基于缓存进行查询。
在上述技术方案中,优选地,步骤106具体包括:对于每批次表达式,判断其中每个表达式是否需要进行数据查询,在判断结果为否时,直接计算每个表达式的运算结果,否则判断数据查询是否是基于缓存进行查询,在判断结果为是时,基于缓存进行数据查询,并根据查询结果计算每个表达式的运算结果,否则提取每个表达式的查询参数,并基于每个表达式的查询参数进行远程数据查询,并根据查询结果计算每个表达式的运算结果。
在上述技术方案中,优选地,基于每个表达式的查询参数进行远程数据查询具体包括:在每批次表达式的所有查询参数中,按预定条件进行一组或多组查询参数的合并,并基于合并后的查询参数进行远程的批量数据查询。通过该技术方案,合并查询参数进行数据查询,可以减少查询次数,提高查询效率。
在上述技术方案中,优选地,还包括:建立复合区域,以存储每批次表达式,其中,复合区域按每批次表达式的类别,将其分组存储。
本发明还提供一种脚本处理装置,包括:脚本解析模块,从脚本中解析出表达式,并根据运算性质,将表达式分类,以及获取表达式之间的依赖关系;批次处理模块,根据表达式的类别以及依赖关系,对表达式进行分批,并确定每批次表达式的执行顺序;结果计算模块,按执行顺序执行每批次表达式,取得每批次表达式的运算结果;结果返回模块,将所有批次表达式的运算结果返回给脚本,以获取脚本的运算结果。通过该技术方案,对表达进行分批,每批次表达式可以一次计算出结果,不会因需依赖其他表达式,而不能计算出结果或者增加后台计算结果的复杂程度。
在上述技术方案中,优选地,在上述技术方案中,优选地,运算性质包括:表达式是否需要进行数据查询;表达式需要进行数据查询时,数据查询是否是基于缓存进行查询。
在上述技术方案中,优选地,结果计算模块对于每批次表达式,判断其中每个表达式是否需要进行数据查询,在判断结果为否时,直接计算每个表达式的运算结果,否则判断数据查询是否是基于缓存进行查询,在判断结果为是时,基于缓存进行数据查询,并根据查询结果计算每个表达式的运算结果,否则提取每个表达式的查询参数,并基于每个表达式的查询参数进行远程数据查询,并根据查询结果计算每个表达式的运算结果。
在上述技术方案中,优选地,结果计算模块在每批次表达式的所有查询参数中,按预定条件进行一组或多组查询参数的合并,并基于合并后的查询参数进行远程的批量数据查询。通过该技术方案,合并查询参数进行数据查询,可以减少查询次数,提高查询效率。
在上述技术方案中,优选地,批次处理模块还建立复合区域,以存储每批次表达式,其中,复合区域按每批次表达式的类别,将其分组存储。
根据以上技术方案,可以实现一种脚本处理方法和一种脚本处理装置,适用于针对大量数据传输,尤其适用于处理交易型数据,既不需要其在远端调用过程占用大量的时间和资源,又不必占用大量内存空间保存调用的结果数据,且能够保证所需数据的准确性。
附图说明
图1是根据本发明的一个实施例的脚本处理方法的流程图;
图2是根据本发明的一个实施例的脚本处理装置的框图;
图3是根据本发明的一个实施例的脚本处理装置的原理示意图;
图4是根据本发明的一个实施例的脚本处理装置的单个模块的工作流程图;
图5是根据本发明的一个实施例的脚本处理装置中采用的复合区域的示意图;
图6是根据本发明的一个实施例的脚本处理装置的单个模块的工作流程图;
图7是根据本发明的一个实施例的脚本处理装置进行表达式分批处理的示意图;
图8是根据本发明的一个实施例的脚本处理装置的单个模块的工作流程图;
图9是根据本发明的一个实施例的脚本处理装置的单个模块的工作流程图;
图10是根据本发明的一个实施例的脚本处理装置的单个模块的工作流程图。
具体实施方式
为了能够更清楚地理解本发明的上述目的、特征和优点,下面结合附图和具体实施方式对本发明进行进一步的详细描述。
在下面的描述中阐述了很多具体细节以便于充分理解本发明,但是,本发明还可以采用其他不同于在此描述的其他方式来实施,因此,本发明并不限于下面公开的具体实施例的限制。
图1是根据本发明的一个实施例的脚本处理方法的流程图。
如图1所示,本发明提供一种脚本处理方法,包括:步骤102,从脚本中解析出表达式,并根据运算性质,将表达式分类,以及获取表达式之间的依赖关系;步骤104,根据表达式的类别以及依赖关系,对表达式进行分批,并确定每批次表达式的执行顺序;步骤106,按执行顺序执行每批次表达式,取得每批次表达式的运算结果;步骤108,将所有批次表达式的运算结果返回给脚本,以获取脚本的运算结果。通过该技术方案,对表达进行分批,每批次表达式可以一次计算出结果,不会因需依赖其他表达式,而不能计算出结果或者增加后台计算结果的复杂程度。
在上述技术方案中,运算性质包括:表达式是否需要进行数据查询;表达式需要进行数据查询时,数据查询是否是基于缓存进行查询。
在上述技术方案中,步骤106具体包括:对于每批次表达式,判断其中每个表达式是否需要进行数据查询,在判断结果为否时,直接计算每个表达式的运算结果,否则判断数据查询是否是基于缓存进行查询,在判断结果为是时,基于缓存进行数据查询,并根据查询结果计算每个表达式的运算结果,否则提取每个表达式的查询参数,并基于每个表达式的查询参数进行远程数据查询,并根据查询结果计算每个表达式的运算结果。
在上述技术方案中,基于每个表达式的查询参数进行远程数据查询具体包括:在每批次表达式的所有查询参数中,按预定条件进行一组或多组查询参数的合并,并基于合并后的查询参数进行远程的批量数据查询。通过该技术方案,合并查询参数进行数据查询,可以减少查询次数,提高查询效率。
在上述技术方案中,还包括:建立复合区域,以存储每批次表达式,其中,复合区域按每批次表达式的类别,将其分组存储。
图2是根据本发明的一个实施例的脚本处理装置的框图。
如图2所示,本发明还提供一种脚本处理装置200,包括:脚本解析模块202,从脚本中解析出表达式,并根据运算性质,将表达式分类,以及获取表达式之间的依赖关系;批次处理模块204,根据表达式的类别以及依赖关系,对表达式进行分批,并确定每批次表达式的执行顺序;结果计算模块206,按执行顺序执行每批次表达式,取得每批次表达式的运算结果;结果返回模块208,将所有批次表达式的运算结果返回给脚本,以获取脚本的运算结果。通过该技术方案,对表达进行分批,每批次表达式可以一次计算出结果,不会因需依赖其他表达式,而不能计算出结果或者增加后台计算结果的复杂程度。
在上述技术方案中,在上述技术方案中,优选地,运算性质包括:表达式是否需要进行数据查询;表达式需要进行数据查询时,数据查询是否是基于缓存进行查询。。
在上述技术方案中,结果计算模块206对于每批次表达式,判断其中每个表达式是否需要进行数据查询,在判断结果为否时,直接计算每个表达式的运算结果,否则判断数据查询是否是基于缓存进行查询,在判断结果为是时,基于缓存进行数据查询,并根据查询结果计算每个表达式的运算结果,否则提取每个表达式的查询参数,并基于每个表达式的查询参数进行远程数据查询,并根据查询结果计算每个表达式的运算结果。
在上述技术方案中,结果计算模块206在每批次表达式的所有查询参数中,按预定条件进行一组或多组查询参数的合并,并基于合并后的查询参数进行远程的批量数据查询。通过该技术方案,合并查询参数进行数据查询,可以减少查询次数,提高查询效率。
在上述技术方案中,批次处理模块204还建立复合区域,以存储每批次表达式,其中,复合区域按每批次表达式的类别,将其分组存储。
图3是根据本发明的一个实施例的脚本处理装置的原理示意图。
如图3所示,从本实施例中的脚本处理装置的工作流程上看,其主要包含以下4个部分:
1.客户端脚本解析器302:负责解析客户端脚本,形成表达式,分析表达式间的依赖关系,根据表达式性质(本地运算、缓存运算或者需要远程调用)及依赖关系对表达式进行分批。
2.客户端批量调用代理模块304:根据依赖关系按顺序执行分批过的表达式,并负责各批次表达式间变量的传递管理。对于一般运算表达式(即不需要执行数据查询的表达式)直接在客户端执行即可,对于可以在前台缓存查询的数据,则在前台缓存查询,这两种情况均可不进行批量处理;关键是对于那些需要从服务端查询的表达式,需要准备好批量调用参数,实现批调用。
3.服务端批量调用实现模块306:可根据准备好的调用参数,适配到持久层进行批量查询。
4.运算结果合并模块308:将各批次表达式执行结果分发到脚本执行引擎中,从脚本引擎的层面来看,批量远程调用的过程是透明的。
以下对上述各模块进行详细说明:
1.客户端脚本解析器302:
脚本的基本构成元素:表达式,常量,变量,函数,操作符;
例如,对于下面的一段脚本:
1)VAR_A=VAR_N1+FUN_L1(“234.12”);
2)VAR_B=FUN_QUERY(“gl_voucher”,“creditmny”,“voucher_code”,VAR_A)+“元”;
3)VAR_C=FUN_R2(VAR_B)+FUN_R3(VAR_B,VAR_A);
4)VAR_D=FUN_QUERY(“bd_person”,“personname”,“personcode”,VAR_PCODE);
其中,每一行整体称作表达式;
VAR_A,VAR_N1,VAR_B,VAR_C,VAR_PCODE均为变量;
“gl_voucher”,“creditmny”,“voucher_code”,“元”为常量;
FUN_L1(),FUN_QUERY(),FUN_R2(),FUN_R3()均为函数;
“+”为操作符。
依赖关系分析:
上面的脚本包含的四个表达式,假设其对应序号依次为:E1,E2,E3,E4。
E2里引用了VAR_A变量,我们称E2依赖了E1,同理E3依赖了E1和E2,E4则不依赖其他表达式。
图4详细介绍了客户端脚本解析器302的工作原理。
如图4所示,在步骤402,客户端脚本解析器302接受客户端脚本,通过脚本相关的解析器进行解析,可以将每个表达式都解析为树形结构,并最终得到树形结构的表达式集合。
步骤404,脚本解析器302循环处理表达式集合里的每一个表达式,判断其是否为一般运算表达式,即不需要进行数据查询,如果是,则加入到前台运算队列;如果否,则判断该表达式涉及到的查询运算是否都可以通过缓存查询,如果是,则一样加入到前台运算队列,如果判断结果为否,则将该表达式加入到远程运算队列。
步骤406,成功得到前台运算队列及远程运算队列之后,脚本解析器302需要分析表达式的依赖关系。此处理流程中依赖分析是关键,根据依赖关系的复杂程度,最终得到的可分批运算队列可能为2批,也可能为n批,其中(n>2)。在客户端脚本中,确定前台运算队列及远程运算队列后,依赖情况一般分为三种情况:
1)无依赖关系:
前台运算队列里的所有表达式和远程运算队列里的表达式之间没有直接的依赖关系,此时得到的分批队列直接分为两个批次即可;
2)简单依赖(无交叉):
前台运算队列里的表达式和远程运算队列里的表达式之间存在简单的依赖关系,即前台运算队列里的表达式依赖远程运算队列里的表达式,或者远程运算队列里的表达式依赖前台运算队列里的表达式,此时根据其依赖关系确定分批表达式的顺序即可;
3)交叉依赖:
前台运算队列里的表达式和远程运算队列里的表达式之间存在交叉依赖,即前台运算队列的表达式依赖远程运算队列表达式的同时,远程运算队列的表达式也依赖前台运算队列里的表达式,此时需要拆分为多个批次,分批按顺序执行。
为解决交叉依赖,我们引入复合区域,如图5所示,复合区域包含两个子区域,分别用于存放来自前台队列里的表达式以及来自远程队列里的表达式。交叉依赖的场景最终会得到多个有顺序的复合区域。
脚本解析器302根据复合区域进行依赖分析以对表达式分析的流程图如图6所示。
步骤602,首先得到前台运算队列和远程运算队列,要初始化第一个复合区域,位置为1,如前所述,复合区域上半部存放远程运算队列的表达式,下半部存放前台运算队列的表达式。
步骤604,将前台运算队列和远程运算队列中的每一个表达式,记为Ei,根据表达式中的变量,获取该表达式所依赖的所有表达式。
对Ei依赖的每一个表达式,在已经建立的复合区里搜索,判断是否已经存在,如果已经存在则记录下所属复合区域的位置,记为topN,否则可直接略过继续处理下一个依赖的公式。
Ei所有依赖的表达式处理完毕后,如果Ei属于前台运算队列,则加入到第topN个复合区域的下半部,如果不是,则在topN之上再新创建一个复合区域,位置为topN+1,并将Ei加入到新区域的上半部。
步骤606,最后根据复合区域的顺序,得到所有分批的运算表达式。
根据以上步骤的一个示例如下:
假如现在前台运算队列里有表达式E1、E2、E5,远程运算队列里有表达式E3、E4、E6、E7。依赖关系为:
E2→E6
E3→E1
E6→E5
E5→E2
则根据图6所示的依赖关系分析过程,复合区域形成的过程可以如如图7所示。
2.客户端批量调用代理模块304:
如图8所示,客户端批量调用代理模块304根据已经分批的表达式,需要按批进行处理。
步骤802,首先对其中的每一个表达式,判断其是否无数据查询,如果是,则直接调用脚本引擎的一般运算,否则判断是否可以从缓存查询,如果是,则基于缓存查询数据,这在引擎实现上还是一个一般性运算;如果以上都不是,则延迟引擎计算,提取查询参数。
步骤804,一次批次收集完,需要进行参数合并,对具有相同查询条件,相同表的查询进行合并。
步骤806,基于合并完的参数进行批量远程调用,得到该批次的远程调用结果。
步骤808,将该批次的远程调用结果更新到引擎的变量表。
按照以上逻辑,循环运算各个批次的表达式。
3.批量调用服务端实现模块306:
批量调用服务端实现模块306实现的远程调用如图9所示。该模块在服务端,根据不同的容器,比如Spring IOC,EJB,普通java,web打包应用等,相应的实现一个简单的无侵害的查询模块。
步骤902,首先根据合并后的参数形成适合特定容器持久层接口的查询;
步骤904,调用相应持久层接口进行查询,得到批量查询结果。
4.查询结果分发模块308:
查询结果分发模块308主要负责将各批次表达式执行结果分发到脚本执行引擎中,从脚本引擎层面来看,批量远程调用是透明的。流程图如图10所示。
步骤1002,首先从服务端得到批量执行的结果,然后对每一个查询结果,找到关联的表达式;
步骤1004,替换相应的在客户端批量调用代理装置被延迟运算的函数节点;
步骤1006,调用引擎进行一般性的运算,得到表达式的值,更新引擎变量表,循环完毕,最终得到脚本运算结果。
以上技术方案在实际应用中,效果如下:
经过大型ERP软件产品的验证,采用本发明技术后,客户端的调用次数明显下降,客户端业务操作效率明显提高。
Figure BDA0000071954050000111
值得一提的是,上表显示的效率优化结果是在前台缓存数据量较低的情况下取得的,更加凸显本发明的技术方案所带来的优化效果。
根据本发明的技术方案,可以实现一种脚本处理方法和一种脚本处理装置,可以有效地改进有实时性要求的数据密集型远程调用的效率,有效的解决了非交易型数据在无法缓存的情况下频繁产生远程调用的问题。其中,本发明的技术方案提供了用于客户端脚本解析和分析的方法和模块,不要求对客户端脚本做任何修改,大量存在的客户端脚本可保持不变,另外服务端只需外用于加批量调用执行的模块,对原有代码无任何侵入性,因此本发明的技术方案可迅速在各种客户端/服务端架构中应用。另外,本发明的技术方案能有效的分析出可合并的非交易型数据查询,客户端和服务端之间的远程调用数量急剧减少,提高了客户端操作的响应速度,给用户带来更流畅的体验效果。再者,本发明有广泛的适用性。只要客户端脚本符合本发明提到的脚本模型结构,本发明的技术方案都可以适用。
以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (10)

1.一种脚本处理方法,其特征在于,包括:
步骤102,从脚本中解析出表达式,并根据运算性质,将所述表达式分类,以及获取所述表达式之间的依赖关系;
步骤104,根据所述表达式的类别以及所述依赖关系,对所述表达式进行分批,并确定每批次表达式的执行顺序;
步骤106,按所述执行顺序执行所述每批次表达式,取得所述每批次表达式的运算结果;
步骤108,将所有批次表达式的运算结果返回给所述脚本,以获取所述脚本的运算结果。
2.根据权利要求1所述的脚本处理方法,其特征在于,在所述步骤102中,所述运算性质包括:
所述表达式是否需要进行数据查询;
所述表达式需要进行所述数据查询时,所述数据查询是否是基于缓存进行查询。
3.根据权利要求1所述的脚本处理方法,其特征在于,所述步骤106具体包括:
对于所述每批次表达式,判断其中每个表达式是否需要进行数据查询,在判断结果为否时,直接计算所述每个表达式的运算结果,
否则判断所述数据查询是否是基于缓存进行查询,在判断结果为是时,基于所述缓存进行所述数据查询,并根据查询结果计算所述每个表达式的运算结果,
否则提取所述每个表达式的查询参数,并基于所述每个表达式的查询参数进行远程数据查询,并根据查询结果计算所述每个表达式的运算结果。
4.根据权利要求3所述的脚本处理方法,其特征在于,所述基于所述每个表达式的查询参数进行远程数据查询具体包括:
在所述每批次表达式的所有查询参数中,按预定条件进行一组或多组查询参数的合并,并基于合并后的查询参数进行远程的批量数据查询。
5.根据权利要求1至4中任一项所述的脚本处理方法,其特征在于,还包括:
建立复合区域,以存储所述每批次表达式,其中,所述复合区域按所述每批次表达式的类别,将其分组存储。
6.一种脚本处理装置,其特征在于,包括:
脚本解析模块,从脚本中解析出表达式,并根据运算性质,将所述表达式分类,以及获取所述表达式之间的依赖关系;
批次处理模块,根据所述表达式的类别以及所述依赖关系,对所述表达式进行分批,并确定每批次表达式的执行顺序;
结果计算模块,按所述执行顺序执行所述每批次表达式,取得所述每批次表达式的运算结果;
结果返回模块,将所有批次表达式的运算结果返回给所述脚本,以获取所述脚本的运算结果。
7.根据权利要求6所述的脚本处理装置,其特征在于,所述运算性质包括:
所述表达式是否需要进行数据查询;
所述表达式需要进行所述数据查询时,所述数据查询是否是基于缓存进行查询。
8.根据权利要求6所述的脚本处理装置,其特征在于,对于所述每批次表达式,判断其中每个表达式是否需要进行数据查询,在判断结果为否时,直接计算所述每个表达式的运算结果,
否则判断所述数据查询是否是基于缓存进行查询,在判断结果为是时,基于所述缓存进行所述数据查询,并根据查询结果计算所述每个表达式的运算结果,
否则提取所述每个表达式的查询参数,并基于所述每个表达式的查询参数进行远程数据查询,并根据查询结果计算所述每个表达式的运算结果。
9.根据权利要求8所述的脚本处理装置,其特征在于,所述结果计算模块在所述每批次表达式的所有查询参数中,按预定条件进行一组或多组查询参数的合并,并基于合并后的查询参数进行远程的批量数据查询。
10.根据权利要求6至9中任一项所述的脚本处理装置,其特征在于,所述批次处理模块还建立复合区域,以存储所述每批次表达式,其中,所述复合区域按所述每批次表达式的类别,将其分组存储。
CN 201110177234 2011-06-28 2011-06-28 脚本处理方法和脚本处理装置 Active CN102222108B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN 201110177234 CN102222108B (zh) 2011-06-28 2011-06-28 脚本处理方法和脚本处理装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN 201110177234 CN102222108B (zh) 2011-06-28 2011-06-28 脚本处理方法和脚本处理装置

Publications (2)

Publication Number Publication Date
CN102222108A true CN102222108A (zh) 2011-10-19
CN102222108B CN102222108B (zh) 2013-06-05

Family

ID=44778660

Family Applications (1)

Application Number Title Priority Date Filing Date
CN 201110177234 Active CN102222108B (zh) 2011-06-28 2011-06-28 脚本处理方法和脚本处理装置

Country Status (1)

Country Link
CN (1) CN102222108B (zh)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103019705A (zh) * 2012-11-28 2013-04-03 南开大学 基于持久存储既有计算结果来加速程序计算的方法及***
CN104866310A (zh) * 2015-05-20 2015-08-26 百度在线网络技术(北京)有限公司 知识数据的处理方法和***
CN106991104A (zh) * 2016-01-21 2017-07-28 泰康保险集团股份有限公司 数据库脚本部署装置和数据库脚本部署方法
CN107220376A (zh) * 2017-06-21 2017-09-29 北京奇艺世纪科技有限公司 一种数据查询方法和装置
CN107784400A (zh) * 2016-08-24 2018-03-09 北京京东尚科信息技术有限公司 一种业务模型的执行方法和装置
CN110880059A (zh) * 2018-09-06 2020-03-13 北京京东尚科信息技术有限公司 批次号生成方法和装置
CN113765805A (zh) * 2021-08-31 2021-12-07 上海完美时空软件有限公司 基于调用的通信方法、装置、存储介质及设备

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101655782A (zh) * 2009-09-10 2010-02-24 浙江大学 基于基本块的汇编代码得出程序的数据流图的实现方法
JP2010262542A (ja) * 2009-05-08 2010-11-18 Panasonic Corp プロセッサ
CN102103519A (zh) * 2009-12-21 2011-06-22 同济大学 一种基于脚本的Web服务执行优化方法

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010262542A (ja) * 2009-05-08 2010-11-18 Panasonic Corp プロセッサ
CN101655782A (zh) * 2009-09-10 2010-02-24 浙江大学 基于基本块的汇编代码得出程序的数据流图的实现方法
CN102103519A (zh) * 2009-12-21 2011-06-22 同济大学 一种基于脚本的Web服务执行优化方法

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103019705B (zh) * 2012-11-28 2015-12-02 南开大学 基于持久存储既有计算结果来加速程序计算的方法及***
CN103019705A (zh) * 2012-11-28 2013-04-03 南开大学 基于持久存储既有计算结果来加速程序计算的方法及***
CN104866310B (zh) * 2015-05-20 2018-07-13 百度在线网络技术(北京)有限公司 知识数据的处理方法和***
CN104866310A (zh) * 2015-05-20 2015-08-26 百度在线网络技术(北京)有限公司 知识数据的处理方法和***
CN106991104A (zh) * 2016-01-21 2017-07-28 泰康保险集团股份有限公司 数据库脚本部署装置和数据库脚本部署方法
CN106991104B (zh) * 2016-01-21 2020-03-17 泰康保险集团股份有限公司 数据库脚本部署装置和数据库脚本部署方法
CN107784400A (zh) * 2016-08-24 2018-03-09 北京京东尚科信息技术有限公司 一种业务模型的执行方法和装置
CN107784400B (zh) * 2016-08-24 2021-05-25 北京京东尚科信息技术有限公司 一种业务模型的执行方法和装置
CN107220376A (zh) * 2017-06-21 2017-09-29 北京奇艺世纪科技有限公司 一种数据查询方法和装置
CN107220376B (zh) * 2017-06-21 2020-10-27 北京奇艺世纪科技有限公司 一种数据查询方法和装置
CN110880059A (zh) * 2018-09-06 2020-03-13 北京京东尚科信息技术有限公司 批次号生成方法和装置
CN113765805A (zh) * 2021-08-31 2021-12-07 上海完美时空软件有限公司 基于调用的通信方法、装置、存储介质及设备
CN113765805B (zh) * 2021-08-31 2023-10-20 上海完美时空软件有限公司 基于调用的通信方法、装置、存储介质及设备

Also Published As

Publication number Publication date
CN102222108B (zh) 2013-06-05

Similar Documents

Publication Publication Date Title
CN102222108B (zh) 脚本处理方法和脚本处理装置
CN109086031B (zh) 一种基于规则引擎的业务决策方法和装置
US11874828B2 (en) Managed materialized views created from heterogenous data sources
EP2596430B1 (en) A system and method for the parallel execution of database queries over cpus and multi core processors
CN104885078B (zh) 用于大规模并行处理数据库集群中的两阶段查询优化的方法
RU2607621C2 (ru) Способ, система и машиночитаемый носитель данных для группирования в социальных сетях
US9424309B2 (en) Method for optimizing performance of database/web-service backed applications by automatically prefetching query results
EP2386965A1 (en) Performing complex operations in a database using a semantic layer
Chauhan et al. Performance evaluation of Yahoo! S4: A first look
CN109325039A (zh) 一种区块链浏览器及区块链信息浏览方法
US9146979B2 (en) Optimization of business warehouse queries by calculation engines
CN107423053A (zh) 一种遥感图像处理的web化模型封装与分布式处理方法
CN108369591B (zh) 用于缓存和参数化ir的***和方法
EP2321725A1 (en) Structured query language function in-lining
WO2018035799A1 (zh) 数据查询方法、应用和数据库服务器、中间件及***
CN106406985B (zh) 分布式计算框架和分布式计算方法
US10140335B2 (en) Calculation scenarios with extended semantic nodes
US10078652B2 (en) Reducing latency in performing a task among distributed systems
US20140344244A1 (en) Calculation Engine with Dynamic Partitioning of Intermediate Results
CN101146113B (zh) 面向网络服务性能的动态配置***和方法
CN112860347A (zh) 一种小程序中存证文件的生成方法及装置
CN116401277A (zh) 数据处理方法、装置、***、设备及介质
CN110489214A (zh) 云环境中数据密集型工作流的动态任务分配
US10169410B2 (en) Merge of stacked calculation views with higher level programming language logic
US20170139982A1 (en) Processing of Data Chunks Using a Database Calculation Engine

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
C56 Change in the name or address of the patentee

Owner name: YONYOU NETWORK TECHNOLOGY CO., LTD.

Free format text: FORMER NAME: UFIDA SOFTWARE CO., LTD.

CP03 Change of name, title or address

Address after: 100094 Haidian District North Road, Beijing, No. 68

Patentee after: Yonyou Network Technology Co., Ltd.

Address before: 100094 Beijing city Haidian District North Road No. 68, UFIDA Software Park

Patentee before: UFIDA Software Co., Ltd.