CN107844488A - 数据查询方法和装置 - Google Patents
数据查询方法和装置 Download PDFInfo
- Publication number
- CN107844488A CN107844488A CN201610830257.9A CN201610830257A CN107844488A CN 107844488 A CN107844488 A CN 107844488A CN 201610830257 A CN201610830257 A CN 201610830257A CN 107844488 A CN107844488 A CN 107844488A
- Authority
- CN
- China
- Prior art keywords
- data
- checked
- storage address
- memory database
- key corresponding
- 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
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2453—Query optimisation
- G06F16/24534—Query rewriting; Transformation
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本申请公开了数据查询方法和装置。所述方法的一具体实施方式包括:拦截客户端发送的数据查询请求,其中,数据查询请求包括待查询数据的存储地址;将待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配;响应于待查询数据的存储地址和目标数据的存储地址的匹配,将与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配;以及响应于与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键的匹配,从内存数据库中获取待查询数据,并将待查询数据发送给客户端。该实施方式减少了对数据库服务器的访问压力。
Description
技术领域
本申请涉及计算机技术领域,具体涉及互联网技术领域,尤其涉及数据查询方法和装置。
背景技术
数据库服务器通常是由运行在局域网中的一台或多台计算机和数据库管理系统软件共同构成,数据库服务器可以为客户应用提供服务,这些服务可以是查询、更新、事务管理、索引、高速缓存、查询优化、安全及多用户存取控制等服务。随着大数据时代的到来,数据库服务器中存储的数据量呈指数级数增长,因此,客户迫切地需要从海量数据中准确地、快速地获取到自己需求的数据。
然而,现有技术中通常需要从数据库服务器获取数据并将数据展现给用户,随着用户访问量的增加,对数据库服务器的访问压力也随之增加。
发明内容
本申请的目的在于提出一种改进的数据查询方法和装置,来解决以上背景技术部分提到的技术问题。
第一方面,本申请提供了一种数据查询方法,所述方法包括:拦截客户端发送的数据查询请求,其中,所述数据查询请求包括待查询数据的存储地址;将所述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配;响应于所述待查询数据的存储地址和所述目标数据的存储地址的匹配,将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的键和所述目标数据;以及响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的匹配,从所述内存数据库中获取所述待查询数据,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述将所述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配,包括:响应于所述待查询数据的存储地址和所述目标数据的存储地址的不匹配,将所述数据查询请求发送给数据库服务器。
在一些实施例中,所述将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,包括:响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的不匹配,从数据库服务器中获取所述待查询数据;将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述预配置文件中还包括目标数据查询请求的类型,所述目标数据查询请求的类型包括查询类型;以及所述将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,包括:对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的参数字段;将所述待查询数据的存储地址的参数字段和所述待查询数据的存储地址的参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的键;获取所述数据查询请求的类型;响应于所述数据查询请求的类型是所述查询类型,将与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键进行匹配。
在一些实施例中,所述从所述内存数据库中获取所述待查询数据,并将所述待查询数据发送给所述客户端,包括:从所述内存数据库中获取所述待查询数据,并确定所述内存数据库中存储的所述待查询数据是否为空;响应于确定所述内存数据库中存储的所述待查询数据不为空,将所述待查询数据发送给所述客户端。
在一些实施例中,所述确定所述内存数据库中存储的所述待查询数据是否为空,包括:响应于确定所述内存数据库中存储的所述待查询数据为空,从数据库服务器中获取所述待查询数据;将所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述目标数据查询请求的类型包括更新类型;以及所述获取所述数据查询请求的类型,包括:响应于所述数据查询请求的类型是所述更新类型,对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的主关键参数字段;将所述待查询数据的存储地址的主关键参数字段和所述待查询数据的存储地址的主关键参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的主键;将与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的主键和与所述目标数据的存储地址对应的键;响应于与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键的匹配,将所述内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除;从数据库服务器中获取所述待查询数据;将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述内存数据库中存储的目标数据具有第一预设存储期限;所述方法还包括:响应于所述第一预设存储期限的到达,删除所述内存数据库中存储的目标数据。
第二方面,本申请提供了一种数据查询装置,所述装置包括:拦截单元,配置用于拦截客户端发送的数据查询请求,其中,所述数据查询请求包括待查询数据的存储地址;第一匹配单元,配置用于将所述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配;第二匹配单元,配置用于响应于所述待查询数据的存储地址和所述目标数据的存储地址的匹配,将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的键和所述目标数据;以及第一发送单元,配置用于响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的匹配,从所述内存数据库中获取所述待查询数据,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述装置还包括:第二发送单元,配置用于响应于所述待查询数据的存储地址和所述目标数据的存储地址的不匹配,将所述数据查询请求发送给数据库服务器。
在一些实施例中,所述装置还包括:获取单元,配置用于响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的不匹配,从数据库服务器中获取所述待查询数据;写入单元,配置用于将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述预配置文件中还包括目标数据查询请求的类型,所述目标数据查询请求的类型包括查询类型;以及所述第二匹配单元,包括:第一解析子单元,配置用于对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的参数字段;第一生成子单元,配置用于将所述待查询数据的存储地址的参数字段和所述待查询数据的存储地址的参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的键;第一获取子单元,配置用于获取所述数据查询请求的类型;第一匹配子单元,配置用于响应于所述数据查询请求的类型是所述查询类型,将与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键进行匹配。
在一些实施例中,所述第一发送单元,包括:确定子单元,配置用于从所述内存数据库中获取所述待查询数据,并确定所述内存数据库中存储的所述待查询数据是否为空;发送子单元,配置用于响应于确定所述内存数据库中存储的所述待查询数据不为空,将所述待查询数据发送给所述客户端。
在一些实施例中,所述第一发送单元,包括:第二获取子单元,配置用于响应于确定所述内存数据库中存储的所述待查询数据为空,从数据库服务器中获取所述待查询数据;第一写入子单元,配置用于将所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述目标数据查询请求的类型包括更新类型;以及所述第二匹配单元,包括:第二解析子单元,配置用于响应于所述数据查询请求的类型是所述更新类型,对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的主关键参数字段;第二生成子单元,配置用于将所述待查询数据的存储地址的主关键参数字段和所述待查询数据的存储地址的主关键参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的主键;第二匹配子单元,配置用于将与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的主键和与所述目标数据的存储地址对应的键;删除子单元,配置用于响应于与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键的匹配,将所述内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除;第三获取子单元,配置用于从数据库服务器中获取所述待查询数据;第二写入子单元,配置用于将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
在一些实施例中,所述内存数据库中存储的目标数据具有第一预设存储期限;所述装置还包括:删除单元,配置用于响应于所述第一预设存储期限的到达,删除所述内存数据库中存储的目标数据。
本申请提供的数据查询方法和装置,通过拦截客户端发送的数据查询请求并将数据查询请求中的待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配,而后基于待查询数据的存储地址和目标数据的存储地址的匹配,将与待查询数据的存储地址对应的键和与内存数据库中存储的与目标数据的存储地址对应的键进行匹配,最后基于与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键的匹配,从内存数据库中获取待查询数据,并将其发送给客户端,从而有效地减少了用户对数据库服务器的访问频率,实现了减少对数据库服务器的访问压力。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显:
图1是本申请可以应用于其中的示例性系统架构图;
图2是根据本申请的数据查询方法的一个实施例的流程图;
图3是根据本申请的数据查询方法的又一个实施例的流程图;
图4是根据本申请的数据查询装置的一个实施例的结构示意图;
图5是适于用来实现本申请实施例的服务器的计算机系统的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的数据查询方法或数据查询装置的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104,服务器105,内存数据库106和数据库服务器107。网络104用以在终端设备101、102、103,服务器105,内存数据库106和数据库服务器107之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105或数据库服务器107交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如网页浏览器应用、搜索类应用、购物类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持数据浏览的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving Picture ExpertsGroup Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving PictureExperts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如,服务器105可以是对终端设备101、102、103查询的数据提供支持的后台数据查询服务器,后台数据查询服务器可以拦截终端设备101、102、103发送的数据查询请求,对拦截到的数据查询请求进行分析等处理,并将处理结果(例如数据)反馈给终端设备;服务器105还可以是将终端设备101、102、103查询到的数据存储到内存数据库106中提供支持的后台数据存储服务器,后台数据存储服务器可以将终端设备101、102、103首次查询的数据存储到内存数据库106中,当再次做同样的查询时,就可以直接从内存数据库106中获取数据并反馈给终端设备。
数据库服务器107可以接收终端设备101、102、103或服务器105发送的数据查询请求,对接收到的数据查询请求进行分析等处理,并将处理结果(例如数据)反馈给终端设备101、102、103或服务器105。
需要说明的是,本申请实施例所提供的数据查询方法一般由服务器105执行,相应地,数据查询装置一般设置于服务器105中。
应该理解,图1中的终端设备、网络、服务器、内存数据库和数据库服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络、服务器、内存数据库和数据库服务器。
继续参考图2,示出了根据本申请的数据查询方法的一个实施例的流程200。所述的数据查询方法,包括以下步骤:
步骤201,拦截客户端发送的数据查询请求。
在本实施例中,数据查询方法运行于其上的电子设备(例如图1所示的服务器105)可以通过设置拦截器来拦截客户端发送的数据查询请求。其中,上述拦截器的作用可以是拦截客户端的数据查询请求并进行相应的处理。上述数据查询请求可以包括待查询数据的存储地址,该存储地址可以是URL(Uniform Resource Locator,统一资源定位符),互联网上的每个数据都对应一个唯一的URL。
步骤202,将待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配。
在本实施例中,基于步骤201中得到的待查询数据的存储地址,上述电子设备(例如图1所示的服务器105)可以将上述待查询数据的存储地址和上述预配置文件中的目标数据的存储地址逐一进行比对,若上述待查询数据的存储地址和上述预配置文件中的一个目标数据的存储地址相同,则匹配,反之,则不匹配。
在本实施例中,上述预配置文件可以预先存储在上述电子设备(例如图1所示的服务器105)中。预配置文件可以是XML(Extensible Markup Language,可扩展标记语言)文件,XML是W3C(World Wide Web Consortium,万维网联盟)标准技术,可移植性较强,各种平台通用。目标数据可以是查询频率较高的数据。作为示例,可以获取最近一天的20:00-21:00时间段内,各个数据的平均查询频率,将平均查询频率大于100HZ的数据定义为目标数据,并将目标数据的存储地址写入预配置文件中。
在本实施例的一些可选的实现方式中,响应于上述待查询数据的存储地址和上述目标数据的存储地址的不匹配,将上述数据查询请求发送给数据库服务器。通常,数据库服务器接收到上述数据查询请求后,基于上述数据查询请求中待查询数据的存储地址,获取待查询数据,并将待查询数据发送给客户端。
步骤203,响应于待查询数据的存储地址和目标数据的存储地址的匹配,将与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配。
在本实施例中,基于步骤202中上述待查询数据的存储地址和上述目标数据的存储地址的匹配的结果,当结果指示匹配时,上述电子设备(例如图1所示的服务器105)可以将与上述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键逐一进行比对,若与上述待查询数据的存储地址对应的键和内存数据库中存储的一个与目标数据的存储地址对应的键相同,则匹配,反之,则不匹配。
在本实施例中,上述内存数据库可以用于以键值对(key:value)的方式存储与目标数据的存储地址对应的键和目标数据。其中,与目标数据的存储地址对应的键可以是目标数据的存储地址,也可以是对目标数据的存储地址进行处理后得到的数据,与目标数据的存储地址对应的键所对应的值可以是目标数据。
在本实施例的一些可选的实现方式中,响应于与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键的不匹配,则可以从数据库服务器中获取上述待查询数据;将与上述待查询数据的存储地址对应的键和上述待查询数据写入上述内存数据库中,并将上述待查询数据发送给上述客户端。可以理解的是,预先将目标数据的存储地址写入预配置文件中,经过客户端的多次查询后,就可以将目标数据尽可能地全部写入内存数据库中,当客户端再次发起相同的数据查询请求时,就可以直接从内存数据库中获取数据,而不必访问数据库服务器。
步骤204,响应于与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键的匹配,从内存数据库中获取待查询数据,并将待查询数据发送给客户端。
在本实施例中,基于步骤203中与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键的匹配的结果,当结果指示匹配时,上述电子设备(例如图1所示的服务器105)可以从上述内存数据库中获取上述待查询数据,并将上述待查询数据发送给客户端。
可以理解的是,若与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键匹配,则内存数据库中存储有与上述待查询数据的存储地址对应的键,内存数据库中存储的与上述待查询数据的存储地址对应的键所对应的值即为待查询数据。
在本实施例的一些可选的实现方式中,上述内存数据库中存储的目标数据可以具有第一预设存储期限;上述方法还可以包括响应于上述第一预设存储期限的到达,删除上述内存数据库中存储的目标数据。作为示例,可以将内存数据库中存储时间超过24小时的目标数据从内存数据库中删除,从而实现了内存数据库中存储的目标数据的定时清理。
本申请的上述实施例提供的方法通过预先将目标数据的存储地址写入预配置文件中,经过客户端的多次查询,实现将目标数据尽可能地全部存储在内存数据库中,当用户查询存储在内存数据库中的目标数据时就可以直接从内存数据库中获取数据,而不必访问数据库服务器,从而有效地减少了用户对数据库服务器的访问频率,实现了减少对数据库服务器的访问压力。
进一步参考图3,其示出了数据查询方法的又一个实施例的流程300。该数据查询方法的流程300,包括以下步骤:
步骤301,拦截客户端发送的数据查询请求。
在本实施例中,数据查询方法运行于其上的电子设备(例如图1所示的服务器105)可以通过设置拦截器来拦截客户端发送的数据查询请求。其中,上述拦截器的作用可以是拦截客户端的数据查询请求并进行相应的处理。上述数据查询请求可以包括待查询数据的存储地址,该存储地址可以是URL(Uniform Resource Locator,统一资源定位符),互联网上的每个数据都对应一个唯一的URL。
步骤302,将待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配。
在本实施例中,基于步骤301中得到的待查询数据的存储地址,上述电子设备(例如图1所示的服务器105)可以将上述待查询数据的存储地址和上述预配置文件中的目标数据的存储地址逐一进行比对,若上述待查询数据的存储地址和上述预配置文件中的一个目标数据的存储地址相同,则匹配,反之,则不匹配。
步骤303,响应于待查询数据的存储地址和目标数据的存储地址的匹配,对待查询数据的存储地址进行解析,获取待查询数据的存储地址的参数字段。
在本实施例中,基于步骤302中上述待查询数据的存储地址和上述目标数据的存储地址的匹配的结果,当结果指示匹配时,上述电子设备(例如图1所示的服务器105)可以对上述待查询数据的存储地址进行解析,并获取上述待查询数据的存储地址的参数字段。其中,上述待查询数据的存储地址的参数字段可以包括但不限于以下至少一项:待查询数据的关键词字段、待查询数据的存储地址字段、待查询数据的辅助参数字段,待查询数据的辅助参数字段可以包括但不限于以下至少一项:待查询数据的字节数、待查询数据的页码信息、待查询数据的创建时间。
需要说明的是,上述对待查询数据的存储地址进行解析的方式可以是语义分析方式,语义分析方式的各种方法是目前广泛研究和应用的公知技术,在此不再赘述。
步骤304,将待查询数据的存储地址的参数字段和待查询数据的存储地址的参数字段的字段值进行加密,生成与待查询数据的存储地址对应的键。
在本实施例中,基于步骤303中得到的上述待查询数据的存储地址的参数字段,上述电子设备(例如图1所示的服务器105)可以将上述待查询数据的存储地址的参数字段及其字段值进行加密,生成与上述待查询数据的存储地址对应的键。
在本实施例中,上述加密算法可以是固定位长算法,固定位长算法是一种压缩算法,这种压缩算法可以把文本用需要的最少的位来进行压缩编码。作为示例,上述电子设备(例如图1所示的服务器105)可以将待查询数据的存储地址的参数字段及其字段值和内存数据库中存储的目标数据的存储地址的参数字段及其字段值均采用固定位长算法进行加密,生成与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键。其中,与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键的位长相等,从而更便于步骤306中与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键的匹配。
步骤305,获取数据查询请求的类型。
在本实施例中,基于步骤302中上述待查询数据的存储地址和上述目标数据的存储地址的匹配的结果,当结果指示匹配时,上述电子设备(例如图1所示的服务器105)可以获取上述数据查询请求的类型。其中,上述预配置文件中还可以包括目标数据查询请求的类型。
在本实施例中,上述电子设备(例如图1所示的服务器105)可以在预配置文件中,对目标数据的存储地址添加注解,用于标明目标数据查询请求的类型。其中,在预配置文件添加的注解可以是AOP(Aspect Oriented Programming,面向切面编程)切面。
可以理解的是,若待查询数据的存储地址和目标数据的存储地址匹配,则预配置文件中存储有待查询数据的存储地址,获取预配置文件中存储的待查询数据的存储地址的注解即获取了上述数据查询请求的类型。
需要说明的是,上述目标数据查询请求的类型可以包括查询类型和更新类型,当上述数据查询请求的类型是查询类型时,执行步骤306,当上述数据查询请求的类型是更新类型时,执行步骤306’。
步骤306,响应于数据查询请求的类型是查询类型,将与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配。
在本实施例中,基于步骤305中获取的上述数据查询请求的类型为查询类型时,上述电子设备(例如图1所示的服务器105)可以将与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键逐一进行比对,若与上述待查询数据的存储地址对应的键和上述内存数据库中存储的一个与目标数据的存储地址对应的键相同,则匹配,反之,则不匹配。
步骤307,响应于与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键的匹配,从内存数据库中获取待查询数据,并确定内存数据库中存储的待查询数据是否为空。
在本实施例中,基于步骤306中与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键的匹配结果,当结果指示匹配时,则确定上述内存数据库中待查询数据是否为空。
在本实施例中,上述内存数据库可以存储空(NULL)键和空(NULL)值,即内存数据库中存储的与目标数据的存储地址对应的键和目标数据都可以为空。若与待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键匹配,则内存数据库中存储有与待查询数据的存储地址对应的键,但是内存数据库中存储的待查询数据可以为空值,因此,需进一步确定内存数据库中存储的待查询数据是否为空值,若不为空值,则执行步骤308;若为空值,则需从数据库服务器获取待查询数据。
在本实施例的一些可选的实现方式中,响应于确定上述内存数据库中存储的上述待查询数据为空,则上述电子设备(例如图1所示的服务器105)可以从数据库服务器中获取上述待查询数据;将上述待查询数据写入上述内存数据库中,并将上述待查询数据发送给上述客户端。可以理解的是,当客户端再次发起相同的数据查询请求时,就可以直接从上述内存数据库中获取数据,而不必访问数据库服务器。
步骤308,响应于确定内存数据库中存储的待查询数据不为空,将待查询数据发送给客户端。
在本实施例中,上述电子设备(例如图1所示的服务器105)确定上述内存数据库中存储的待查询数据不为空,则可以从上述内存数据库中获取上述待查询数据,并将其发送给客户端。
步骤306’,响应于数据查询请求的类型是更新类型,对待查询数据的存储地址进行解析,获取待查询数据的存储地址的主关键参数字段。
在本实施例中,基于步骤305中获取的上述数据查询请求的类型是更新类型时,上述电子设备(例如图1所示的服务器105)可以对上述待查询数据的存储地址进行解析,获取上述待查询数据的存储地址的主关键参数字段。其中,上述待查询数据的存储地址的主关键参数字段可以包括但不限于以下至少一项:待查询数据的关键词字段、待查询数据的存储地址字段。
需要说明的是,上述对待查询数据的存储地址进行解析的方式可以是语义分析方式,语义分析方式的各种方法是目前广泛研究和应用的公知技术,在此不再赘述。
步骤307’,将待查询数据的存储地址的主关键参数字段和待查询数据的存储地址的主关键参数字段的字段值进行加密,生成与待查询数据的存储地址对应的主键。
在本实施例中,基于步骤306’中获取的上述待查询数据的存储地址的主关键参数字段,上述电子设备(例如图1所示的服务器105)可以对待查询数据的存储地址的主关键参数字段及其字段值进行加密,生成与上述待查询数据的存储地址对应的主键。
在本实施例中,上述加密算法可以是固定位长算法。作为示例,上述电子设备(例如图1所示的服务器105)可以将待查询数据的存储地址的主关键参数字段及其字段值和内存数据库中存储的目标数据的存储地址的主关键参数字段及其字段值均采用固定位长算法进行加密,生成与待查询数据的存储地址对应的主键和内存数据库中存储的与目标数据的存储地址对应的主键。其中,与待查询数据的存储地址对应的主键和内存数据库中存储的与目标数据的存储地址对应的键的位长相等,从而更便于步骤308’中与待查询数据的存储地址对应的主键和内存数据库中存储的与目标数据的存储地址对应的主键的匹配。
步骤308’,将与待查询数据的存储地址对应的主键和内存数据库中存储的与目标数据的存储地址对应的主键进行匹配。
在本实施例中,基于步骤307’中获取的与上述待查询数据的存储地址对应的主键,上述电子设备(例如图1所示的服务器105)可以将与上述待查询数据的存储地址对应的主键和上述内存数据库中存储的与目标数据的存储地址对应的主键逐一进行比对,若与上述待查询数据的存储地址对应的主键和上述内存数据库中存储的一个与目标数据的存储地址对应的主键,则匹配,反之,则不匹配。其中,上述内存数据库可以用于以键值对的方式存储与上述目标数据的存储地址对应的主键和与上述目标数据的存储地址对应的键。
可以理解的是,若内存数据库中存储的多个目标数据的存储地址的主关键参数字段相同,则多个目标数据的存储地址对应的主键相同,即与目标数据的存储地址对应的主键所对应的值可以是由多个与目标数据的存储地址对应的键组成的集合。
步骤309’,响应于与待查询数据的存储地址对应的主键和内存数据库中存储的与目标数据的存储地址对应的主键的匹配,将内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除。
在本实施例中,基于步骤308’中与上述待查询数据的存储地址对应的主键和上述内存数据库中存储的与目标数据的存储地址对应的主键的匹配结果,当结果指示匹配成功时,则将上述将内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除。
在本实施例中,上述内存数据库可以用于以键值对的方式存储与目标数据的存储地址对应的主键和与目标数据的存储地址对应的键,因此,若与上述待查询数据的存储地址对应的主键和上述内存数据库中存储的与目标数据的存储地址对应的主键匹配时,可以获取匹配的与目标数据的存储地址对应的主键对应的值,即匹配的与目标数据的存储地址对应的键;上述内存数据库还可以用于以键值对的方式存储与目标数据的存储地址对应的键和目标数据,因此,基于匹配的与目标数据的存储地址对应的键,还可以进一步获取匹配的与目标数据的存储地址对应的键所对应的值即匹配的目标数据;然后将匹配的与目标数据的存储地址对应的键和目标数据从内存数据库中删除即可。同时还可以将上述预配置文件中上述数据查询请求的类型修改为查询类型。
步骤310’,从数据库服务器中获取待查询数据。
在本实施例中,基于步骤309’中将上述内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除后,上述电子设备(例如图1所示的服务器105)可以从上述数据库服务器中获取上述待查询数据。
步骤311’,将与待查询数据的存储地址对应的键和待查询数据写入内存数据库中,并将待查询数据发送给客户端。
在本实施例中,基于步骤310’中从数据库服务器中获取的上述待查询数据,上述电子设备(例如图1所示的服务器105)可以将与上述待查询数据的存储地址对应的键和上述待查询数据写入上述内存数据库中,并将上述待查询数据发送给客户端。从而实现了当待查询数据在数据库服务器中更新后,上述内存数据中存储的相应数据可以及时更新,以确保用户从内存数据库中获取的数据的准确性。
从图3中可以看出,与图2对应的实施例相比,本实施例中的数据查询方法的流程300突出了对上述内存数据库中存储的目标数据进行查询和更新的步骤。由此,本实施例描述的方案中内存数据库中存储的与目标数据的存储地址对应得键是加密后的字符串,更便于查询匹配,以及当数据库服务器中存储的目标数据更新后,内存数据库中存储的相应的数据也可以及时更新,以确保用户从内存数据库中获取的数据的准确性。
进一步参考图4,作为对上述各图所示方法的实现,本申请提供了一种数据查询装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图4所示,本实施例所述的数据查询装置400包括:拦截单元401、第一匹配单元402、第二匹配单元403和第一发送单元404。其中,拦截单元401,配置用于拦截客户端发送的数据查询请求,其中,上述数据查询请求包括待查询数据的存储地址;第一匹配单元402,配置用于将上述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配;第二匹配单元403,配置用于响应于上述待查询数据的存储地址和上述目标数据的存储地址的匹配,将与上述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,其中,上述内存数据库用于以键值对的方式存储与上述目标数据的存储地址对应的键和上述目标数据;以及第一发送单元404,配置用于响应于与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键的匹配,从上述内存数据库中获取上述待查询数据,并将上述待查询数据发送给上述客户端。
在本实施例中,数据查询装置400的拦截单元401可以通过设置拦截器来拦截客户端发送的数据查询请求。其中,上述拦截器的作用可以是拦截客户端的数据查询请求并进行相应的处理。上述数据查询请求可以包括待查询数据的存储地址,该存储地址可以是URL(Uniform Resource Locator,统一资源定位符),互联网上的每个数据都对应一个唯一的URL。
在本实施例中,基于拦截单元401得到的待查询数据的存储地址,上述第一匹配单元402可以将上述待查询数据的存储地址和上述预配置文件中的目标数据的存储地址逐一进行比对,若上述待查询数据的存储地址和上述预配置文件中的一个目标数据的存储地址相同,则匹配,反之,则不匹配。
在本实施例中,基于第一匹配单元402输出的结果为匹配时,上述第二匹配单元403可以将与上述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键逐一进行比对,若与上述待查询数据的存储地址对应的键和内存数据库中存储的一个与目标数据的存储地址对应的键相同,则匹配,反之,则不匹配。
在本实施例中,基于第二匹配单元403输出的结果为匹配时,上述第一发送单元404可以从上述内存数据库中获取上述待查询数据,并将上述待查询数据发送给客户端。
在本实施例的一些可选的实现方式中,上述数据查询装置400还包括:第二发送单元,配置用于响应于上述待查询数据的存储地址和上述目标数据的存储地址的不匹配,将上述数据查询请求发送给数据库服务器。
在本实施例的一些可选的实现方式中,上述数据查询装置400还包括:获取单元,配置用于响应于与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键的不匹配,从数据库服务器中获取上述待查询数据;写入单元,配置用于将与上述待查询数据的存储地址对应的键和上述待查询数据写入上述内存数据库中,并将上述待查询数据发送给上述客户端。
在本实施例的一些可选的实现方式中,上述预配置文件中还包括目标数据查询请求的类型,上述目标数据查询请求的类型包括查询类型;以及上述第二匹配单元403,包括:第一解析子单元,配置用于对上述待查询数据的存储地址进行解析,获取上述待查询数据的存储地址的参数字段;第一生成子单元,配置用于将上述待查询数据的存储地址的参数字段和上述待查询数据的存储地址的参数字段的字段值进行加密,生成与上述待查询数据的存储地址对应的键;第一获取子单元,配置用于获取上述数据查询请求的类型;第一匹配子单元,配置用于响应于上述数据查询请求的类型是上述查询类型,将与上述待查询数据的存储地址对应的键和上述内存数据库中存储的与目标数据的存储地址对应的键进行匹配。
在本实施例的一些可选的实现方式中,上述第一发送单元404,包括:确定子单元,配置用于从上述内存数据库中获取上述待查询数据,并确定上述内存数据库中存储的上述待查询数据是否为空;发送子单元,配置用于响应于确定上述内存数据库中存储的上述待查询数据不为空,将上述待查询数据发送给上述客户端。
在本实施例的一些可选的实现方式中,上述第一发送单元404,包括:第二获取子单元,配置用于响应于确定上述内存数据库中存储的上述待查询数据为空,从数据库服务器中获取上述待查询数据;第一写入子单元,配置用于将上述待查询数据写入上述内存数据库中,并将上述待查询数据发送给上述客户端。
在本实施例的一些可选的实现方式中,上述目标数据查询请求的类型包括更新类型;以及上述第二匹配单元403,包括:第二解析子单元,配置用于响应于上述数据查询请求的类型是上述更新类型,对上述待查询数据的存储地址进行解析,获取上述待查询数据的存储地址的主关键参数字段;第二生成子单元,配置用于将上述待查询数据的存储地址的主关键参数字段和上述待查询数据的存储地址的主关键参数字段的字段值进行加密,生成与上述待查询数据的存储地址对应的主键;第二匹配子单元,配置用于将与上述待查询数据的存储地址对应的主键和上述内存数据库中存储的与目标数据的存储地址对应的主键进行匹配,其中,上述内存数据库用于以键值对的方式存储与上述目标数据的存储地址对应的主键和与上述目标数据的存储地址对应的键;删除子单元,配置用于响应于与上述待查询数据的存储地址对应的主键和上述内存数据库中存储的与目标数据的存储地址对应的主键的匹配,将上述内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除;第三获取子单元,配置用于从数据库服务器中获取上述待查询数据;第二写入子单元,配置用于将与上述待查询数据的存储地址对应的键和上述待查询数据写入上述内存数据库中,并将上述待查询数据发送给上述客户端。
在本实施例的一些可选的实现方式中,上述内存数据库中存储的目标数据具有第一预设存储期限;上述数据查询装置400还包括:删除单元,配置用于响应于上述第一预设存储期限的到达,删除上述内存数据库中存储的目标数据。
下面参考图5,其示出了适于用来实现本申请实施例的服务器的计算机系统500的结构示意图。
如图5所示,计算机系统500包括中央处理单元(CPU)501,其可以根据存储在只读存储器(ROM)502中的程序或者从存储部分508加载到随机访问存储器(RAM)503中的程序而执行各种适当的动作和处理。在RAM 503中,还存储有系统500操作所需的各种程序和数据。CPU 501、ROM 502以及RAM 503通过总线504彼此相连。输入/输出(I/O)接口505也连接至总线504。
以下部件连接至I/O接口505:包括键盘、鼠标等的输入部分506;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分507;包括硬盘等的存储部分508;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分509。通信部分509经由诸如因特网的网络执行通信处理。驱动器510也根据需要连接至I/O接口505。可拆卸介质511,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器510上,以便于从其上读出的计算机程序根据需要被安装入存储部分508。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括有形地包含在机器可读介质上的计算机程序,所述计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分509从网络上被下载和安装,和/或从可拆卸介质511被安装。在该计算机程序被中央处理单元(CPU)501执行时,执行本申请的方法中限定的上述功能。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,所述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本申请实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括拦截单元、第一匹配单元、第二匹配单元和第一发送单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,拦截单元还可以被描述为“拦截客户端发送的数据查询请求的单元”。
作为另一方面,本申请还提供了一种非易失性计算机存储介质,该非易失性计算机存储介质可以是上述实施例中所述装置中所包含的非易失性计算机存储介质;也可以是单独存在,未装配入终端中的非易失性计算机存储介质。上述非易失性计算机存储介质存储有一个或者多个程序,当所述一个或者多个程序被一个设备执行时,使得所述设备:拦截客户端发送的数据查询请求,其中,所述数据查询请求包括待查询数据的存储地址;将所述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配;响应于所述待查询数据的存储地址和所述目标数据的存储地址的匹配,将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的键和所述目标数据;以及响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的匹配,从所述内存数据库中获取所述待查询数据,并将所述待查询数据发送给所述客户端。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离所述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
Claims (16)
1.一种数据查询方法,其特征在于,所述方法包括:
拦截客户端发送的数据查询请求,其中,所述数据查询请求包括待查询数据的存储地址;
将所述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配;
响应于所述待查询数据的存储地址和所述目标数据的存储地址的匹配,将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的键和所述目标数据;以及
响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的匹配,从所述内存数据库中获取所述待查询数据,并将所述待查询数据发送给所述客户端。
2.根据权利要求1所述的数据查询方法,其特征在于,所述将所述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配,包括:
响应于所述待查询数据的存储地址和所述目标数据的存储地址的不匹配,将所述数据查询请求发送给数据库服务器。
3.根据权利要求1所述的数据查询方法,其特征在于,所述将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,包括:
响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的不匹配,从数据库服务器中获取所述待查询数据;
将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
4.根据权利要求1所述的数据查询方法,其特征在于,所述预配置文件中还包括目标数据查询请求的类型,所述目标数据查询请求的类型包括查询类型;以及所述将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,包括:
对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的参数字段;
将所述待查询数据的存储地址的参数字段和所述待查询数据的存储地址的参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的键;
获取所述数据查询请求的类型;
响应于所述数据查询请求的类型是所述查询类型,将与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键进行匹配。
5.根据权利要求4所述的数据查询方法,其特征在于,所述从所述内存数据库中获取所述待查询数据,并将所述待查询数据发送给所述客户端,包括:
从所述内存数据库中获取所述待查询数据,并确定所述内存数据库中存储的所述待查询数据是否为空;
响应于确定所述内存数据库中存储的所述待查询数据不为空,将所述待查询数据发送给所述客户端。
6.根据权利要求5所述的数据查询方法,其特征在于,所述确定所述内存数据库中存储的所述待查询数据是否为空,包括:
响应于确定所述内存数据库中存储的所述待查询数据为空,从数据库服务器中获取所述待查询数据;
将所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
7.根据权利要求4所述的数据查询方法,其特征在于,所述目标数据查询请求的类型包括更新类型;以及所述获取所述数据查询请求的类型,包括:
响应于所述数据查询请求的类型是所述更新类型,对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的主关键参数字段;
将所述待查询数据的存储地址的主关键参数字段和所述待查询数据的存储地址的主关键参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的主键;
将与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的主键和与所述目标数据的存储地址对应的键;
响应于与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键的匹配,将所述内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除;
从数据库服务器中获取所述待查询数据;
将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
8.根据权利要求1-7之一所述的数据查询方法,其特征在于,所述内存数据库中存储的目标数据具有第一预设存储期限;所述方法还包括:
响应于所述第一预设存储期限的到达,删除所述内存数据库中存储的目标数据。
9.一种数据查询装置,其特征在于,所述装置包括:
拦截单元,配置用于拦截客户端发送的数据查询请求,其中,所述数据查询请求包括待查询数据的存储地址;
第一匹配单元,配置用于将所述待查询数据的存储地址和预配置文件中的目标数据的存储地址进行匹配;
第二匹配单元,配置用于响应于所述待查询数据的存储地址和所述目标数据的存储地址的匹配,将与所述待查询数据的存储地址对应的键和内存数据库中存储的与目标数据的存储地址对应的键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的键和所述目标数据;以及
第一发送单元,配置用于响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的匹配,从所述内存数据库中获取所述待查询数据,并将所述待查询数据发送给所述客户端。
10.根据权利要求9所述的数据查询装置,其特征在于,所述装置还包括:
第二发送单元,配置用于响应于所述待查询数据的存储地址和所述目标数据的存储地址的不匹配,将所述数据查询请求发送给数据库服务器。
11.根据权利要求9所述的数据查询装置,其特征在于,所述装置还包括:
获取单元,配置用于响应于与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键的不匹配,从数据库服务器中获取所述待查询数据;
写入单元,配置用于将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
12.根据权利要求9所述的数据查询装置,其特征在于,所述预配置文件中还包括目标数据查询请求的类型,所述目标数据查询请求的类型包括查询类型;以及所述第二匹配单元,包括:
第一解析子单元,配置用于对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的参数字段;
第一生成子单元,配置用于将所述待查询数据的存储地址的参数字段和所述待查询数据的存储地址的参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的键;
第一获取子单元,配置用于获取所述数据查询请求的类型;
第一匹配子单元,配置用于响应于所述数据查询请求的类型是所述查询类型,将与所述待查询数据的存储地址对应的键和所述内存数据库中存储的与目标数据的存储地址对应的键进行匹配。
13.根据权利要求12所述的数据查询装置,其特征在于,所述第一发送单元,包括:
确定子单元,配置用于从所述内存数据库中获取所述待查询数据,并确定所述内存数据库中存储的所述待查询数据是否为空;
发送子单元,配置用于响应于确定所述内存数据库中存储的所述待查询数据不为空,将所述待查询数据发送给所述客户端。
14.根据权利要求13所述的数据查询装置,其特征在于,所述第一发送单元,包括:
第二获取子单元,配置用于响应于确定所述内存数据库中存储的所述待查询数据为空,从数据库服务器中获取所述待查询数据;
第一写入子单元,配置用于将所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
15.根据权利要求12所述的数据查询方法,其特征在于,所述目标数据查询请求的类型包括更新类型;以及所述第二匹配单元,包括:
第二解析子单元,配置用于响应于所述数据查询请求的类型是所述更新类型,对所述待查询数据的存储地址进行解析,获取所述待查询数据的存储地址的主关键参数字段;
第二生成子单元,配置用于将所述待查询数据的存储地址的主关键参数字段和所述待查询数据的存储地址的主关键参数字段的字段值进行加密,生成与所述待查询数据的存储地址对应的主键;
第二匹配子单元,配置用于将与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键进行匹配,其中,所述内存数据库用于以键值对的方式存储与所述目标数据的存储地址对应的主键和与所述目标数据的存储地址对应的键;
删除子单元,配置用于响应于与所述待查询数据的存储地址对应的主键和所述内存数据库中存储的与目标数据的存储地址对应的主键的匹配,将所述内存数据库中匹配的与目标数据的存储地址对应的键和目标数据删除;
第三获取子单元,配置用于从数据库服务器中获取所述待查询数据;
第二写入子单元,配置用于将与所述待查询数据的存储地址对应的键和所述待查询数据写入所述内存数据库中,并将所述待查询数据发送给所述客户端。
16.根据权利要求9-15之一所述的数据查询装置,其特征在于,所述内存数据库中存储的目标数据具有第一预设存储期限;所述装置还包括:
删除单元,配置用于响应于所述第一预设存储期限的到达,删除所述内存数据库中存储的目标数据。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610830257.9A CN107844488B (zh) | 2016-09-18 | 2016-09-18 | 数据查询方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610830257.9A CN107844488B (zh) | 2016-09-18 | 2016-09-18 | 数据查询方法和装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107844488A true CN107844488A (zh) | 2018-03-27 |
CN107844488B CN107844488B (zh) | 2022-02-01 |
Family
ID=61656937
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610830257.9A Active CN107844488B (zh) | 2016-09-18 | 2016-09-18 | 数据查询方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107844488B (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108614871A (zh) * | 2018-04-19 | 2018-10-02 | 中国银行股份有限公司 | 数据查询与结果生成方法、装置、设备及存储介质 |
CN109635028A (zh) * | 2018-12-05 | 2019-04-16 | 拉扎斯网络科技(上海)有限公司 | 数据查询方法及装置、服务器及计算机可读存储介质 |
CN109800237A (zh) * | 2019-01-28 | 2019-05-24 | 广州酷狗计算机科技有限公司 | 数据查询方法、装置和计算机可读存储介质 |
CN110032576A (zh) * | 2019-03-12 | 2019-07-19 | 平安科技(深圳)有限公司 | 一种业务处理方法以及装置 |
CN110888939A (zh) * | 2018-09-06 | 2020-03-17 | 北京京东尚科信息技术有限公司 | 一种数据管理方法和装置 |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2008066249A1 (en) * | 2006-12-01 | 2008-06-05 | Netpia.Com, Inc. | System and method of processing keyword and storage medium of storing program executing the same |
US20090049013A1 (en) * | 2007-08-13 | 2009-02-19 | Oracle International Corporation | Enhanced control to users to populate a cache in a database system |
CN101668004A (zh) * | 2008-09-04 | 2010-03-10 | 阿里巴巴集团控股有限公司 | 一种网页获取方法、装置及系统 |
US20110314027A1 (en) * | 2008-11-03 | 2011-12-22 | China Mobile Communications Corporation | Index building, querying method, device, and system for distributed columnar database |
CN103248684A (zh) * | 2013-04-28 | 2013-08-14 | 北京奇虎科技有限公司 | 一种互联网中资源获取方法和装置 |
CN103853727A (zh) * | 2012-11-29 | 2014-06-11 | 深圳中兴力维技术有限公司 | 提高大数据量查询性能的方法及系统 |
CN104035993A (zh) * | 2014-06-10 | 2014-09-10 | 江苏凤凰优阅信息科技有限公司 | 电子书的存储检索方法、电子书管理系统、阅读系统 |
CN105024906A (zh) * | 2014-04-21 | 2015-11-04 | 腾讯科技(深圳)有限公司 | 社交网络中的群消息存储、查询方法和系统 |
US20160021114A1 (en) * | 2014-07-17 | 2016-01-21 | Alibaba Group Holding Limited | Method and Server of Remote Information Query |
CN105430438A (zh) * | 2015-11-16 | 2016-03-23 | Tcl集团股份有限公司 | 一种智能电视主题商店服务器端的配置方法及系统 |
-
2016
- 2016-09-18 CN CN201610830257.9A patent/CN107844488B/zh active Active
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2008066249A1 (en) * | 2006-12-01 | 2008-06-05 | Netpia.Com, Inc. | System and method of processing keyword and storage medium of storing program executing the same |
US20090049013A1 (en) * | 2007-08-13 | 2009-02-19 | Oracle International Corporation | Enhanced control to users to populate a cache in a database system |
CN101668004A (zh) * | 2008-09-04 | 2010-03-10 | 阿里巴巴集团控股有限公司 | 一种网页获取方法、装置及系统 |
US20110314027A1 (en) * | 2008-11-03 | 2011-12-22 | China Mobile Communications Corporation | Index building, querying method, device, and system for distributed columnar database |
CN103853727A (zh) * | 2012-11-29 | 2014-06-11 | 深圳中兴力维技术有限公司 | 提高大数据量查询性能的方法及系统 |
CN103248684A (zh) * | 2013-04-28 | 2013-08-14 | 北京奇虎科技有限公司 | 一种互联网中资源获取方法和装置 |
CN105024906A (zh) * | 2014-04-21 | 2015-11-04 | 腾讯科技(深圳)有限公司 | 社交网络中的群消息存储、查询方法和系统 |
CN104035993A (zh) * | 2014-06-10 | 2014-09-10 | 江苏凤凰优阅信息科技有限公司 | 电子书的存储检索方法、电子书管理系统、阅读系统 |
US20160021114A1 (en) * | 2014-07-17 | 2016-01-21 | Alibaba Group Holding Limited | Method and Server of Remote Information Query |
CN105430438A (zh) * | 2015-11-16 | 2016-03-23 | Tcl集团股份有限公司 | 一种智能电视主题商店服务器端的配置方法及系统 |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108614871A (zh) * | 2018-04-19 | 2018-10-02 | 中国银行股份有限公司 | 数据查询与结果生成方法、装置、设备及存储介质 |
CN108614871B (zh) * | 2018-04-19 | 2022-07-05 | 中国银行股份有限公司 | 数据查询与结果生成方法、装置、设备及存储介质 |
CN110888939A (zh) * | 2018-09-06 | 2020-03-17 | 北京京东尚科信息技术有限公司 | 一种数据管理方法和装置 |
CN109635028A (zh) * | 2018-12-05 | 2019-04-16 | 拉扎斯网络科技(上海)有限公司 | 数据查询方法及装置、服务器及计算机可读存储介质 |
CN109800237A (zh) * | 2019-01-28 | 2019-05-24 | 广州酷狗计算机科技有限公司 | 数据查询方法、装置和计算机可读存储介质 |
CN110032576A (zh) * | 2019-03-12 | 2019-07-19 | 平安科技(深圳)有限公司 | 一种业务处理方法以及装置 |
CN110032576B (zh) * | 2019-03-12 | 2023-06-16 | 平安科技(深圳)有限公司 | 一种业务处理方法以及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN107844488B (zh) | 2022-02-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107844488A (zh) | 数据查询方法和装置 | |
US10489369B2 (en) | Providing a content preview | |
US20110136542A1 (en) | Method and apparatus for suggesting information resources based on context and preferences | |
CN107943594A (zh) | 数据获取方法和装置 | |
CN108846753B (zh) | 用于处理数据的方法和装置 | |
CN105472045A (zh) | 数据库迁移的方法和装置 | |
CN105488205B (zh) | 页面生成方法和装置 | |
CN107368493A (zh) | 数据库查询方法和装置 | |
CN109657174A (zh) | 用于更新数据的方法和装置 | |
CN110019552A (zh) | 用户关注状态更新的方法和装置 | |
CN107169077A (zh) | 用于推送信息的方法和装置 | |
CN110019263A (zh) | 信息存储方法和装置 | |
CN107391277A (zh) | 信息处理方法和装置 | |
CN110297995A (zh) | 用于收藏信息的方法和装置 | |
CN109885593A (zh) | 用于处理信息的方法和装置 | |
US7979470B2 (en) | Data manipulation process method and system | |
CN106201010B (zh) | 词库添加方法和装置 | |
CN107918617A (zh) | 数据查询方法和装置 | |
CN108932640A (zh) | 用于处理订单的方法和装置 | |
CN1472911A (zh) | 无线设备同步系统及方法 | |
CN107291923A (zh) | 信息处理方法和装置 | |
US20190286671A1 (en) | Algorithmic computation of entity information from ip address | |
CN112100168A (zh) | 一种确定数据关联关系的方法和装置 | |
CN109815433A (zh) | 浏览器本地存储方法及装置、存储介质及电子设备 | |
US20210173729A1 (en) | Systems and methods of application program interface (api) parameter monitoring |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |