CN111625536A - 一种数据访问方法及装置 - Google Patents
一种数据访问方法及装置 Download PDFInfo
- Publication number
- CN111625536A CN111625536A CN202010328936.2A CN202010328936A CN111625536A CN 111625536 A CN111625536 A CN 111625536A CN 202010328936 A CN202010328936 A CN 202010328936A CN 111625536 A CN111625536 A CN 111625536A
- Authority
- CN
- China
- Prior art keywords
- data
- preset
- cached
- cache space
- data set
- 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
Images
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/22—Indexing; Data structures therefor; Storage structures
-
- 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/2455—Query execution
- G06F16/24552—Database cache management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Computational Linguistics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本申请示出了一种数据访问方法及装置。在检测到用户是按照位置顺序从前之后连续访问预设数据集合中的多个位置顺序连续的数据时,客户端就可以在客户端的缓存空间中缓存预设数据集合中的、位置顺序位于当前正在访问的数据的位置顺序之后且与距离当前正在访问的数据的位置顺序最近的一个或多个待访问数据,用户之后在按照上述规律访问预设数据集合中的数据时,客户端可以直接从客户端中的缓存空间中获取缓存的预设数据集合中的数据,如此,用户短时间内就可以访问到待访问数据。通过本申请,可以提高用户之后按照上述规律访问预设数据集合中的数据的访问效率。
Description
技术领域
本申请涉及计算机技术领域,特别是涉及一种数据访问方法及装置。
背景技术
在互联网的数据访问中,客户端可以访问服务端中的数据,客户端在访问服务端的数据的过程中,需要借助客户端与服务端之间的网络进行数据交互,然而,客户端与服务端之间的网络有时候不稳定,且延迟较高,导致客户端访问服务端的数据的访问效率较低。
为了降低客户端访问服务端中的数据的访问延迟,以提高访问效率,可以事先将服务端中的数据预存在客户端中,当客户端需要访问服务端中的数据时,客户端可以在本地查找预存的数据,并向用户响应查找到的数据。
然而,如果将服务端中的所有数据预存在客户端中,则会耗费客户端中非常大的存储空间,如果将服务端中的部分数据预存在客户端中,则预存的部分数据可能并不是用户需要访问的数据,则仍旧无法解决访问效率低的问题。
发明内容
为解决上述技术问题,本申请示出了一种数据访问方法及装置。
第一方面,本申请示出了一种数据访问方法,所述方法包括:
接收用户提交的携带第一标识的数据访问请求;
在缓存空间中查找所述第一标识所对应的第一数据;
在查找到所述第一数据的情况下,以所述第一数据响应所述数据访问请求;以及,
确定所述第一数据在预设数据集合中的第一位置顺序是否位于第二数据在所述预设数据集合中的第二位置顺序之后且与所述第二位置顺序相邻,所述第二数据包括所述用户最近一次访问的所述预设数据集合中的数据;
在所述第一位置顺序位于所述第二位置顺序之后且与所述第二位置顺序相邻的情况下,在所述缓存空间中缓存所述预设数据集合中的第三数据;所述第三数据包括所述预设数据集合中的除在所述缓存空间中的已缓存数据以外的数据,且所述第三数据在所述预设数据集合中的第三位置顺序位于所述缓存空间中的已缓存数据的位置顺序之后且距离所述已缓存数据的位置顺序最近。
在一个可选的实现方式中,所述在所述缓存空间中缓存所述预设数据集合中的第三数据,包括:
确定在所述缓存空间中为所述用户缓存所述预设数据集合中的数据的已缓存次数;
根据所述已缓存次数确定缓存所述第三数据的待缓存数量;
在所述缓存空间中缓存所述预设数据集合中的所述待缓存数量个第三数据。
在一个可选的实现方式中,所述方法还包括:
在未查找到所述第一数据的情况下,从所述预设数据集合中获取所述第一数据所对应的第一数据;
以所述第一数据响应所述数据访问请求;以及,
在所述缓存空间中缓存所述预设数据集合中的所述第三数据。
在一个可选的实现方式中,所述方法还包括:
确定所述缓存空间中的所述已缓存数据的数据量是否大于预设数据量;
在所述已缓存数据的数据量大于预设数据量的情况下,在所述缓存空间中的已缓存数据中按照位置顺序删除至少一个被所述用户访问过的数据,以使所述缓存空间中剩余的已缓存数据的数据量小于预设数据量。
在一个可选的实现方式中,所述方法还包括:
在所述缓存空间中缓存的所述预设数据集合中的数据未被访问的持续时长达到预设时长的情况下,删除所述缓存空间中缓存的所述预设数据集合中的数据。
第二方面,本申请示出了一种数据访问装置,所述装置包括:
接收模块,用于接收用户提交的携带第一标识的数据访问请求;
查找模块,用于在缓存空间中查找所述第一标识所对应的第一数据;
第一响应模块,用于在查找到所述第一数据的情况下,以所述第一数据响应所述数据访问请求;以及,
第一确定模块,用于确定所述第一数据在预设数据集合中的第一位置顺序是否位于第二数据在所述预设数据集合中的第二位置顺序之后且与所述第二位置顺序相邻,所述第二数据包括所述用户最近一次访问的所述预设数据集合中的数据;
第一缓存模块,用于在所述第一位置顺序位于所述第二位置顺序之后且与所述第二位置顺序相邻的情况下,在所述缓存空间中缓存所述预设数据集合中的第三数据;所述第三数据包括所述预设数据集合中的除在所述缓存空间中的已缓存数据以外的数据,且所述第三数据在所述预设数据集合中的第三位置顺序位于所述缓存空间中的已缓存数据的位置顺序之后且距离所述已缓存数据的位置顺序最近。
在一个可选的实现方式中,所述第一缓存模块包括:
第一确定单元,用于确定在所述缓存空间中为所述用户缓存所述预设数据集合中的数据的已缓存次数;
第二确定单元,用于根据所述已缓存次数确定缓存所述第三数据的待缓存数量;
缓存单元,用于在所述缓存空间中缓存所述预设数据集合中的所述待缓存数量个第三数据。
在一个可选的实现方式中,所述装置还包括:
获取模块,用于在未查找到所述第一数据的情况下,从所述预设数据集合中获取所述第一数据所对应的第一数据;
第二响应模块,用于以所述第一数据响应所述数据访问请求;以及,
第二缓存模块,用于在所述缓存空间中缓存所述预设数据集合中的所述第三数据。
在一个可选的实现方式中,所述装置还包括:
第二确定模块,用于确定所述缓存空间中的所述已缓存数据的数据量是否大于预设数据量;
第一删除模块,用于在所述已缓存数据的数据量大于预设数据量的情况下,在所述缓存空间中的已缓存数据中按照位置顺序删除至少一个被所述用户访问过的数据,以使所述缓存空间中剩余的已缓存数据的数据量小于预设数据量。
在一个可选的实现方式中,所述装置还包括:
第二删除模块,用于在所述缓存空间中缓存的所述预设数据集合中的数据未被访问的持续时长达到预设时长的情况下,删除所述缓存空间中缓存的所述预设数据集合中的数据。
第三方面,本申请示出了一种电子设备,所述电子设备包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行如第一方面所述的数据访问方法。
第四方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据访问方法。
第五方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据访问方法。
本申请提供的技术方案可以包括以下有益效果:
在本申请中,在检测到用户是按照位置顺序从前之后连续访问预设数据集合中的多个位置顺序连续的数据时,客户端就可以在客户端的缓存空间中缓存预设数据集合中的、位置顺序位于当前正在访问的数据的位置顺序之后且与距离当前正在访问的数据的位置顺序最近的一个或多个待访问数据,用户之后在按照上述规律访问预设数据集合中的数据时,客户端可以直接从客户端中的缓存空间中获取缓存的预设数据集合中的数据,如此,用户短时间内就可以访问到待访问数据。通过本申请,使得用户之后在访问待访问数据时,客户端可以直接从客户端的缓存空间中获取到待访问数据并向用户响应,而不需要从服务端的预设数据集合中获取待访问数据再向用户响应,由于客户端从客户端的缓存空间中获取数据的效率高于客户端基于与服务端之间的网络连接从服务端获取数据的效率,因此,本申请可以提高用户之后按照上述规律访问预设数据集合中的数据的访问效率。
其次,本申请也不需要将服务端的预设数据集合中的所有数据均缓存在客户端的缓存空间中,因此,可以节省客户端的存储空间。
附图说明
图1是本申请的一种数据访问方法的步骤流程图;
图2是本申请的一种数据访问装置的结构框图;
图3是本申请示出的一种电子设备的框图;
图4是本申请示出的一种电子设备的框图。
具体实施方式
为使本申请的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本申请作进一步详细的说明。
参照图1,示出了本申请的一种数据访问方法的步骤流程图,该方法可以应用于客户端,该方法具体可以包括如下步骤:
在步骤S101中,接收用户提交的携带第一标识的数据访问请求;
在本申请中,在用户使用客户端的过程中,如果需要访问预设数据集合中的第一数据,则用户可以向客户端提交携带第一数据的第一标识的数据访问请求,客户端接收用户提交的携带第一标识的数据访问请求,然后执行步骤S102。其中,预设数据集合中包括至少一个数据。
在步骤S102中,在缓存空间中查找第一标识所对应的第一数据;
在本申请中,预设数据集合位于服务端,客户端从服务端获取数据的过程需要借助客户端与服务端之间的网络连接,由于网络连接的带宽问题以及稳定性问题,会造成数据传输延时,因此,客户端从服务端的预设数据集合中获取数据的效率往往低于客户端直接从客户端的缓存空间中获取数据的效率。
所以,在本申请中,客户端在客户端的缓存空间中获取用户需要访问数据,可以提高获取数据的效率。
因此,为了提高获取第一数据的效率,以提高响应用户的该数据访问请求的效率,在本申请中,客户端可以在缓存空间中查找第一标识所对应的第一数据,其中,在缓存空间中查找到第一数据的情况下,可以执行步骤S103。
在本申请中,每当在客户端的缓存空间中缓存一个数据时,客户端就会获取该数据的标识,然后将该标识与该数据组成对应表项,并存储在缓存空间中存储的、标识与数据之间的对应关系中。
因此,在本步骤中,可以在缓存空间中存储的、标识与数据之间的对应关系中,查找与第一标识相对应的第一数据。
在查找到第一数据的情况下,在步骤S103中,以第一数据响应数据访问请求;
在本申请一个实施例中,如果用户是需要查看第一标识所对应的第一数据,则客户端在以第一数据响应该数据访问请求时,可以显示第一数据等。
在本申请另一个实施例中,如果用户是需要在客户端上直接应用第一标识所对应的第一数据,则客户端在以第一数据响应该数据访问请求时,可以直接应用第一数据等。
在步骤S104中,确定第一数据在预设数据集合中的第一位置顺序是否位于第二数据在预设数据集合中的第二位置顺序之后且与第二位置顺序相邻;
其中,第二数据包括用户最近一次访问的预设数据集合中的数据。
在本申请中,预设数据集合中的每一个数据在预设数据集合中都具有各自的位置顺序,且不同的数据在预设数据集合中的位置顺序不同。
用户在访问预设数据集合中的数据时,用户往往是连续地访问预设数据集合中的多个数据,如果用户是连续地访问预设数据集合中的多个数据,则用户可以按照位置顺序从前至后连续访问预设数据集合中的多个位置顺序连续的数据,用户也可以连续地随机访问预设数据集合中的多个数据。
如果用户是按照位置顺序从前之后连续访问预设数据集合中的多个位置顺序连续的数据,则用户连续访问预设数据集合中的数据的行为是规律的。
如此,在用户访问预设数据集合中的数据时,可以基于这个规律预估用户之后可能需要访问的预设数据集合中的待访问数据,然后将用户之后可能需要访问的预设数据集合中的待访问数据缓存在客户端的缓存空间中,以使用户之后在访问需要访问的待访问数据时,客户端可以直接从客户端的缓存空间中获取到用户需要访问的待访问数据并向用户响应,而不需要从服务端的预设数据集合中获取用户需要访问的待访问数据再向用户响应。
例如,在用户访问了预设数据集合中的位置顺序为第1位的数据1之后,如果用户是按照上述规律继续访问预设数据集合中的数据,则用户下一次会访问预设数据集合中的位置顺序为第2位的数据2,再访问预设数据集合中的位置顺序为第3位的数据3等,以此类推。
因此,在用户访问预设数据集合中的位置顺序为第1位的数据1的情况下,可以预估用户可能会访问预设数据集合中的位置顺序为第2位的数据2以及位置顺序为第3位的数据3等,以此类推,因此,可以提前在客户端的缓存空间中预缓存预设数据集合中的位置顺序为第2位的数据2以及位置顺序为第3位的数据3等,以使用户之后在基于上述规律继续访问预设数据集合中的位置顺序为第2位的数据2以及位置顺序为第3位的数据3等时,客户端可以直接从客户端缓存空间中获取到预设数据集合中的位置顺序为第2位的数据2以及位置顺序为第3位的数据3等并向用户响应,而不需要从服务端的预设数据集合中预设数据集合中的位置顺序为第2位的数据2以及位置顺序为第3位的数据3等再向用户响应。
其中,预设数据集合位于服务端,客户端从服务端获取数据的过程需要借助客户端与服务端之间的网络连接,由于网络连接的带宽问题以及稳定性问题,会造成数据传输延时,因此,客户端从服务端的预设数据集合中获取用户需要访问的数据的往往效率低于客户端直接从客户端的缓存空间中获取用户需要访问数据的效率。
所以,本申请从客户端的缓存空间中获取用户需要访问数据,可以提高获取数据的效率。
因此,为了提高用户之后按照上述规律访问预设数据集合中的数据的访问效率,在本申请中,可以先判断用户是否正在按照上述规律访问预设数据集合中的数据,如果用户是正在按照上述规律访问预设数据集合中的数据,则可以在客户端的缓存空间中缓存预设数据集合中的、位置顺序位于第一数据的位置顺序之后且与距离第一数据的位置顺序最近的一个或多个第三数据,以使用户之后在访问第三数据时,客户端可以直接从客户端的缓存空间中获取到第三数据并向用户响应,而不需要从服务端的预设数据集合中获取第三数据再向用户响应。
其中,判断用户是否正在按照上述规律访问预设数据集合中的数据时,可以确定用户当前访问的第一数据在预设数据集合中的第一位置顺序是否位于第二数据在预设数据集合中的第二位置顺序之后且与第二位置顺序相邻,第二数据包括用户最近一次访问的预设数据集合中的数据。
在一个实施例中,如果用户当前访问的第一数据在预设数据集合中的第一位置顺序位于第二数据在预设数据集合中的第二位置顺序之后且与第二位置顺序相邻,则说明用户是正在按照上述规律访问预设数据集合中的数据,也即,用户是按照位置顺序从前之后连续访问预设数据集合中的多个位置顺序连续的数据。
在本实施例中,在预设数据集合中,第二数据的第二位置顺序位于第一数据的第一位置顺序之前,且第二数据的第二位置顺序与第一数据的第一位置顺序相邻,用户最近一次访问的预设数据集合中的数据为第二数据,用户当前访问的数据为第一数据,此时可以说明用户是按照上述规律来访问预设数据集合中的数据的。
在另一个实施例中,如果用户当前访问的第一数据在预设数据集合中的第一位置顺序不位于第二数据在预设数据集合中的第二位置顺序之后或者与第二位置顺序不相邻,则说明用户未正在按照上述规律访问预设数据集合中的数据。也即,用户不是按照位置顺序从前之后连续访问预设数据集合中的多个位置顺序连续的数据。
在第一位置顺序位于第二位置顺序之后且与第二位置顺序相邻的情况下,在步骤S105中,在缓存空间中缓存预设数据集合中的第三数据。
其中,第三数据包括预设数据集合中的除在缓存空间中的已缓存数据以外的数据,且第三数据在预设数据集合中的第三位置顺序位于缓存空间中的已缓存数据的位置顺序之后且距离已缓存数据的位置顺序最近。
第三位置顺序距离已缓存数据的位置顺序最近的含义包括:假设在客户端中的缓存空间中缓存的预设数据集合中的已缓存数据中,位置顺序最大的数据为参考数据。
在第三数据为一个的情况下,第三数据在预设数据集合中的第三位置顺序位于参考数据在预设数据集合中的参考位置顺序之后,且第三数据在预设数据集合中的第三位置顺序与参考数据在预设数据集合中的参考位置顺序相邻。
在第三数据为多个的情况下,多个第三数据分别在预设数据集合中的位置顺序相邻,位置顺序最小的第三数据在预设数据集合中的第三位置顺序位于参考数据在预设数据集合中的参考位置顺序之后,且位置顺序最小的第三数据在预设数据集合中的第三位置顺序与参考数据在预设数据集合中的参考位置顺序相邻。
在用户按照位置顺序从前至后连续访问预设数据集合中的多个位置顺序连续的数据的过程中,每当用户按照上述规律访问到预设数据集合中的一个数据,客户端就可以在缓存空间中缓存预设数据集合中的至少一个用户之后可能会访问到的数据。
在用户按照位置顺序从前至后连续访问预设数据集合中的多个位置顺序连续的数据的数量越多,则说明用户访问预设数据集合中的数据越规律,在用户访问预设数据集合中的数据越规律的情况下,客户端在缓存空间中缓存预设数据集合中的至少一个用户之后可能会访问到的数据的数量可以越多,以支持用户在该规律下,之后可以按照上述规律一次快速地访问到更多的预设数据集合中的数据。
如此,在本步骤中,在缓存空间中缓存预设数据集合中的第三数据时,可以确定在缓存空间中为用户缓存预设数据集合中的数据的已缓存次数;再根据已缓存次数确定缓存第三数据的待缓存数量;例如,将已缓存次数与数值1相加,得到一个新的次数,然后计算新的次数与为用户第一次缓存预设数据集合中的数据的数量之间的乘积,并作为待缓存数量,然后在缓存空间中缓存预设数据集合中的待缓存数量个第三数据。
在本申请中,在检测到用户是按照位置顺序从前之后连续访问预设数据集合中的多个位置顺序连续的数据时,客户端就可以在客户端的缓存空间中缓存预设数据集合中的、位置顺序位于当前正在访问的数据的位置顺序之后且与距离当前正在访问的数据的位置顺序最近的一个或多个待访问数据,用户之后在按照上述规律访问预设数据集合中的数据时,客户端可以直接从客户端中的缓存空间中获取缓存的预设数据集合中的数据,如此,用户短时间内就可以访问到待访问数据。通过本申请,使得用户之后在访问待访问数据时,客户端可以直接从客户端的缓存空间中获取到待访问数据并向用户响应,而不需要从服务端的预设数据集合中获取待访问数据再向用户响应,由于客户端从客户端的缓存空间中获取数据的效率高于客户端基于与服务端之间的网络连接从服务端获取数据的效率,因此,本申请可以提高用户之后按照上述规律访问预设数据集合中的数据的访问效率。
其次,本申请也不需要将服务端的预设数据集合中的所有数据均缓存在客户端的缓存空间中,因此,可以节省客户端的存储空间。
在本申请另一实施例中,在未查找到第一数据的情况下,则说明第一数据并未存户在缓存空间中,为了能够得到第一数据,可以从预设数据集合中获取第一数据所对应的第一数据;例如,向服务器发送该数据访问请求,服务器接收该数据访问请求,然后在服务器中的预设数据集合中查找第一数据标识所对应的第一数,并然后向客户端返回第一数据,客户端接收服务器端返回的第一数据。然后以第一数据响应数据访问请求;以及,可以异步地在缓存空间中缓存预设数据集合中的第三数据,如此可以使得之后用户在需要基于客户端访问第三数据时,可以直接从客户端的缓存空间中获取第三数据,以提高用户之后访问第三数据的访问效率。
在本申请中,如果用户访问过缓存空间中缓存的预设数据集合中的某一数据,则用户之后再次重新访问该数据的可能性较低,且访问该数据的时刻距离当前时刻越远,用户再次重新访问该数据的可能性越低。
其中,缓存空间的一个目的是为了在用户需要访问预设数据集合中的未访问过的数据时,可以直接从缓存空间中访问事先预存的数据,从而提高访问效率,然而,如果缓存空间中存储的数据中被用户已访问过的数据较多,则会导致缓存空间的利用率较低。
因此,为了提高缓存空间的利用率,在本申请另一实施例中,在基于缓存空间中的数据来响应用户的访问请求的过程中,可以定期或者实时确定缓存空间中的已缓存数据的数据量是否大于预设数据量;已缓存数据包括在缓存空间中缓存的预设数据集合中的数据,预设数据量可以小于缓存空间的最大容量,例如,为缓存空间的最大容量的85%、90%以及95%等。
在已缓存数据的数据量大于预设数据量的情况下,在缓存空间中的已缓存数据中按照位置顺序删除至少一个被用户访问过的数据,以使缓存空间中剩余的已缓存数据的数据量小于预设数据量。
其中,在本申请中,预设数据集合中的每一个数据在预设数据集合中都具有各自的位置顺序,且不同的数据在预设数据集合中的位置顺序不同。
如此,在缓存空间中缓存的预设数据集合中的已缓存数据中,每一个已缓存数据都具有各自在预设数据集合中的位置顺序,可以在缓存空间中删除位置顺序为第一位的已缓存数据,如果删除了位置顺序为第一位的已缓存数据之后的缓存空间中的已缓存数据的数据量小于预设数据量,则结束删除流程,如果删除了位置顺序为第一位的已缓存数据之后的缓存空间中的已缓存数据的数据量大于或等于预设数据量,则继续在缓存空间中删除位置顺序为第二位的已缓存数据,如果删除了位置顺序为第二位的已缓存数据之后的缓存空间中的已缓存数据的数据量小于预设数据量,则结束删除流程,如果删除了位置顺序为第二位的已缓存数据之后的缓存空间中的已缓存数据的数据量大于或等于预设数据量,则继续在缓存空间中删除位置顺序为第三位的已缓存数据,直至缓存空间中剩余的已缓存数据的数据量小于预设数据量为止。
在本实施例中,优先删除缓存空间中的用户访问过的位置顺序靠前的数据,实现了优先在缓存空间中删除用户再次重新访问的可能性越低的数据,而优先在缓存空间中保留用户再次重新访问的可能性越高的数据,从而可以提高缓存空间的利用率。
其中,缓存空间的其中一个目的是为了在用户需要访问预设数据集合中的未访问过的数据时,可以直接从缓存空间中的事先预存的数据获取用户需要访问的数据,从而提高访问效率。
然而,在本申请中,用户访问预设数据集合中的数据往往是阶段性的,例如,在一段时间内集中连续访问预设数据集合中的数据。如果用户已经不再需要访问预设数据集合中的数据,则在缓存空间中也就没有必要继续缓存预设数据集合中的数据,否则会浪费缓存空间中的存储资源,从而会导致缓存空间的利用率较低。
因此,为了提高缓存空间的利用率,在本申请另一实施例中,在缓存空间中缓存的预设数据集合中的数据未被访问的持续时长达到预设时长的情况下,可以删除缓存空间中缓存的预设数据集合中的数据。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的动作并不一定是本申请所必须的。
参照图2,示出了本申请的一种数据访问装置的结构框图,该装置具体可以包括如下模块:
接收模块11,用于接收用户提交的携带第一标识的数据访问请求;
查找模块12,用于在缓存空间中查找所述第一标识所对应的第一数据;
第一响应模块13,用于在查找到所述第一数据的情况下,以所述第一数据响应所述数据访问请求;以及,
第一确定模块14,用于确定所述第一数据在预设数据集合中的第一位置顺序是否位于第二数据在所述预设数据集合中的第二位置顺序之后且与所述第二位置顺序相邻,所述第二数据包括所述用户最近一次访问的所述预设数据集合中的数据;
第一缓存模块15,用于在所述第一位置顺序位于所述第二位置顺序之后且与所述第二位置顺序相邻的情况下,在所述缓存空间中缓存所述预设数据集合中的第三数据;所述第三数据包括所述预设数据集合中的除在所述缓存空间中的已缓存数据以外的数据,且所述第三数据在所述预设数据集合中的第三位置顺序位于所述缓存空间中的已缓存数据的位置顺序之后且距离所述已缓存数据的位置顺序最近。
在一个可选的实现方式中,所述第一缓存模块包括:
第一确定单元,用于确定在所述缓存空间中为所述用户缓存所述预设数据集合中的数据的已缓存次数;
第二确定单元,用于根据所述已缓存次数确定缓存所述第三数据的待缓存数量;
缓存单元,用于在所述缓存空间中缓存所述预设数据集合中的所述待缓存数量个第三数据。
在一个可选的实现方式中,所述装置还包括:
获取模块,用于在未查找到所述第一数据的情况下,从所述预设数据集合中获取所述第一数据所对应的第一数据;
第二响应模块,用于以所述第一数据响应所述数据访问请求;以及,
第二缓存模块,用于在所述缓存空间中缓存所述预设数据集合中的所述第三数据。
在一个可选的实现方式中,所述装置还包括:
第二确定模块,用于确定所述缓存空间中的所述已缓存数据的数据量是否大于预设数据量;
第一删除模块,用于在所述已缓存数据的数据量大于预设数据量的情况下,在所述缓存空间中的已缓存数据中按照位置顺序删除至少一个被所述用户访问过的数据,以使所述缓存空间中剩余的已缓存数据的数据量小于预设数据量。
在一个可选的实现方式中,所述装置还包括:
第二删除模块,用于在所述缓存空间中缓存的所述预设数据集合中的数据未被访问的持续时长达到预设时长的情况下,删除所述缓存空间中缓存的所述预设数据集合中的数据。
在本申请中,在检测到用户是按照位置顺序从前之后连续访问预设数据集合中的多个位置顺序连续的数据时,客户端就可以在客户端的缓存空间中缓存预设数据集合中的、位置顺序位于当前正在访问的数据的位置顺序之后且与距离当前正在访问的数据的位置顺序最近的一个或多个待访问数据,用户之后在按照上述规律访问预设数据集合中的数据时,客户端可以直接从客户端中的缓存空间中获取缓存的预设数据集合中的数据,如此,用户短时间内就可以访问到待访问数据。通过本申请,使得用户之后在访问待访问数据时,客户端可以直接从客户端的缓存空间中获取到待访问数据并向用户响应,而不需要从服务端的预设数据集合中获取待访问数据再向用户响应,由于客户端从客户端的缓存空间中获取数据的效率高于客户端基于与服务端之间的网络连接从服务端获取数据的效率,因此,本申请可以提高用户之后按照上述规律访问预设数据集合中的数据的访问效率。
其次,本申请也不需要将服务端的预设数据集合中的所有数据均缓存在客户端的缓存空间中,因此,可以节省客户端的存储空间。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
图3是本申请示出的一种电子设备800的框图。例如,电子设备800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图3,电子设备800可以包括以下一个或多个组件:处理组件802,存储器804,电力组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制电子设备800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在电子设备800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图像,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件806为电子设备800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为电子设备800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述电子设备800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当电子设备800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为电子设备800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为电子设备800的显示器和小键盘,传感器组件814还可以检测电子设备800或电子设备800一个组件的位置改变,用户与电子设备800接触的存在或不存在,电子设备800方位或加速/减速和电子设备800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于电子设备800和其他设备之间有线或无线方式的通信。电子设备800可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播操作信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由电子设备800的处理器820执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
图4是本申请示出的一种电子设备1900的框图。例如,电子设备1900可以被提供为一服务器。
参照图4,电子设备1900包括处理组件1922,其进一步包括一个或多个处理器,以及由存储器1932所代表的存储器资源,用于存储可由处理组件1922的执行的指令,例如应用程序。存储器1932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1922被配置为执行指令,以执行上述方法。
电子设备1900还可以包括一个电源组件1926被配置为执行电子设备1900的电源管理,一个有线或无线网络接口1950被配置为将电子设备1900连接到网络,和一个输入输出(I/O)接口1958。电子设备1900可以操作基于存储在存储器1932的操作系统,例如Windows ServerTM,Mac OS XTM,UnixTM,LinuxTM,FreeBSDTM或类似。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本申请的实施例可提供为方法、装置、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程生成测试用例终端设备的处理器以产生一个机器,使得通过计算机或其他可编程生成测试用例终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程生成测试用例终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程生成测试用例终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本申请的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本申请所提供的一种数据访问方法及装置,进行了详细介绍,本文中应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的一般技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。
Claims (12)
1.一种数据访问方法,其特征在于,所述方法包括:
接收用户提交的携带第一标识的数据访问请求;
在缓存空间中查找所述第一标识所对应的第一数据;
在查找到所述第一数据的情况下,以所述第一数据响应所述数据访问请求;以及,
确定所述第一数据在预设数据集合中的第一位置顺序是否位于第二数据在所述预设数据集合中的第二位置顺序之后且与所述第二位置顺序相邻,所述第二数据包括所述用户最近一次访问的所述预设数据集合中的数据;
在所述第一位置顺序位于所述第二位置顺序之后且与所述第二位置顺序相邻的情况下,在所述缓存空间中缓存所述预设数据集合中的第三数据;所述第三数据包括所述预设数据集合中的除在所述缓存空间中的已缓存数据以外的数据,且所述第三数据在所述预设数据集合中的第三位置顺序位于所述缓存空间中的已缓存数据的位置顺序之后且距离所述已缓存数据的位置顺序最近。
2.根据权利要求1所述的方法,其特征在于,所述在所述缓存空间中缓存所述预设数据集合中的第三数据,包括:
确定在所述缓存空间中为所述用户缓存所述预设数据集合中的数据的已缓存次数;
根据所述已缓存次数确定缓存所述第三数据的待缓存数量;
在所述缓存空间中缓存所述预设数据集合中的所述待缓存数量个第三数据。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
在未查找到所述第一数据的情况下,从所述预设数据集合中获取所述第一数据所对应的第一数据;
以所述第一数据响应所述数据访问请求;以及,
在所述缓存空间中缓存所述预设数据集合中的所述第三数据。
4.根据权利要求1所述的方法,其特征在于,所述方法还包括:
确定所述缓存空间中的所述已缓存数据的数据量是否大于预设数据量;
在所述已缓存数据的数据量大于预设数据量的情况下,在所述缓存空间中的已缓存数据中按照位置顺序删除至少一个被所述用户访问过的数据,以使所述缓存空间中剩余的已缓存数据的数据量小于预设数据量。
5.根据权利要求1所述的方法,其特征在于,所述方法还包括:
在所述缓存空间中缓存的所述预设数据集合中的数据未被访问的持续时长达到预设时长的情况下,删除所述缓存空间中缓存的所述预设数据集合中的数据。
6.一种数据访问装置,其特征在于,所述装置包括:
接收模块,用于接收用户提交的携带第一标识的数据访问请求;
查找模块,用于在缓存空间中查找所述第一标识所对应的第一数据;
第一响应模块,用于在查找到所述第一数据的情况下,以所述第一数据响应所述数据访问请求;以及,
第一确定模块,用于确定所述第一数据在预设数据集合中的第一位置顺序是否位于第二数据在所述预设数据集合中的第二位置顺序之后且与所述第二位置顺序相邻,所述第二数据包括所述用户最近一次访问的所述预设数据集合中的数据;
第一缓存模块,用于在所述第一位置顺序位于所述第二位置顺序之后且与所述第二位置顺序相邻的情况下,在所述缓存空间中缓存所述预设数据集合中的第三数据;所述第三数据包括所述预设数据集合中的除在所述缓存空间中的已缓存数据以外的数据,且所述第三数据在所述预设数据集合中的第三位置顺序位于所述缓存空间中的已缓存数据的位置顺序之后且距离所述已缓存数据的位置顺序最近。
7.根据权利要求6所述的装置,其特征在于,所述第一缓存模块包括:
第一确定单元,用于确定在所述缓存空间中为所述用户缓存所述预设数据集合中的数据的已缓存次数;
第二确定单元,用于根据所述已缓存次数确定缓存所述第三数据的待缓存数量;
缓存单元,用于在所述缓存空间中缓存所述预设数据集合中的所述待缓存数量个第三数据。
8.根据权利要求6所述的装置,其特征在于,所述装置还包括:
获取模块,用于在未查找到所述第一数据的情况下,从所述预设数据集合中获取所述第一数据所对应的第一数据;
第二响应模块,用于以所述第一数据响应所述数据访问请求;以及,
第二缓存模块,用于在所述缓存空间中缓存所述预设数据集合中的所述第三数据。
9.根据权利要求6所述的装置,其特征在于,所述装置还包括:
第二确定模块,用于确定所述缓存空间中的所述已缓存数据的数据量是否大于预设数据量;
第一删除模块,用于在所述已缓存数据的数据量大于预设数据量的情况下,在所述缓存空间中的已缓存数据中按照位置顺序删除至少一个被所述用户访问过的数据,以使所述缓存空间中剩余的已缓存数据的数据量小于预设数据量。
10.根据权利要求6所述的装置,其特征在于,所述装置还包括:
第二删除模块,用于在所述缓存空间中缓存的所述预设数据集合中的数据未被访问的持续时长达到预设时长的情况下,删除所述缓存空间中缓存的所述预设数据集合中的数据。
11.一种电子设备,其特征在于,所述电子设备包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行如权利要求1-5任一项所述的数据访问方法。
12.一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如权利要求1-5任一项所述的数据访问方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010328936.2A CN111625536B (zh) | 2020-04-23 | 2020-04-23 | 一种数据访问方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010328936.2A CN111625536B (zh) | 2020-04-23 | 2020-04-23 | 一种数据访问方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111625536A true CN111625536A (zh) | 2020-09-04 |
CN111625536B CN111625536B (zh) | 2023-09-22 |
Family
ID=72270827
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010328936.2A Active CN111625536B (zh) | 2020-04-23 | 2020-04-23 | 一种数据访问方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111625536B (zh) |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2007062254A2 (en) * | 2005-11-28 | 2007-05-31 | Commvault Systems, Inc. | Systems and methods for data management |
CN105988941A (zh) * | 2015-02-28 | 2016-10-05 | 深圳市腾讯计算机系统有限公司 | 缓存数据处理方法和装置 |
CN107079056A (zh) * | 2014-09-19 | 2017-08-18 | Netapp股份有限公司 | 在存储集群系统中协调命令的并行执行和取消的技术 |
CN107666509A (zh) * | 2017-08-28 | 2018-02-06 | 深圳市诚壹科技有限公司 | 缓存控制方法及服务器 |
CN108234663A (zh) * | 2018-01-09 | 2018-06-29 | 武汉斗鱼网络科技有限公司 | 一种获取数据的方法、装置及计算机设备 |
CN109144431A (zh) * | 2018-09-30 | 2019-01-04 | 华中科技大学 | 数据块的缓存方法、装置、设备及存储介质 |
CN109947667A (zh) * | 2017-12-21 | 2019-06-28 | 华为技术有限公司 | 数据访问预测方法和装置 |
-
2020
- 2020-04-23 CN CN202010328936.2A patent/CN111625536B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2007062254A2 (en) * | 2005-11-28 | 2007-05-31 | Commvault Systems, Inc. | Systems and methods for data management |
CN107079056A (zh) * | 2014-09-19 | 2017-08-18 | Netapp股份有限公司 | 在存储集群系统中协调命令的并行执行和取消的技术 |
CN105988941A (zh) * | 2015-02-28 | 2016-10-05 | 深圳市腾讯计算机系统有限公司 | 缓存数据处理方法和装置 |
CN107666509A (zh) * | 2017-08-28 | 2018-02-06 | 深圳市诚壹科技有限公司 | 缓存控制方法及服务器 |
CN109947667A (zh) * | 2017-12-21 | 2019-06-28 | 华为技术有限公司 | 数据访问预测方法和装置 |
CN108234663A (zh) * | 2018-01-09 | 2018-06-29 | 武汉斗鱼网络科技有限公司 | 一种获取数据的方法、装置及计算机设备 |
CN109144431A (zh) * | 2018-09-30 | 2019-01-04 | 华中科技大学 | 数据块的缓存方法、装置、设备及存储介质 |
Non-Patent Citations (2)
Title |
---|
ALPER KOZ; R.L. LAGENDIJK * |
邓亚丹;景宁;熊伟;: "一种新的数据库访问图算法及其应用", no. 17 * |
Also Published As
Publication number | Publication date |
---|---|
CN111625536B (zh) | 2023-09-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105338409B (zh) | 一种网络视频预加载方法及装置 | |
CN106897937B (zh) | 一种展示社交分享信息的方法和装置 | |
CN106896991B (zh) | 一种更新信息的方法及装置 | |
CN109388625B (zh) | 多分布式文件系统中处理配置文件的方法及装置 | |
CN107220059B (zh) | 应用界面的显示方法及装置 | |
US20220286740A1 (en) | Method and apparatus for video playing | |
CN113190777A (zh) | 数据更新方法、装置、电子设备、存储介质及产品 | |
CN112711723A (zh) | 一种恶意网址检测方法、装置及电子设备 | |
CN107402767B (zh) | 显示推送消息的方法和装置 | |
CN111814088A (zh) | 一种页面处理方法及装置 | |
US20160006787A1 (en) | Methods and devices for visiting a webpage | |
CN106528247B (zh) | 数据刷新方法及装置 | |
CN109245992B (zh) | 请求处理方法、装置、电子设备及存储介质 | |
CN110908814A (zh) | 消息处理方法、装置、电子设备及存储介质 | |
CN111625536B (zh) | 一种数据访问方法及装置 | |
CN111221862B (zh) | 一种请求处理方法及装置 | |
CN110457084B (zh) | 一种加载方法及装置 | |
CN110008135B (zh) | 一种信息处理方法、装置及电子设备 | |
CN112883314A (zh) | 一种请求处理方法及装置 | |
CN112102009A (zh) | 广告展示方法、装置、设备及存储介质 | |
CN114077461A (zh) | 应用程序的运行方法、装置、设备及存储介质 | |
CN107257384B (zh) | 服务状态监控方法及装置 | |
CN111724398A (zh) | 一种图像显示方法及装置 | |
CN111241134B (zh) | 一种数据处理方法及装置 | |
CN111061633A (zh) | 一种网页首屏时间检测方法、装置、终端及介质 |
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 |