一种实现数据表查询限制的装置和方法与流程

文档序号:13031531阅读:212来源:国知局
本发明涉及大数据
技术领域
:,尤其涉及一种实现数据表查询限制的装置。
背景技术
::大数据集群天生存在多租户问题,租户之间的数据既要隔离又要互通。在存放大量数据的数据仓库中,所有应用的数据存放在一个数据库表中,并通过各大应用的id号和事件发生的时间ds(一般按天)作为数据仓库的分区字段来区分不同的应用,这个是大数据集群常用的集中式数据存储的方式。对于这种几种存储,就有这样的问题:如何解决租户之间的数据的隔离,同时又具备各大应用之间的数据共享。如果没有做数据隔离,a应用访问数据时,采用形如:“select*fromtbl_events”的查询语句,就会查询到数据库表中其他应用的所有数据。普通的web业务系统碰到这种情况,一般会在查询语句中添加数据访问权限隔离语句(一般是数据所属应用信息),来完成数据访问权限的隔离,添加的数据访问权限隔离语句形如“wheretbl_event.appid=xxx”。但遗憾的是,大数据平台有一种即席查询这种业务场景,访问数据使用的sql语句并非程序员编写,而是由数据分析师或者其他接入业务方来编写。普通业务系统碰到这种情况,完全不知道在哪个地方添加数据访问权限隔离语句。技术实现要素:本发明的主要目的在于提出一种实现数据表查询限制的装置和方法,旨在解决如何自动在sql语句中正确地添加数据访问权限隔离语句的问题。为实现上述目的,本发明提供一种实现数据表查询限制的装置,包括:解析模块,用于利用语法解析器对待解析语句进行词法、语法的解析,生成语法树;查询模块,用于查询语法树中是否有表名和/或表重命名对应的第一节点;判断模块,用于若查询结果为是,则根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句;更改模块,用于若存在子句,则在子句后加入过滤条件,过滤条件用于利用待查表在数据库中的实际表名对待查表的查询范围进行限定,待查表为表名或表重命名对应的表。可选的,判断模块,用于判断第一节点所属的父节点中,是否存在上级节点类型为预设查询节点类型的第二节点,若存在,则第二节点对应的子句是属于子查询或第一级查询的子句。可选的,判断模块,用于对第一节点所属的父节点,按照从下向上的顺序循环以下的步骤:获取该父节点的上级节点类型,并判断上级节点类型是否为预设查询节点类型;若是,则确定当前的父节点是第二节点;否则判断上级节点类型是否是语法树顶级节点类型,若是,则退出。可选的,查询模块,用于利用事件触发监听的方法对语法树进行遍历;若触发预设的进入表名事件,则触发预设的进入表名事件的节点为表名或表重命名对应的第一节点。可选的,更改模块,用于判断子句中是否存在预设的查询位置词;若存在,则在查询位置词后面添加限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表;否则,在子句之后添加预设的查询位置词和限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表。为实现上述目的,本发明还提供一种实现数据表查询限制的方法,包括:利用语法解析器对待解析语句进行词法、语法的解析,生成语法树;查询语法树中是否有表名或表重命名对应的第一节点;若查询结果为是,则根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句;若存在子句,则在子句后加入过滤条件,过滤条件用于利用待查表在数据库中的实际表名对待查表的查询范围进行限定,待查表为表名或表重命名对应的表。可选的,根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句包括:判断第一节点所属的父节点中,是否存在上级节点类型为预设查询节点类型的第二节点,若存在,则第二节点对应的子句是属于子查询或第一级查询的子句。可选的,判断第一节点所属的父节点中,是否存在上级节点类型为预设查询节点类型的第二节点包括:对第一节点所属的父节点,按照从下向上的顺序循环以下的步骤:获取该父节点的上级节点类型,并判断上级节点类型是否为预设查询节点类型;若是,则确定当前的父节点是第二节点;否则判断上级节点类型是否是语法树顶级节点类型,若是,则退出。可选的,查询语法树中是否有表名或表重命名对应的第一节点包括:利用事件触发监听的方法对语法树进行遍历;若触发预设的进入表名事件,则触发预设的进入表名事件的节点为表名或表重命名对应的第一节点。可选的,在子句后加入过滤条件包括:判断子句中是否存在预设的查询位置词;若存在,则在查询位置词后面添加限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表;否则,在子句之后添加预设的查询位置词和限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表。采用本发明的实现数据表查询限制的装置和方法,可利用语法解析器对待解析语句进行词法、语法的解析,生成语法树;并在查询语法树中存在表名和/或表重命名对应的第一节点时,根据第一节点所属父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句;在该子句后加入过滤条件,该过滤条件用于利用待查表在数据库中的实际表名对待查表的查询范围进行限定,该待查表为表名或表重命名对应的表。本发明的装置完成了对待解析语句的语法树分析,并基于语法树分析在待解析语句准确找到添加过滤条件的位置,并添加正确的语句,实现了对待解析语句的数据查询权限限制,为即席查询业务场景下对租户之间的数据隔离问题提供了解决方案。附图说明图1为实现本发明各个实施例的一个可选择的移动终端的硬件结构示意图;图2是本发明的一种实现数据表查询限制的装置的模块示意图;图3是利用图2的中实现数据表查询限制的装置生成的语法树的示意图;图4是图2中的实现数据表查询限制的装置实现数据查询表权限限制的方法流程图;图5是本发明的一种实现数据表查询限制的装置的硬件结构示意图;图6是本发明的一种实现数据表查询限制的方法的流程图。本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。具体实施方式应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑等移动终端,以及诸如台式计算机等固定终端。后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:rf(radiofrequency,射频)单元101、wifi模块102、音频输出单元103、a/v(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。下面结合图1对移动终端的各个部件进行具体的介绍:射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于gsm(globalsystemofmobilecommunication,全球移动通讯系统)、gprs(generalpacketradioservice,通用分组无线服务)、cdma2000(codedivisionmultipleaccess2000,码分多址2000)、wcdma(widebandcodedivisionmultipleaccess,宽带码分多址)、td-scdma(timedivision-synchronouscodedivisionmultipleaccess,时分同步码分多址)、fdd-lte(frequencydivisionduplexing-longtermevolution,频分双工长期演进)和tdd-lte(timedivisionduplexing-longtermevolution,分时双工长期演进)等。wifi属于短距离无线传输技术,移动终端通过wifi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了wifi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或wifi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。a/v输入单元104用于接收音频或视频信号。a/v输入单元104可以包括图形处理器(graphicsprocessingunit,gpu)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或wifi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(liquidcrystaldisplay,lcd)、有机发光二极管(organiclight-emittingdiode,oled)等形式来配置显示面板1061。用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(i/o)端口、视频i/o端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。基于上述移动终端硬件结构,提出本发明方法各个实施例。实施例一:参见图2,本实施例中示出了一种实现数据表查询限制的装置,可以在用户输入待解析语句,如sql语言的时候,自动地对该语言进行分析,生成对应的语法树,然后根据语法树上的节点类型判断出该待解析语句中是否存在需要添加过滤条件的子句,并在存在该子句的时候自动对待解析语句进行过滤条件的添加。如图2所示的实现数据表查询限制的装置包括:解析模块21,用于利用语法解析器对待解析语句进行词法、语法的解析,生成语法树;查询模块22,用于查询语法树中是否有表名和/或表重命名对应的第一节点;判断模块23,用于若查询结果为是,则根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句;更改模块24,用于若存在,则在子句后加入过滤条件,过滤条件用于利用待查表在数据库中的实际表名对待查表的查询范围进行限定,待查表为表名或表重命名对应的表。在本实施例中上述的实现数据表查询限制的装置可以是固定终端,如电脑,也可以是移动终端如笔记本电脑,平板电脑,还可以是服务器。通过
背景技术
:可知,在大数据平台中存在一种即席查询的业务场景,在这种业务场景下,用户输入的查询语句是根据自己的需求灵活设置的。对于这种语句,其内容中可能没有关于书访问权限的隔离,即该语句查询的可能是数据库表中所有应用的所有数据,这种访问方式不能满足对于大数据租户的数据隔离的需求。为了在查询的时候,能保证租户的数据隔离,同时又能够使得各租户应用之间的数据共享,本实施例的装置需要达到的一个效果是在用户输入的语句中分析出是否需要添加过滤条件,以及添加过滤条件的正确位置。为了便于叙述,下面将用户输入的语句统称为待解析语句,为了便于对待解析语句的分析,本实施例的装置利用语法解析器对待解析语句生成了语法树。其中,本实施例中的语法解析器包括但不限于antlr(anothertoolforlanguagerecognition)语法分析器。可以预见,若待解析语句是程序员编写的,则程序员在编写的时候会有意识地在该语句中加入上述过滤条件,所以为了避免资源的浪费,本实施例的装置可以在用户的即席查询业务场景下工作。下面参见图3,以antlr语法解析器为例,对本实施例中解析模块利用ntlr语法解析器生成的语法树进行说明。假设待解析语句是selectcount(*)fromevent2asbleftjoinevent3ascgroupbyc.app”,图3中示出了利用ntlr语法解析器生成的语法树,在该语法树中,select/from/group/by/join/left/as/都可以有相应的文法规则来完成词法的解析。对于表名“event2”、“event3”以及他们的重命名“b”和“c”,还有“(”,“)”,“*”,“app”等在语法树解析中都有对应的类型来识别,并且是以单个字母为一个词。对于用户输入的语句中是否需要添加过滤条件的问题,如果在语法树中存在节点对应的内容是表名和/或表的重命名,则说明在待解析语句很可能是需要添加过滤条件的,所以查询模块22将语法树中是否有表名和/或表重命名对应的第一节点作为条件进行查询。其中,在用户将某个表存入数据库中时,可能会对该表进行重命名,所以上述的表重命名表示在用户修改表名的情况下,该表在数据库中的表名。在一个实施例中,上述的查询模块22,用于利用事件触发监听的方法对语法树进行遍历;若触发预设的进入表名事件,则触发预设的进入表名事件的节点为表名或表重命名对应的第一节点。具体的,查询模块22可以给语法树添加触发事件监听器,将触发事件定义为entertablename事件,然后遍历语法树,当触发entertablename事件,触发事件的节点就是表名或表重命名节点。当待解析语句中出现表名和/或表重命名时,待解析语句的作用可能是对该表名和/或表重命名对应的数据库表进行修改等等,而不一定是查询,所以为了过滤条件的添加准确,还需要进行表名和/或表重命名用于查询数据库表的确认。对于语法树而言,其具有多个节点,各个节点对应的节点类型不同。而上述的第一节点一般是具有多个父节点的(包括最近的父节点,父节点的父节点,父节点的父节点的父节点……等等),若是待解析语句中的表名或表重命名的作用是进行数据库表的查询,则第一节点所属的父节点中必然有查询节点,所以判断模块23可以根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句。具体的,断模块23可以在第一节点所属的父节点类型中出现预设查询节点类型时,判断待解析语句中存在属于子查询或第一级查询的子句。以上述图3中的语法树为例来分析,在上述的语法树中,第一节点可认为是“event2”“b”“event3”“c”中单个字母所在的节点,从该第一节点向上连接的都是其父节点,在其父节点中,存在父节点queryspecification的类型是queryspecificationcontext类型,这表明存在sql子查询或者第一级查询,所以该待解析语句中存在属于子查询或第一级查询的子句。可选的,判断模块23,用于判断第一节点所属的父节点中,是否存在上级节点类型为预设查询节点类型的第二节点;若存在,则第二节点对应的子句是属于子查询或第一级查询的子句。其中,预设节点类型包括但不限于queryspecification(查询详情)节点对应的是queryspecificationcontext(查询详情上下文)类型。判断模块,用于对第一节点的父节点,按照从下向上的顺序循环以下的步骤:获取该父节点的上级节点类型,并判断上级节点类型是否为预设查询节点类型;若是,则确定当前的父节点是第二节点;否则判断上级节点类型是否是语法树顶级节点,若是,则退出。下面结合图3中的语法树对判断模块23如何确定属于子查询或第一级查询的子句进行说明:在确定第一节点后,获取第一节点的向上的第一个父节点的上级节点类型,判断该上级节点类型是不是queryspecification对应的是queryspecificationcontext类型,若是,该说明遇到sql子查询或者第一级查询,该最近父节点对应的子句就是属于子查询或第一级查询的子句;若不是,则获取第一节点的向上的第二个父节点的上级节点类型,再判断该上级节点类型是不是queryspecification对应的是queryspecificationcontext类型,若是,该说明遇sql子查询或者第一级查询,该第二个父节点对应的子句就是属于子查询或第一级查询的子句;若不是,则获取第一节点的向上的第三个父节点的上级节点类型,在进行类似的判断过程,若获取到的第一节点的第n个父节点的类型是statement节点对应的是statementcontext类型,则说明是语法树顶级,需要退出。例如在图3的语法树中,当循环到语法树中的第一个relation节点(从语法树顶点向下的第一个relation节点),此时该relation节点的上级节点类型是queryspecificationcontext类型,该relaition节点就是第二节点,该relation节点对应的子句:“event2asbleftjoinevent3asc”就是需要添加过滤条件的子句,且过滤条件是添加在最后一个字母c的后面。更改模块24在子句中添加过滤条件的时候需要注意,由于过滤条件是对数据库中的待查表进行查询条件的设置,所以需要利用待查表在数据库中的实际表名进行过滤条件的设置。例如在上述的语法树中,event2对应的待查表在数据库中的表明是b,所以在设置过滤条件的时候,待查表表名是b,这样才可以在数据库中查到对应的表。一般地,过滤条件包括了查询位置词,例如where,和限制待查表中被查询数据来源的语句,该语句中表明两点,第一是待查表的在数据库中的表名;第二是被查询的待查表中被查询的数据所属的应用是哪一个。该语句的形式一般如“yyy.appid=xxx”yyy是待查表在数据库中的表名。可选的,更改模块24,用于判断子句中是否存在预设的查询位置词;若存在,则在查询位置词后面添加限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表;否则,在子句之后添加预设的查询位置词和限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表。例如,对于图3中的语法树,当判断模块23判断出第二节点后,在第二节点对应的子句“event2asbleftjoinevent3asc”添加限制条件时,需要判断第二节点下是否存在预设的查询位置词,例如where,如果存在,则直接在该查询位置词后添加待查表中被查寻数据来源的语句,即在where之后添加“c.appid=xxx”、“b.appid=xxx”的语句。若第二节点对应的子句中没有预设的查询位置词,例如where,则在子句之后添加wherec.appid=xxx”、“whereb.appid=xxx”类似的语句。下面结合图4一语法解析器为antlr,待解析语句为“selectcount(*)fromevent2asbleftjoinevent3ascgroupbyc.app”为例,对本实施例中的装置实现数据表查询限制的方法进行说明:s401、接收用户输入的sql语句(上述的待解析语句)。s402、使用antlr工具类commontokenstream解析sql语句生成词法流。s403、使用antlr的解析工具parser类,对词法流进行解析,生成语法树。s404、给语法树添加触发事件监听器,监听事件为entertablename事件。s405、遍历语法树时,若触发entertablename事件,则进入s406,进行过滤条件添加操作。否则重新回到s404。s406、获取当前节点的上级节点类型。s407、判断上级节点类型是否是queryspecification对应的,queryspecificationcontext类型(上下文类型)。如果是,则说明遇到sql子查询或者第一级查询,进入s408;否则进入s411。s408、判断当前节点下是否存在where词,如果是,则进入s409,否则进入s410。s409、则直接找到待解析语句中的where词,并在后面添加“条件”,如添加“yyy.appid=xxx”,其中,yyy为表在数据库中的实际表名。s410、找到如图3中语法树中第一个为relation节点类型的子句,在子句后面加上过滤子句”where条件”,如“wherec.appid=xxx”whereb.appid=xxx”。s411、判断上级节点类型是否是statement对应的是statementcontext类型,若是,则退出;否则将该上级节点作为当前节点,并返回s406。采用本实施例的装置,可利用语法解析器对待解析语句进行词法、语法的解析,生成语法树;查询语法树中是否有表名和/或表重命名对应的第一节点;若查询结果为是,则根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句;并在该子句存在的时候,则在子句后加入过滤条件,该过滤条件用于利用待查表在数据库中的实际表名对待查表的查询范围进行限定,该待查表为表名或表重命名对应的表。本实施例的装置完成了对用户输入的待解析语句的语法树分析,并在语法树的基础上进一步判断待解析语句是否需要过滤条件,并准确确定了过滤条件的添加位置,实现了对待解析语句的数据查询权限的限制,为即席查询业务场景下对租户之间的数据隔离问题提供了解决方案。实施例二:参见图5,本实施例示出了一种实现数据表查询限制的装置,包括控制器51和用户输入单元52,该用户输入模块52与控制器51连接。用户输入单元52用于接收用户输入的待解析语句并传输给控制器51。控制器51用于利用语法解析器对待解析语句进行词法、语法的解析,生成语法树;查询语法树中是否有表名和/或表重命名对应的第一节点;若查询结果为是,则根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句;若该子句存在,则在子句后加入过滤条件,过滤条件用于利用待查表在数据库中的实际表名对待查表的查询范围进行限定,待查表为表名或表重命名对应的表。在本实施例中上述的实现数据表查询限制的装置可以是固定终端,如电脑,也可以是移动终端如笔记本电脑,平板电脑,还可以是服务器。通过
背景技术
:可知,在大数据平台中存在一种即席查询的业务场景,在这种业务场景下,用户输入的查询语句是根据自己的需求灵活设置的。对于这种语句,其内容中可能没有关于书访问权限的隔离,即该语句查询的可能是数据库表中所有应用的所有数据,这种访问方式不能满足对于大数据租户的数据隔离的需求。为了在查询的时候,能保证租户的数据隔离,同时又能够使得各租户应用之间的数据共享,本实施例的装置需要达到的一个效果是在用户输入的语句中分析出是否需要添加过滤条件,以及添加过滤条件的正确位置。为了便于叙述,下面将用户输入的语句统称为待解析语句,为了便于对待解析语句的分析,本实施例的装置利用语法解析器对待解析语句生成了语法树。其中,本实施例中的语法解析器包括但不限于antlr(anothertoolforlanguagerecognition)语法分析器。可以预见,若待解析语句是程序员编写的,则程序员在编写的时候会有意识地在该语句中加入上述过滤条件,所以为了避免资源的浪费,本实施例的装置可以只在用户的即席查询业务场景下工作。对于语法树的结构,可以参见实施例一中的图3,对于用户输入的语句中是否需要添加过滤条件的问题,如果在语法树中存在节点对应的内容是表名和/或表的重命名,则说明在待解析语句很可能是需要添加过滤条件的,所以控制器51将语法树中是否有表名和/或表重命名对应的第一节点作为条件进行查询。其中,在用户将某个表存入数据库中时,可能会对该表进行重命名,所以上述的表重命名表示在用户修改表名的情况下,该表在数据库中的表名。在一个实施例中,控制器51用于利用事件触发监听的方法对语法树进行遍历;若触发预设的进入表名事件,则触发预设的进入表名事件的节点为表名或表重命名对应的第一节点。具体的,控制器51可以给语法树添加触发事件监听器,将触发事件定义为entertablename事件,然后遍历语法树,当触发entertablename事件,触发事件的节点就是表名或表重命名节点。当待解析语句中出现表名和/或表重命名时,待解析语句的作用可能是对该表名和/或表重命名对应的数据库表进行修改等等,而不一定是查询,所以为了过滤条件的添加准确,控制器51还需要进行表名和/或表重命名用于查询数据库表的确认。对于语法树而言,其具有多个节点,各个节点对应的节点类型不同。而上述的第一节点一般是具有多个父节点的(包括最近的父节点,父节点的父节点,父节点的父节点的父节点……等等),若是待解析语句中的表名或表重命名的作用是进行数据库表的查询,则第一节点所属的父节点中必然有查询节点,所以控制器51可以根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句。具体的,控制器51可以在第一节点所属的父节点类型中出现预设查询节点类型时,判断待解析语句中存在属于子查询或第一级查询的子句。以实施例一中图3的语法树为例来分析,在该语法树中,第一节点可认为是“event2”“b”“event3”“c”中单个字母所在的节点,从该第一节点向上连接的都是其父节点,在其父节点中,存在父节点queryspecification的类型是queryspecificationcontext类型,这表明存在sql子查询或者第一级查询,所以该待解析语句中存在属于子查询或第一级查询的子句。可选的,控制器51用于判断第一节点所属的父节点中,是否存在上级节点类型为预设查询节点类型的第二节点;若存在第二节点,则第二节点对应的子句是属于子查询或第一级查询的子句。其中,预设节点类型包括但不限于queryspecification(查询详情)节点对应的是queryspecificationcontext(查询详情上下文)类型。在一实施例中,控制器51用于对第一节点的父节点,按照从下向上(即从靠近第一节点的父节点到远离第一节点的父节点)的顺序循环以下的步骤:获取该父节点的上级节点类型,并判断上级节点类型是否为预设查询节点类型;若是,则确定当前的父节点是第二节点;否则判断上级节点类型是否是语法树顶级节点,若是,则退出。下面结合图3中的语法树对控制器51如何确定属于子查询或第一级查询的子句进行说明:在确定第一节点后,获取第一节点的向上的第一个父节点的上级节点类型,判断该上级节点类型是不是queryspecification对应的是queryspecificationcontext类型,若是,该说明遇到sql子查询或者第一级查询,该最近父节点对应的子句就是属于子查询或第一级查询的子句;若不是,则获取第一节点的向上的第二个父节点的上级节点类型,再判断该上级节点类型是不是queryspecification对应的是queryspecificationcontext类型,若是,该说明遇sql子查询或者第一级查询,该第二个父节点对应的子句就是属于子查询或第一级查询的子句;若不是,则获取第一节点的向上的第三个父节点的上级节点类型,在进行类似的判断过程,若获取到的第一节点的第n个父节点的类型是statement节点对应的是statementcontext类型,则说明是语法树顶级,需要退出。例如在图3的语法树中,当循环到语法树中的第一个relation节点(从语法树顶点向下的第一个relation节点),此时该relation节点的上级节点类型是queryspecificationcontext类型,该relaition节点就是第二节点,该relation节点对应的子句:“event2asbleftjoinevent3asc”就是需要添加过滤条件的子句,且过滤条件是添加在最后一个字母c的后面。控制器51在子句中添加过滤条件的时候需要注意,由于过滤条件是对数据库中的待查表进行查询条件的设置,所以需要利用待查表在数据库中的实际表名进行过滤条件的设置。例如在上述的语法树中,event2对应的待查表在数据库中的表明是b,所以在设置过滤条件的时候,待查表表名是b,这样才可以在数据库中查到对应的表。在数据库中的表上存储了很多个应用的数据,对一个待查表的查询范围的限制,可以是只允许查询待查该表上的一个或几个应用的数据,即限定该待查表上允许被查询的应用数据属于哪个应用。可选的,控制器51用于判断子句中是否存在预设的查询位置词;若存在,则在查询位置词后面添加限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表;否则,在子句之后添加预设的查询位置词和限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表。例如,对于图3中的语法树,当控制器51判断出第二节点后,在对第二节点对应的子句“event2asbleftjoinevent3asc”添加限制条件时,需要判断第二节点下是否存在预设的查询位置词,例如where,如果存在,则直接在该查询位置词后添加待查表中被查寻数据来源的语句,即在where之后添加“c.appid=xxx”、“b.appid=xxx”的语句。若第二节点对应的子句中没有预设的查询位置词,例如where,则在子句之后添加wherec.appid=xxx”、“whereb.appid=xxx”类似的语句。本实施例的装置完成了对用户输入的待解析语句的语法树分析,并在语法树的基础上进一步判断待解析语句是否需要过滤条件,并准确确定了过滤条件的添加位置,实现了对待解析语句的数据查询权限的限制,为即席查询业务场景下对租户之间的数据隔离问题提供了解决方案。实施例三:参见图6,本实施例中示出了一种实现数据表查询限制的方法,包括:s601、利用语法解析器对待解析语句进行词法、语法的解析,生成语法树;s602、查询语法树中是否有表名或表重命名对应的第一节点;s603、若有,则根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句;s604、若存在该子句,则在子句后加入过滤条件,过滤条件用于利用待查表在数据库中的实际表名对对待查表的查询范围进行限定,待查表为表名或表重命名对应的表。在本实施例中实现上述方案的可以是固定终端,如电脑,也可以是移动终端如笔记本电脑,平板电脑,还可以是服务器。为了便于叙述,下面将用户输入的语句统称为待解析语句,为了便于对待解析语句的分析,本实施例的装置利用语法解析器对待解析语句生成了语法树。其中,本实施例中的语法解析器包括但不限于antlr(anothertoolforlanguagerecognition)语法分析器。可以预见,若待解析语句是程序员编写的,则程序员在编写的时候会有意识地在该语句中加入上述过滤条件,所以为了避免资源的浪费,本实施例的装置可以在用户的即席查询业务场景下工作。假设待解析语句是selectcount(*)fromevent2asbleftjoinevent3ascgroupbyc.app”,语法解析器为ntlr语法解析器,在s601中生成的语法树可以参见实施例一中的图3所示的语法树。对于用户输入的语句中是否需要添加过滤条件的问题,如果在语法树中存在节点对应的内容是表名和/或表的重命名,则说明在待解析语句很可能是需要添加过滤条件的,所以在s602中将语法树中是否有表名和/或表重命名对应的第一节点作为条件进行查询。其中,在用户将某个表存入数据库中时,可能会对该表进行重命名,所以上述的表重命名表示在用户修改表名的情况下,该表在数据库中的表名。在一个实施例中,上述的s602中查询语法树中是否有表名或表重命名对应的第一节点包括:利用事件触发监听的方法对语法树进行遍历;若触发预设的进入表名事件,则触发预设的进入表名事件的节点为表名或表重命名对应的第一节点。具体的,s602中可以给语法树添加触发事件监听器,将触发事件定义为entertablename事件,然后遍历语法树,当触发entertablename事件,触发事件的节点就是表名或表重命名节点。当待解析语句中出现表名和/或表重命名时,待解析语句的作用可能是对该表名和/或表重命名对应的数据库表进行修改等等,而不一定是查询,所以为了过滤条件的添加准确,还需要进行表名和/或表重命名用于查询数据库表的确认。对于语法树而言,其具有多个节点,各个节点对应的节点类型不同。而上述的第一节点一般是具有多个父节点的(包括最近的父节点,父节点的父节点,父节点的父节点的父节点……等等),若是待解析语句中的表名或表重命名的作用是进行数据库表的查询,则第一节点所属的父节点中必然有查询节点,所以s603中可以根据第一节点所属的父节点的类型,判断待解析语句中是否存在属于子查询或第一级查询的子句。具体的,可以在第一节点所属的父节点类型中出现预设查询节点类型时,判断待解析语句中存在属于子查询或第一级查询的子句。以上述图3中的语法树为例来分析,在上述的语法树中,第一节点可认为是“event2”“b”“event3”“c”中单个字母所在的节点,从该第一节点向上连接的都是其父节点,在其父节点中,存在父节点queryspecification的类型是queryspecificationcontext类型,这表明存在sql子查询或者第一级查询,所以该待解析语句中存在属于子查询或第一级查询的子句。在一实施例中,s603中的根据第一节点所属的父节点的类型,判断待解析语句中是否存在子查询语或第一级查询的子句包括:判断第一节点所属的父节点中,是否存在上级节点类型为预设查询节点类型的第二节点;若存在,则第二节点对应的子句是属于子查询或第一级查询的子句。其中,预设节点类型包括但不限于queryspecification(查询详情)节点对应的是queryspecificationcontext(查询详情上下文)类型。在本实施例中,判断第一节点所属的父节点中,存在上级节点类型为预设查询节点类型的第二节点的方法包括:对第一节点的父节点,按照从下向上的顺序循环以下的步骤:获取该父节点的上级节点类型,并判断上级节点类型是否为预设查询节点类型;若是,则确定当前的父节点是第二节点;否则判断上级节点类型是否是语法树顶级节点,若是,则退出。下面结合图3中的语法树对如何确定属于子查询或第一级查询的子句进行说明:在确定第一节点后,获取第一节点的向上的第一个父节点的上级节点类型,判断该上级节点类型是不是queryspecification对应的是queryspecificationcontext类型,若是,该说明遇到sql子查询或者第一级查询,该最近父节点对应的子句就是属于子查询或第一级查询的子句;若不是,则获取第一节点的向上的第二个父节点的上级节点类型,再判断该上级节点类型是不是queryspecification对应的是queryspecificationcontext类型,若是,该说明遇sql子查询或者第一级查询,该第二个父节点对应的子句就是属于子查询或第一级查询的子句;若不是,则获取第一节点的向上的第三个父节点的上级节点类型,在进行类似的判断过程,若获取到的第一节点的第n个父节点的类型是statement节点对应的是statementcontext类型,则说明是语法树顶级,需要退出。例如在图3的语法树中,当循环到语法树中的第一个relation节点(从语法树顶点向下的第一个relation节点),此时该relation节点的上级节点类型是queryspecificationcontext类型,该relaition节点就是第二节点,该relation节点对应的子句:“event2asbleftjoinevent3asc”就是需要添加过滤条件的子句,且过滤条件是添加在最后一个字母c的后面。在s604中,在子句中添加过滤条件的时候需要注意,由于过滤条件是对数据库中的待查表进行查询条件的设置,所以需要利用待查表在数据库中的实际表名进行过滤条件的设置。例如在上述的语法树中,event2对应的待查表在数据库中的表明是b,所以在设置过滤条件的时候,待查表表名是b,这样才可以在数据库中查到对应的表。一般地,过滤条件包括了查询位置词,例如where,和限制待查表中被查询数据来源的语句,该语句中表明两点,第一是待查表的在数据库中的表名;第二是被查询的待查表中被查询的数据所属的应用是哪一个。该语句的形式一般如“yyy.appid=xxx”yyy是待查表在数据库中的表名。可选的,s604中在子句后加入过滤条件的方法包括:判断子句中是否存在预设的查询位置词;若存在,则在查询位置词后面添加限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表;否则,在子句之后添加预设的查询位置词和限制待查表中被查寻数据来源的语句,待查表为表名或表重命名对应的表。例如,对于图3中的语法树,当判断出第二节点后,在第二节点对应的子句“event2asbleftjoinevent3asc”添加限制条件时,需要判断第二节点下是否存在预设的查询位置词,例如where,如果存在,则直接在该查询位置词后添加待查表中被查寻数据来源的语句,即在where之后添加“c.appid=xxx”、“b.appid=xxx”的语句。若第二节点对应的子句中没有预设的查询位置词,例如where,则在子句之后添加wherec.appid=xxx”、“whereb.appid=xxx”类似的语句。采用本实施例的实现数据表查询限制的方法,可以在对待解析语句的语法树分析的基础上,判断待解析语句是否需要过滤条件,并在待解析语句的正确位置上添加正确的过滤条件,实现了对待解析语句的数据查询权限的限制,为即席查询业务场景下对租户之间的数据隔离问题提供了解决方案。需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如rom/ram、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例的方法。上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。当前第1页12当前第1页12
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1