数据处理方法、装置及服务器与流程

文档序号:12364341阅读:200来源:国知局
数据处理方法、装置及服务器与流程

本发明涉及计算机技术领域,具体而言,涉及一种数据处理方法、装置及服务器。



背景技术:

在现今的互联网系统中,服务器需要面对海量数据的存储和访问。特别是对于OLTP(On-Line Transaction Processing)类系统,由于该类系统对数据处理需要有较强的事务性要求,并且同时还要求系统有较高的处理能力。但是由于传统数据存储系统的单数据库表的方式,且受数据存储系统承载设备的物理硬件本身的限制,在不升级承载设备的物理硬件的情况下,无法有效的提升数据存储系统的高并发数据处理能力。



技术实现要素:

有鉴于此,本发明实施例的目的在于提供一种数据处理方法、装置及服务器,以提升数据存储系统的高并发读写能力。

第一方面,本发明实施例提供了一种数据处理方法,应用于应用服务器,所述方法包括:响应于第一数据查询指令,获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表;获取数据表切分配置信息;基于所述数据表切分配置信息以及所述关键信息,获取所述初始数据表对应的目标数据表,所述目标数据表为预先基于所述数据表切分配置信息将所述初始数据表切分为多个子数据表中的一个;生成携带有所述关键信息并指向所述目标数据表的第二数据查询指令。

第二方面,本发明实施例提供了一种数据处理方法,应用于应用服务器,所述方法包括:响应于第一数据查询指令,获取所述第一数据查询指令所携带的查询条件以及所指向的初始数据表;获取数据表切分配置信息;基于所述数据表切分配置信息预先将所述初始数据表切分为多个子数据表;基于所述查询条件生成第二查询指令;将所述第二查询指令发送到每个所述子数据表进行数据查询,获得每个所述子数据表对应的查询结果;将所述每个所述子数据表对应的查询结果进行合并,以获取所述第一数据查询指令所对应的查询结果。

第三方面,本发明实施例提供的一种数据处理装置,应用于应用服务器,所述装置包括:数据响应单元,用于响应于第一数据查询指令,获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表;数据获取单元,用于获取数据表切分配置信息;数据切分单元,用于基于所述数据表切分配置信息以及所述关键信息,获取所述初始数据表对应的目标数据表,所述目标数据表为预先基于所述数据表切分配置信息将所述初始数据表切分为多个子数据表中的一个;数据生成单元,用于生成携带有所述关键信息并指向所述目标数据表的第二数据查询指令。

第四方面,本发明实施例提供的一种数据处理装置,应用于应用服务器,所述装置包括:数据响应单元,用于响应于第一数据查询指令,获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表;数据获取单元,用于获取数据表切分配置信息;数据切分单元,用于基于所述数据表切分配置信息预先将所述初始数据表切分为多个子数据表;数据生成单元,用于基于所述查询条件生成第二查询指令;数据查询单元,用于将所述第二查询指令发送到每个所述子数据表进行数据查询,获得每个所述子数据表对应的查询结果;数据合并单元,用于将所述每个所述子数据表对应的查询结果进行合并,以获取所述第一数据查询指令所对应的查询结果。

第五方面,本发明实施例提供了一种服务器,所述服务器包括处理器以及存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述服务器执行以下操作:响应于第一数据查询指令,获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表;获取数据表切分配置信息;基于所述数据表切分配置信息以及所述关键信息,获取所述初始数据表对应的目标数据表,所述目标数据表为预先基于所述数据表切分配置信息将所述初始数据表切分为多个子数据表中的一个;生成携带有所述关键信息并指向所述目标数据表的第二数据查询指令。

第六方面,本发明实施例提供了一种服务器,所述服务器包括处理器以及存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述服务器执行以下操作:响应于第一数值查询指令,获取所述第一数值查询指令所携带的查询条件以及所指向的初始数据表;获取数据表切分配置信息,所述数据表切分配置信息包括预先将所述初始数据表切分后得到的多个子数据表各自的标识信息;基于所述查询条件以及所述多个子数据表各自的标识信息,生成分别对应所述多个子数据表的第二数值查询指令;向数据库服务器存储的所述多个子数据表发送各自对应的第二数值查询指令,接收多个子数据表各自返回的的查询结果,并将所述多个子数据表各自返回的的查询结果进行合并,以获得所述第一数值查询指令的查询结果。

本发明实施例提供的数据处理方法、装置及服务器,通过响应于第一数据查询指令,以获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表,然后获取数据表切分配置信息,再基于所述数据表切分配置信息以及所述关键信息,获取所述初始数据表对应的目标数据表,最后生成携带有所述关键信息并指向所述目标数据表的第二数据查询指令,使得将初始数据表切分为多个子数据表,且子数据表的数据量较大程度的低于初始数据表后,在进行单次数据查询过程中,生成的第二数据查询指令在所指向的子数据表中即可查询到第一查询指令所要查询到的数据,进而使得单次查询过程中所处理的数据量减小,提升了单次数据查询的速度,从而提升了整体的数据的高并发读写能力。

本发明实施例提供的数据处理方法、装置及服务器,通过响应于第一数值查询指令,获取所述第一数值查询指令所携带的查询条件以及所指向的初始数据表,进一步获取数据表切分配置信息,所述数据表切分配置信息包括预先将所述初始数据表切分后得到的多个子数据表各自的标识信息,然后基于所述查询条件以及所述多个子数据表各自的标识信息,生成分别对应所述多个子数据表的第二数值查询指令后,再向数据库服务器存储的所述多个子数据表发送各自对应的第二数值查询指令,并接收多个子数据表各自返回的的查询结果,并将所述多个子数据表各自返回的的查询结果进行合并,以获得所述第一数值查询指令的查询结果,即通过将第二数值查询指令查询获得的结果进行合并处理,使得第二数值查询指令获得的结果与第一数值查询指令获得的结果相同。

本发明的其他特征和优点将在随后的说明书阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明实施例了解。本发明的目的和其他优点可通过在所写的说明书、权利要求书、以及附图中所特别指出的结构来实现和获得。

附图说明

为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。

图1为本发明较佳实施例提供的服务器与本地终端进行交互的示意图;

图2为本发明较佳实施例提供的数据处理装置的结构框图;

图3为本发明较佳实施例提供的一种数据处理方法的流程图;

图4为本发明较佳实施例提供的一种数据处理方法中的数据库分表示意图;

图5为本发明较佳实施例提供的另一种数据处理方法的流程图;

图6为本发明实施例提供的一种数据处理装置的结构框图;

图7为本发明实施例提供的另一种数据处理装置的结构框图。

具体实施方式

下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。

应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。

如图1所示,是本发明较佳实施例提供的数据库服务器与应用服务器进行交互的示意图。所述数据库服务器200通过网络与一个或多个应用服务器100进行通信连接,以进行数据通信或交互。

图2示出了一种可应用于本申请实施例中的应用服务器的结构框图。如图2所示,应用服务器包括:数据处理装置201、存储器202、存储控制器203、处理器204。

数据处理装置201、存储器202、存储控制器203和处理器204各元件之间直接或间接地电连接,以实现数据的传输或交互。例如,这些元件之间可以通过一条或多条通讯总线或信号总线实现电连接。所述数据处理方法包括至少一个可以以软件或固件(firmware)的形式存储于存储器202中的软件功能模块,例如所述数据处理装置201包括的软件功能模块或计算机程序。

存储器202可以存储各种软件程序以及模块,如本申请实施例提供的数据处理方法以及装置对应的程序指令/模块。处理器204通过运行存储在存储器202中的软件程序以及模块,从而执行各种功能应用以及数据处理,即实现本申请实施例中的数据处理方法。存储器202可以包括但不限于随机存取存储器(Random Access Memory,RAM),只读存储器(Read Only Memory,ROM),可编程只读存储器(Programmable Read-Only Memory,PROM),可擦除只读存储器(Erasable Programmable Read-Only Memory,EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-Only Memory,EEPROM)等。

处理器204可以是一种集成电路芯片,具有信号处理能力。上述处理器可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(DSP)、专用集成电路(ASIC)、现成可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。其可以实现或者执行本申请实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。

请参阅图3,本发明实施例提供的一种数据处理方法,应用于应用服务器,所述方法包括:

步骤S301:响应于第一数据查询指令,获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表。

当应用服务器接收到应用服务器发送的第一数据查询指令时,便可以获取第一数据查询指令所携带的关键信息以及所指向的初始数据表。其中,所述关键信息可以是查询条件。通过获取所述关键信息获取该第一数据查询指令所查询的初始数据表。例如,当用户输入的第一数据查询指令为:select*from user where user_id=1时,应用服务器可以获取到的关键信息包括查询条件user_id=1以及查询的初始数据表为user表。

步骤S302:获取数据表切分配置信息。

其中,所述数据表切分配置信息是预先设置的。其中,数据表切分配置信息可以从本地获取,也可以从数据库服务器中获取,还可以通过第三方提供的配置服务获取。

当从数据库服务器中获取时,应用服务器可以先向数据库服务器发送版本号查找指令,再接收所述数据库服务器返回的所述数据库服务器存储的数据表切分配置信息的当前版本号,将所述当前版本号与本地存储的数据表切分配置信息的版本号进行对比。当所述当前版本号比原来的数据表切分配置信息的版本号高时,应用服务器向数据库服务器发送数据表切分配置信息请求指令,获取所述数据库服务器返回的数据表切分配置信息。通过获取更高的版本号实现对当前的数据表切分配置信息的版本进行更新,以使应用服务器能够对数据表切分配置信息进行更新。

步骤S303:基于所述数据表切分配置信息以及所述关键信息,获取所述初始数据表对应的目标数据表,所述目标数据表为预先基于所述数据表切分配置信息将所述初始数据表切分为多个子数据表中的一个。

作为一种实施方式,所述关键信息可以包括查询条件参数,所述数据表切分配置信息可以包括所述初始数据表的切分参考参数,其中,查询条件参数用于表征该条第一数据查询指令的查询依据,切分参考参数表征初始数据表的切分依据。

则在获取到查询条件参数以及切分参考参数后,可以通过将所述查询条件参数与所述切分参考参数进行匹配,得到目标参数,然后将所述目标参数对应的所述子数据表作为目标数据表。

例如,当用户输入的第一数据查询指令为:select*from user where user_name=张三时,那么所述查询条件参数为user_name=张三,当所述切分参考参数为数据的首字母时,则初始数据表会被切分为多个存储的数据的首字母不同的子数据表。那么user_name=张三中张三的首字母为ZH,于是就根据首字母ZH找到存储的数据的首字母为ZH的子数据表为目标数据表,然后从目标数据表中进行查询。

此外,切分参考参数还可以是切分成的子数据表的总数,例如,数据库服务器现在有一个用户表user,包含user_id和name两个字段,并且存储有6个user_id以及每个user_id对应的name,数据库服务器可以配置按照user_id进行数据切分,如果把user表分成3个子数据表,即所述切分参考参数为user_id且所切分的个数为3。那么如图4所示,子数据表分别为shard_0、shard_1和shard_2,于是shard_0存储的是user_id=3和user_id=6,shard_1存储的是user_id=1和user_id=4,shard_2存储的是user_id=2和user_id=5。那么当用户输入的第一数据查询指令为:select*from user where user_id=1时,通过将user_id和子数据表的个数进行求余,获得余数,通过数据表切分配置信息找到余数所对应的目标数据表,即将user_id与3求余等于是将user_id的值1与3进行求余,得到余数为1,然后根据数据表切分配置信息找到余数1对应的目标数据表shard_1。

步骤S304:生成携带有所述关键信息并指向所述目标数据表的第二数据查询指令。

本实施例提供的方法使得将初始数据表切分为多个子数据表,且子数据表的数据量较大程度的低于初始数据表后,在进行单次数据查询过程中,生成的第二数据查询指令在所指向的子数据表中即可查询到第一查询指令所要查询到的数据,进而使得单次查询过程中所处理的数据量减小,提升了单次数据查询的速度,从而提升了整体的数据的高并发读写能力。

请参阅图5,本发明实施例提供的另一种数据处理方法,应用于应用服务器,所述方法包括:

步骤S401:响应于第一数值查询指令,获取所述第一数值查询指令所携带的查询条件以及所指向的初始数据表。

作为一种实施方式,当用户输入第一数值查询指令后,应用服务器基于第一数值查询指令获取该第一数值查询指令的查询条件,其中,第一数值查询指令是指该第一数值查询指令所查询的条件是一个数值,该数值可以是数据表数据的总条数或者还可以是某个字段数据的平均数。通过获取所述第一数值查询指令的查询条件获取该第一数值查询指令所查询的数据表。例如,当用户输入的第一数值查询指令为:select avg(user_id)from user时,应用服务器可以获取到的查询条件为user_id以及查询的初始数据表为user表。

步骤S402:获取数据表切分配置信息,所述数据表切分配置信息包括预先将所述初始数据表切分后得到的多个子数据表各自的标识信息。

其中,所述数据表切分配置信息是预先设置的,所述数据表切分配置信息包括预先将所述初始数据表切分后得到的多个子数据表各自的标识信息,其中,所述标识信息是指每个所述子数据表的表名。通过获取的数据表切分配置信息,以使应用服务器能够根据获取到的数据表切分配置信息将所述第一数值查询指令发送到该第一数值查询指令所查询的数据表。

步骤S403:基于所述查询条件以及所述多个子数据表各自的标识信息,生成分别对应所述多个子数据表的第二数值查询指令。

作为一种实施方式,例如,数据库服务器现在有一个用户表user,包含user_id和name两个字段,其中user_id所表征的数字的大小是按照出现在数据表里面的顺序进行设置的,并且存储有6个user_id以及每个user_id对应的name,数据库服务器可以配置按照user_id进行数据切分,如果把user表分成3个子数据表,即所述切分参考参数为user_id且所切分的个数为3。那么子数据表分别为shard_0、shard_1和shard_2,于是shard_0存储的是user_id=3和user_id=6,shard_1存储的是user_id=1和user_id=4,shard_2存储的是user_id=2和user_id=5。那么当用户输入的第一数值查询指令为:select avg(user_id)from user,那么根据每个子数据表各自的标识信息将用户输入的第一数值查询指令改写为:select avg(user_id)from shard_0,select avg(user_id)from shard_1,select avg(user_id)from shard_2。

步骤S404:向数据库服务器存储的所述多个子数据表发送各自对应的第二数值查询指令,接收多个子数据表各自返回的的查询结果,并将所述多个子数据表各自返回的的查询结果进行合并,以获得所述第一数值查询指令的查询结果。

作为一种实施方式,经过步骤S403后,将改写后的第二数值查询指令发送到各自对应的数据库服务器所存储的所述多个子数据表,并接收多个子数据表各自返回的的查询结果,然后将所述多个子数据表各自返回的的查询结果进行合并,以获得所述第一数值查询指令的查询结果。例如,数据库服务器现在有一个用户表user,包含user_id和name两个字段,其中user_id所表征的数字的大小是按照出现在数据表里面的顺序进行设置的,并且存储有6个user_id以及每个user_id对应的name,数据库服务器可以配置按照user_id进行数据切分,如果把user表分成3个子数据表,即所述切分参考参数为user_id且所切分的个数为3。那么子数据表分别为shard_0、shard_1和shard_2,于是shard_0存储的是user_id=3和user_id=6,shard_1存储的是user_id=1和user_id=4,shard_2存储的是user_id=2和user_id=5。那么当用户输入的第一数值查询指令为:select avg(user_id)from user,则可以根据每个子数据表各自的标识信息将用户输入的第一数值查询指改写为:select avg(user_id)from shard_0,select avg(user_id)from shard_1,select avg(user_id)from shard_2。那么每个改写后的第二数值查询指令返回的结果分别为4.5、2.5、3.5,然后将所有的结果进行合并即将返回的结果先加和然后再除以加和个数,即(4.5+2.5+3.5)/3=3.5。那么通过合并所得到的结果3.5即为用户所查询的结果,即通过select avg(user_id)from user所查询的结果与改写后的查询语句查询的结果一致。

请参阅图6,本发明实施例提供的一种数据处理装置500,应用于应用服务器,所述装置500包括:数据响应单元510、数据获取单元520、数据改写单元530和数据生成单元540。

其中,数据响应单元510,用于响应于第一数据查询指令,获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表。

数据获取单元520,用于获取数据表切分配置信息。

其中,数据获取单元520还包括数据版本获取子单元521和数据版本比对子单元522。

数据版本获取子单元521,用于向数据库服务器发送版本号查找指令,接收所述数据库服务器返回的所述数据库服务器存储的数据表切分配置信息的当前版本号。

数据版本比对子单元522,用于将所述当前版本号与本地存储的数据表切分配置信息的版本号进行对比。当所述当前版本号高时,向数据库服务器发送数据表切分配置信息请求指令,获取所述数据库服务器返回的数据表切分配置信息。

数据改写单元530,用于基于所述数据表切分配置信息以及所述关键信息,获取所述初始数据表对应的目标数据表,所述目标数据表为预先基于所述数据表切分配置信息将所述初始数据表切分为多个子数据表中的一个。

其中,数据改写单元530还包括数据匹配子单531。

数据匹配子单元531,用于将所述查询条件参数与所述切分参考参数进行匹配,得到目标参数,将所述目标参数对应的所述子数据表作为目标数据表。

其中,所述数据匹配子单元531还用于,将所述顺序值与所述初始数据表对应的多个子数据表的总数进行求余,获得余数,将所述多个子数据表中与所述余数对应的子数据表作为目标数据表。其中,所述查询条件参数为所查询数据在所述初始数据表中顺序的顺序值,所述切分参考参数为所述初始数据表对应的多个子数据表的总数。

数据生成单元540,用于生成携带有所述关键信息并指向所述目标数据表的第二数据查询指令。

请参阅图7,本发明实施例提供的另一种数据处理装置,应用于应用服务器,所述装置包括:数据响应单元610、数据获取单元620、数据生成单元630和数据合并单元640。

其中,数据响应单元610,用于响应于第一数值查询指令,获取所述第一数值查询指令所携带的查询条件以及所指向的初始数据表。

数据获取单元620,用于获取数据表切分配置信息,所述数据表切分配置信息包括预先将所述初始数据表切分后得到的多个子数据表各自的标识信息。

数据生成单元630,用于基于所述查询条件以及所述多个子数据表各自的标识信息,生成分别对应所述多个子数据表的第二数值查询指令。

数据合并单元640,用于向数据库服务器存储的所述多个子数据表发送各自对应的第二数值查询指令,接收多个子数据表各自返回的的查询结果,并将所述多个子数据表各自返回的的查询结果进行合并,以获得所述第一数值查询指令的查询结果。

综上所述,本发明实施例提供的一种数据处理方法、装置及服务器,通过响应于第一数据查询指令,以获取所述第一数据查询指令所携带的关键信息以及所指向的初始数据表,然后获取数据表切分配置信息,再基于所述数据表切分配置信息以及所述关键信息,获取所述初始数据表对应的目标数据表,最后生成携带有所述关键信息并指向所述目标数据表的第二数据查询指令的方式,使得将初始数据表切分为多个子数据表,且子数据表的数据量较大程度的低于初始数据表后,在进行单次数据查询过程中,生成的第二数据查询指令在所指向的子数据表中即可查询到第一查询指令所要查询到的数据,进而使得单次查询过程中所处理的数据量减小,提升了单次数据查询的速度,从而提升了整体的数据的高并发读写能力。

本发明实施例提供的另一种数据处理方法、装置及服务器,通过响应于第一数值查询指令,获取所述第一数值查询指令所携带的查询条件以及所指向的初始数据表,进一步获取数据表切分配置信息,所述数据表切分配置信息包括预先将所述初始数据表切分后得到的多个子数据表各自的标识信息,然后基于所述查询条件以及所述多个子数据表各自的标识信息,生成分别对应所述多个子数据表的第二数值查询指令后,再向数据库服务器存储的所述多个子数据表发送各自对应的第二数值查询指令,并接收多个子数据表各自返回的的查询结果,并将所述多个子数据表各自返回的的查询结果进行合并,以获得所述第一数值查询指令的查询结果。通过将第二数值查询指令查询获得的结果进行合并处理,使得第二数值查询指令获得的结果与第一数值查询指令获得的结果相同。

在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。

另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。

所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。

以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1