CN113535769B - 查询信息的方法和装置 - Google Patents
查询信息的方法和装置 Download PDFInfo
- Publication number
- CN113535769B CN113535769B CN202010295677.8A CN202010295677A CN113535769B CN 113535769 B CN113535769 B CN 113535769B CN 202010295677 A CN202010295677 A CN 202010295677A CN 113535769 B CN113535769 B CN 113535769B
- Authority
- CN
- China
- Prior art keywords
- information
- time period
- user
- database
- time
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 45
- 230000004044 response Effects 0.000 claims abstract description 29
- 238000012545 processing Methods 0.000 claims description 40
- 238000003860 storage Methods 0.000 claims description 20
- 238000004590 computer program Methods 0.000 claims description 9
- 238000010586 diagram Methods 0.000 description 10
- 238000004891 communication Methods 0.000 description 7
- 230000006870 function Effects 0.000 description 7
- 230000008569 process Effects 0.000 description 6
- 238000004364 calculation method Methods 0.000 description 5
- 230000003287 optical effect Effects 0.000 description 4
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 239000000835 fiber Substances 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 239000004753 textile Substances 0.000 description 2
- 238000010276 construction Methods 0.000 description 1
- 238000001816 cooling Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000007710 freezing Methods 0.000 description 1
- 230000008014 freezing Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000005057 refrigeration Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
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
-
- 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
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (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是本发明实施例可以应用于其中的示例性***架构图;
图6是适于用来实现本发明实施例的终端设备或服务器的计算机***的结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
需要指出的是,在不冲突的情况下,本发明中的实施例以及实施例中的特征可以互相组合。
在第二次查询时,第一次查询获取的信息一与第二次查询获取的信息一中部分内容相同,但第一次查询获取的信息一与第二次查询获取的信息一整体不同,因而,缓存数据库不存在第二次查询获取的信息一,需要从数据库获取信息二,将信息二确定为第二次查询的响应结果。得到第二次查询的响应结果需要访问数据库,现有技术存在数据库的访问次数多的问题。访问数据库需要消耗时间,因而,现有技术存在查询效率低的问题。
为了解决现有技术存在的问题,本发明一实施例提供了一种查询信息的方法,如图1所示,该方法包括:
步骤S101、基于查询请求获取第一信息和第一时间。
需说明的是,该步骤的具体实施方式在下文中进行了详细地介绍,在此不再赘述。
步骤S102、若缓存数据库存在所述第一信息,则从所述缓存数据库获取与所述第一信息匹配存储的第二信息和第一时间段;若所述第一时间段包括所述第一时间,则将所述第二信息确定为所述查询请求的响应结果;其中,所述第二信息与所述第一时间段匹配。
在该步骤中,具体实施时,若缓存数据库存在第一信息,则第一信息是作为键,第二信息和第一时间段是作为值,以键值的方式匹配存储在缓存数据库。
下面以一具体例子说明第一时间段包括第一时间:第一时间段为2019-12-1至2019-12-31,第一时间为2019-12-2,2019-12包括2019-12-2。
需说明的是,若第一时间段不包括第一时间,则从数据库获取与第一信息匹配的第三信息,以及与第三信息匹配的第二时间段;将第一信息,以及第三信息和第二时间段匹配存储在缓存数据库,将第三信息确定为查询请求的响应结果。
具体地,第三信息与第二信息可能相同,也可能不同。第二时间段与第一时间段不同。从数据库获取第三信息的方法与从数据库获取第二信息的方法相同,确定第二时间段的方法与确定第一时间段的方法相同,在此不再赘述。
在本发明实施例中,还包括:
若所述缓存数据库不存在所述第一信息,则从数据库获取与所述第一信息匹配的第二信息,以及与所述第二信息匹配的第一时间段;将所述第一信息,以及所述第二信息和所述第一时间段匹配存储在所述缓存数据库;将所述第二信息确定为所述查询请求的响应结果。
在该实施例中,需说明的是,缓存数据库不存在第一信息,也就是,缓存数据库不存在存储对象是第一信息的键。
另外,从数据库获取与所述第一信息匹配的第二信息,以及与所述第二信息匹配的第一时间段,在下文中进行了详细地介绍,在此不再赘述。
在该实施例中,将第一信息,以及第二信息和第一时间段匹配存储在缓存数据库,以便以后直接从缓存数据库查询信息,进一步提高了查询效率。
在本发明实施例中,基于查询请求获取第一信息和第一时间,包括:
接收查询请求,所述查询请求携带用户的标识、业务类型、所述用户的物品的标识和第一时间;
基于所述用户的标识、所述用户的物品的标识和所述第一时间获取所述物品的目标属性的值,将所述用户的标识、所述业务类型和所述物品的目标属性的值组合成第一信息。
在该实施例中,以物流领域为例,具体实施时,用户的标识可以是用户的名称或者用户编码(物流公司为用户设置的数字组合,具有唯一性)。用户的物品的标识可以是用户的物品的库存保有单位(Stock keeping Unit,简称SKU);第一时间可以是服务发生日期。业务类型包括销售出库、采购入库、存储或者退货入库等。
获取物品的目标属性的值的过程在下文中进行了详细地介绍,在此不再赘述。
在该实施例中,将用户的标识、业务类型和物品的目标属性的值组合成第一信息,缓存数据库中的键是第一信息,而不再是第一信息和第一时间,进一步减少缓存数据库中的信息量,进一步提高查询效率。
在本发明实施例中,基于所述用户的标识、所述用户的物品的标识和所述第一时间获取所述物品的目标属性的值,包括:
从所述数据库查询到信息表的摘要,所述摘要包括所述用户的标识,所述摘要的有效期包括所述第一时间;
从所述摘要中获取目标属性;
根据所述用户的物品的标识和所述目标属性获取所述物品的目标属性的值。
在该实施例中,具体实施时,数据库可以是报价数据库,摘要可以是报价主单,摘要存储在数据库中。摘要包括目标属性、摘要的有效期和用户的标识。目标属性可以是报价维度。
应理解的是,一个用户的报价维度是固定的。报价维度可以是物品件型和计费分类。物品件型的值包括小件(例如,小包装)、中件(例如,中包装)和大件(例如,大包装)等。计费分类的值包括服饰一类(例如,女装)、服饰二类(例如,男装)、家居家纺类、电子电器类和户外运动类等。报价维度还可以是仓库储藏物品的方式。仓库储藏物品的方式包括常温储藏、鲜活储藏、控温储藏、冷藏、冷冻储藏或深冷储藏等。
根据所述用户的物品的标识和所述目标属性从基础信息库获取所述物品的目标属性的值。用户的物品的标识、目标属性和物品的目标属性的值匹配存储在基础信息库。当然,基础信息库中还匹配存储物品的除目标属性以外的属性,及物品的除目标属性以外的属性的值。另外,每个物品均预先设置了物品件型和计费分类。
在本发明实施例中,从数据库获取与所述第一信息匹配的第二信息,包括:
从所述摘要中获取所述摘要的标识;
从数据库查询到包含有所述摘要的标识的所述信息表;
从所述信息表中得到与所述业务类型和所述物品的目标属性的值均匹配的信息,将其确定为与所述第一信息匹配的第二信息。
在该实施例中,摘要的标识可以是报价主单的编码(编码可以是一组数字,具有唯一性);摘要包括摘要的标识;信息表可以是报价明细表;报价明细表存储在数据库;报价明细表表中匹配存储业务类型、物品的目标属性的值和第二信息。另外,报价明细表与报价主单具有一一对应关系。
第二信息包括单位价格、单位、单位价格的精确度和折扣等。物品的目标属性的值不同,第二信息不同。
在该实施例中,从包含有摘要的标识的信息表中得到与业务类型和物品的目标属性的值均匹配的第二信息,且摘要包括用户的标识,因而得到准确的第二信息,提高了信息查询的准确性。
在本发明实施例中,所述第一时间段的确定方法,包括:
将所述摘要的有效期和业务处理时间段的交集确定为所述第一时间段,或者,直接将所述摘要的有效期确定为所述第一时间段。
在该实施例中,业务处理时间段可以根据用户的结算方式确定。例如,用户的结算方式为月结,则业务处理时间段为月初到月末。另外,第一时间段预先存储在数据库中。
下面以一具体例子说明为何将摘要的有效期和业务处理时间段的交集确定为第一时间段。用户存在报价主单P003和报价主单P004,用户的报价主单P003的有效期为2019-11-01至2019-11-10,用户的报价主单P004的有效期为2019-11-11至2019-11-30,业务处理时间段为2019-11-01至2019-11-30。2019-11-01至2019-11-10期间产生的费用应使用P003对应的报价明细表,2019-11-11至2019-11-30期间产生的费用应使用P004对应的报价明细表。直接将业务处理时间段确定为第一时间段,可能导致2019-11-01至2019-11-10期间产生的费用使用P004对应的报价明细表,最终得到错误的第二信息。
在该实施例中,第一时间段为摘要的有效期和业务处理时间段的交集,或者摘要的有效期,而不是业务处理时间段,减少得到错误的第二信息的可能性,进一步提高了信息查询的准确性。
在本发明实施例中,将所述第一信息,以及所述第二信息和所述第一时间段匹配存储在所述缓存数据库,包括:
将所述第一信息作为键,将所述第二信息和所述第一时间段作为值,以键值的方式匹配存储在所述缓存数据库。
在该实施例中,需说明的是,第二信息可以从数据库查询,但将经常用到的第二信息存储到缓存数据库,可以提高第二信息的查询效率。
在该实施例中,键只包括第一信息,不包括第一时间,降低键的维度,减少缓存数据库中的键的数量,进一步减少缓存数据库中的信息量,进一步减少占用缓存数据库的空间,进一步提高查询效率。
为了解决现有技术存在的问题,本发明另一实施例提供了一种查询信息的方法。
需说明的是,物流公司为用户提供仓储配运及增值服务,基于这些服务向用户提供报价,并按照报价收取费用。用户数量庞大,按照现结方式结算费用非常繁杂,因而,一般采用非现结方式结算费用,例如月结。例如,用户C的报价主单P001的有效期为2019-01-01至2019-12-31。2020-01-01需计算用户C在2019-12-01至2019-12-31范围内的服务费用。用户在2019-12有笔销售出库订单S001。销售出库订单的产生理由:物流公司将用户C的物品存储在仓库中,用户C销售物品时需要将物品出库,产生销售出库订单,物流公司向用户C收取费用。
销售出库订单S001,服务发生日期:2019-12-01,物品件型的值:小件,计费分类的值:服饰一类,用户的标识:C,业务类型:销售出库(即S),用户的物品的标识:SKU1,报价明细表如下表所示:
表1报价明细表
如图2和图3所示,该方法包括:
步骤S201、接收查询请求,查询请求携带用户的标识、业务类型、用户的物品的标识和第一时间。
在该步骤中,用户的标识、业务类型、用户的物品的标识和第一时间(即服务发生日期)源自销售出库订单。
服务发生日期即现场作业的日期,业务***产生现场作业,将服务发生日期、用户编码、业务类型和用户的物品的标识和查询请求发送给本发明实施例应用的服务器。本发明实施例应用的服务器在确定了响应结果后,将响应结果返回给业务***。
步骤S202、从数据库查询到信息表的摘要,摘要包括用户的标识,摘要的有效期包括第一时间。
在该步骤中,从报价数据库查询到报价主单P001。报价主单P001包括用户的标识C和报价主单P001的有效期,报价主单P001的有效期(2019-01-01至2019-12-31)包括第一时间(2019-12-01)。
步骤S203、从摘要中获取目标属性。
在该步骤中,报价主单P001的报价维度是物品件型和计费分类。
步骤S204、根据用户的物品的标识和目标属性从基础信息库获取物品的目标属性的值。
在该步骤中,物品的目标属性的值包括物品的物品件型的值和物品的计费分类的值。为物品件型的每个值设置编码,为计费分类的每个值设置编码,例如,小件的编码为GT001,服饰一类的编码为CT001,家居家纺一类的编码为CT002。从而在组合第一信息时,用物品的物品件型的值的编码替代物品的物品件型的值,用物品的计费分类的值的编码替代物品的计费分类的值,以减少第一信息包括的信息量。
步骤S205、将用户的标识、业务类型和物品的目标属性的值组合成第一信息。
在该步骤中,将用户编码、销售出库、物品的物品件型的值的编码和物品的计费分类的值的编码组合成第一信息。第一信息为C-S-GT001-CT001。
步骤S206、若缓存数据库存在第一信息,则从缓存数据库获取与第一信息匹配存储的第二信息和第一时间段;若第一时间段包括第一时间,则将第二信息确定为查询请求的响应结果;其中,第二信息与第一时间段匹配。
步骤S207、若缓存数据库不存在第一信息,则从数据库获取与第一信息匹配的第二信息,以及与第二信息匹配的第一时间段;将第一信息,以及第二信息和第一时间段匹配存储在缓存数据库;将第二信息确定为查询请求的响应结果。
在该步骤中,将摘要的有效期和业务处理时间段的交集确定为第一时间段。例如,报价主单P001的有效期为2019-01-01至2019-12-31,业务处理时间段为2019-12-01至2019-12-31,因而,第一时间段为2019-12-01至2019-12-31。
从数据库获取与第一信息匹配的第二信息,包括:从摘要中获取摘要的标识;从数据库查询到包含有摘要的标识的信息表;从信息表中得到与业务类型和物品的目标属性的值均匹配的信息,将其确定为与第一信息匹配的第二信息。具体地,报价明细表(即信息表)中匹配存储销售出库、物品的物品件型的值、物品的计费分类的值和第二信息。
在确定了响应结果之后,业务***按照第二信息计算销售出库订单的费用。例如,确定第二信息包括2元/件,折扣为0.8。而销售出库订单中物品的数量为3件,则费用=4.8元=3件×2元/件×0.8。
需说明的是,若用户C的所有订单的费用计算均已完成,则删除缓存数据库中包含C的第一信息,以及与第一信息匹配存储的所有信息。如此,可以提高其他用户的查询效率。
应理解的是,本发明实施例不仅适用于费用计算中查询第二信息,其他用到缓存数据库的场景也可以适用。缓存数据库中的键的选取,需要根据具体业务场景确定。在本发明实施例中,同一用户,在2019-12-01有一个物品A的销售出库订单,在2019-12-02至2019-12-31有物品A的销售出库订单,以及与物品A的目标属性的值相同的其他物品的销售出库订单的可能性较高。因而,键可以不包括时间。而计费分类不具有上述规律性,即有GT001类物品的销售出库订单,无法预测有GT002类物品的销售出库订单,或者出现的概率较低,因而,键要包括计费分类。
需说明的是,可以将报价主单P001下对应的报价明细表一次性存储到缓存数据库。因而,在第一信息包括GT001和CT002的情况下,则将3元/件和折扣为0.8确定为查询请求的响应结果,在第一信息包括GT002和CT003的情况下,将4元/件和折扣为0.8确定为查询请求的响应结果。但存在如下问题:缓存数据库的值过大,缓存数据库的存取性能下降;缓存数据库内的信息利用率不高。
发明人发现同一用户的订单,经常存在重复的信息。例如,在2019-12-01有一个物品A的销售出库订单,其他日期也会出现物品A的销售出库订单。物流公司与用户签订的服务合同是具有有效期的,因而,在该有效期内,物品A的销售出库订单的费用固定不变。
而整月的订单,是以用户为单位进行处理。同一用户的所有订单的费用计算在一个较短的时间完成,一般在几分钟到几小时之间。因而,查询费用计算的规则(即第二信息)也应在较短时间完成。
因而,在本发明实施例中,在第一次查询完成的情况下,键(即key)只包括第一信息,不包括第一次查询的第一时间,第一时间段和第二信息同时作为值(即value),以键值的方式匹配存储在缓存数据库。第二次查询时,若第一信息没变,且第二次查询的第一时间包含于第一时间段,则直接将第二信息作为第二次查询的响应结果。从而以缓存数据库预热的方式,提高查询效率,减少数据库的访问次数。
缓存数据库:将数据放在内存中直接操作的数据库。相对于磁盘,内存的数据读写速度要高出几个数量级,将数据保存在内存中相比从磁盘上访问能够极大地提高应用的性能。存储方式,一般以键-值形式,查询时可根据键获取值。
缓存数据库预热:将未使用到的数据保存到缓存数据库中,以提高查询性能。
为了解决现有技术存在的问题,本发明实施例提供了一种查询信息的装置,如图4所示,该装置包括:
第一处理单元401,用于基于查询请求获取第一信息和第一时间;
第二处理单元402,用于若缓存数据库存在所述第一信息,则从所述缓存数据库获取与所述第一信息匹配存储的第二信息和第一时间段;若所述第一时间段包括所述第一时间,则将所述第二信息确定为所述查询请求的响应结果;其中,所述第二信息与所述第一时间段匹配。
在本发明实施例中,第二处理单元402用于:
若所述缓存数据库不存在所述第一信息,则从数据库获取与所述第一信息匹配的第二信息,以及与所述第二信息匹配的第一时间段;将所述第一信息,以及所述第二信息和所述第一时间段匹配存储在所述缓存数据库;将所述第二信息确定为所述查询请求的响应结果。
在本发明实施例中,第一处理单元401用于:
接收查询请求,所述查询请求携带用户的标识、业务类型、所述用户的物品的标识和第一时间;
基于所述用户的标识、所述用户的物品的标识和所述第一时间获取所述物品的目标属性的值,将所述用户的标识、所述业务类型和所述物品的目标属性的值组合成第一信息。
在本发明实施例中,第一处理单元401用于:
从所述数据库查询到信息表的摘要,所述摘要包括所述用户的标识,所述摘要的有效期包括所述第一时间;
从所述摘要中获取目标属性;
根据所述用户的物品的标识和所述目标属性获取所述物品的目标属性的值。
在本发明实施例中,第二处理单元402用于:
从所述摘要中获取所述摘要的标识;
从数据库查询到包含有所述摘要的标识的所述信息表;
从所述信息表中得到与所述业务类型和所述物品的目标属性的值均匹配的信息,将其确定为与所述第一信息匹配的第二信息。
在本发明实施例中,第二处理单元402用于:
将所述摘要的有效期和业务处理时间段的交集确定为所述第一时间段,或者,直接将所述摘要的有效期确定为所述第一时间段。
在本发明实施例中,第二处理单元402用于:
将所述第一信息作为键,将所述第二信息和所述第一时间段作为值,以键值的方式匹配存储在所述缓存数据库。
应理解的是,本发明实施例提供的查询信息的装置的各个部件所执行的功能已经在上述实施例一种查询信息的方法中做了详细的介绍,在此不再赘述。
图5示出了可以应用本发明实施例的查询信息的方法或查询信息的装置的示例性***架构500。
如图5所示,***架构500可以包括终端设备501、502、503,网络504和服务器505。网络504用以在终端设备501、502、503和服务器505之间提供通信链路的介质。网络504可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备501、502、503通过网络504与服务器505交互,以接收或发送消息等。终端设备501、502、503上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等(仅为示例)。
终端设备501、502、503可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器505可以是提供各种服务的服务器,例如对用户利用终端设备501、502、503所浏览的购物类网站提供支持的后台管理服务器(仅为示例)。后台管理服务器可以对接收到的产品信息查询请求等数据进行分析等处理,并将处理结果(例如目标推送信息、产品信息--仅为示例)反馈给终端设备。
需要说明的是,本发明实施例所提供的查询信息的方法一般由服务器505执行,相应地,查询信息的装置一般设置于服务器505中。
应该理解,图5中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
下面参考图6,其示出了适于用来实现本发明实施例的终端设备的计算机***600的结构示意图。图6示出的终端设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图6所示,计算机***600包括中央处理单元(CPU)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有***600操作所需的各种程序和数据。CPU 601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
以下部件连接至I/O接口605:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便于从其上读出的计算机程序根据需要被安装入存储部分608。
特别地,根据本发明公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被中央处理单元(CPU)601执行时,执行本发明的***中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的***、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行***、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行***、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的***、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个单元、程序段、或代码的一部分,上述单元、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的***来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括第一处理单元和第二处理单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,第一处理单元还可以被描述为“基于查询请求获取第一信息和第一时间的单元”。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该设备执行时,使得该设备包括:基于查询请求获取第一信息和第一时间;若缓存数据库存在所述第一信息,则从所述缓存数据库获取与所述第一信息匹配存储的第二信息和第一时间段;若所述第一时间段包括所述第一时间,则将所述第二信息确定为所述查询请求的响应结果;其中,所述第二信息与所述第一时间段匹配。
根据本发明实施例的技术方案,将得到响应结果的条件由确定缓存数据库存在同时包含有第一信息和第一时间的信息,转变为确定缓存数据库存在第一信息,且第一时间段包括第一时间,从而减少缓存数据库中的信息量,减少占用缓存数据库的空间,减少数据库的访问次数,提高查询效率。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。
Claims (9)
1.一种查询信息的方法,其特征在于,包括:
基于查询请求获取第一信息和第一时间;
若缓存数据库存在所述第一信息,则从所述缓存数据库获取与所述第一信息匹配存储的第二信息和第一时间段;若所述第一时间段包括所述第一时间,则将所述第二信息确定为所述查询请求的响应结果;其中,所述第二信息与所述第一时间段匹配;
若所述缓存数据库不存在所述第一信息,则从数据库获取与所述第一信息匹配的第二信息,以及与所述第二信息匹配的第一时间段;将所述第一信息,以及所述第二信息和所述第一时间段匹配存储在所述缓存数据库;将所述第二信息确定为所述查询请求的响应结果。
2.根据权利要求1所述的方法,其特征在于,基于查询请求获取第一信息和第一时间,包括:
接收查询请求,所述查询请求携带用户的标识、业务类型、所述用户的物品的标识和第一时间;
基于所述用户的标识、所述用户的物品的标识和所述第一时间获取所述物品的目标属性的值,将所述用户的标识、所述业务类型和所述物品的目标属性的值组合成第一信息。
3.根据权利要求2所述的方法,其特征在于,基于所述用户的标识、所述用户的物品的标识和所述第一时间获取所述物品的目标属性的值,包括:
从所述数据库查询到信息表的摘要,所述摘要包括所述用户的标识,所述摘要的有效期包括所述第一时间;
从所述摘要中获取目标属性;
根据所述用户的物品的标识和所述目标属性获取所述物品的目标属性的值。
4.根据权利要求3所述的方法,其特征在于,从数据库获取与所述第一信息匹配的第二信息,包括:
从所述摘要中获取所述摘要的标识;
从数据库查询到包含有所述摘要的标识的所述信息表;
从所述信息表中得到与所述业务类型和所述物品的目标属性的值均匹配的信息,将其确定为与所述第一信息匹配的第二信息。
5.根据权利要求4所述的方法,其特征在于,所述第一时间段的确定方法,包括:
将所述摘要的有效期和业务处理时间段的交集确定为所述第一时间段,或者,直接将所述摘要的有效期确定为所述第一时间段。
6.根据权利要求1所述的方法,其特征在于,将所述第一信息,以及所述第二信息和所述第一时间段匹配存储在所述缓存数据库,包括:
将所述第一信息作为键,将所述第二信息和所述第一时间段作为值,以键值的方式匹配存储在所述缓存数据库。
7.一种查询信息的装置,其特征在于,包括:
第一处理单元,用于基于查询请求获取第一信息和第一时间;
第二处理单元,用于若缓存数据库存在所述第一信息,则从所述缓存数据库获取与所述第一信息匹配存储的第二信息和第一时间段;若所述第一时间段包括所述第一时间,则将所述第二信息确定为所述查询请求的响应结果;其中,所述第二信息与所述第一时间段匹配;
第二处理单元用于:若所述缓存数据库不存在所述第一信息,则从数据库获取与所述第一信息匹配的第二信息,以及与所述第二信息匹配的第一时间段;将所述第一信息,以及所述第二信息和所述第一时间段匹配存储在所述缓存数据库;将所述第二信息确定为所述查询请求的响应结果。
8.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-6中任一所述的方法。
9.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求1-6中任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010295677.8A CN113535769B (zh) | 2020-04-15 | 2020-04-15 | 查询信息的方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010295677.8A CN113535769B (zh) | 2020-04-15 | 2020-04-15 | 查询信息的方法和装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113535769A CN113535769A (zh) | 2021-10-22 |
CN113535769B true CN113535769B (zh) | 2023-11-03 |
Family
ID=78120097
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010295677.8A Active CN113535769B (zh) | 2020-04-15 | 2020-04-15 | 查询信息的方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113535769B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115063923A (zh) * | 2022-06-28 | 2022-09-16 | 北京字跳网络技术有限公司 | 投票处理方法、***、装置、电子设备和存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104572727A (zh) * | 2013-10-22 | 2015-04-29 | 阿里巴巴集团控股有限公司 | 一种数据查询方法及装置 |
CN108984553A (zh) * | 2017-06-01 | 2018-12-11 | 北京京东尚科信息技术有限公司 | 缓存方法和装置 |
WO2019154353A1 (zh) * | 2018-02-07 | 2019-08-15 | 中兴通讯股份有限公司 | ***运行参数查询方法、匹配方法、装置及节点设备 |
WO2019210585A1 (zh) * | 2018-05-03 | 2019-11-07 | 平安科技(深圳)有限公司 | 消息推送方法、计算机可读存储介质、终端设备及装置 |
-
2020
- 2020-04-15 CN CN202010295677.8A patent/CN113535769B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104572727A (zh) * | 2013-10-22 | 2015-04-29 | 阿里巴巴集团控股有限公司 | 一种数据查询方法及装置 |
CN108984553A (zh) * | 2017-06-01 | 2018-12-11 | 北京京东尚科信息技术有限公司 | 缓存方法和装置 |
WO2019154353A1 (zh) * | 2018-02-07 | 2019-08-15 | 中兴通讯股份有限公司 | ***运行参数查询方法、匹配方法、装置及节点设备 |
WO2019210585A1 (zh) * | 2018-05-03 | 2019-11-07 | 平安科技(深圳)有限公司 | 消息推送方法、计算机可读存储介质、终端设备及装置 |
Non-Patent Citations (1)
Title |
---|
基于JDBC数据管理与查询优化的研究;韩兵;李晶晶;方英兰;;计算机技术与发展(第09期);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN113535769A (zh) | 2021-10-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107172151B (zh) | 用于推送信息的方法和装置 | |
CN107967284B (zh) | 用于存储、查询订单信息的方法和装置 | |
CN107229718B (zh) | 处理报表数据的方法和装置 | |
CN112884405A (zh) | 一种询价***及其调度方法 | |
CN110473036B (zh) | 一种生成订单号的方法和装置 | |
CN113095893A (zh) | 确定物品销量的方法和装置 | |
CN113535769B (zh) | 查询信息的方法和装置 | |
CN111401684A (zh) | 一种任务处理的方法和装置 | |
CN112182138A (zh) | 一种目录编制方法和装置 | |
CN113762863B (zh) | 一种库存管理方法和装置 | |
CN113761565A (zh) | 数据脱敏方法和装置 | |
US20140244484A1 (en) | Network computing environment collection and notification of point of sale information | |
CN113112048A (zh) | 一种物品回库方法和装置 | |
CN115760300A (zh) | 一种基于标签管理销售品的实现方法及*** | |
CN110956514A (zh) | 一种生成订单信息的方法和装置 | |
CN114445128A (zh) | 卡券管理方法、装置、电子设备和计算机可读介质 | |
CN113868687A (zh) | 一种任务处理进度的管理方法和装置 | |
CN113762865A (zh) | 一种库存信息处理方法和装置 | |
CN113496386A (zh) | 一种合并计费的方法和装置 | |
CN110738806B (zh) | 支付方式确定方法、装置、***及电子设备 | |
CN113822516A (zh) | 一种配运方的匹配方法及装置 | |
CN113761102A (zh) | 数据处理方法、装置、服务器、***和存储介质 | |
CN113762835A (zh) | 一种处理订单数据的方法和装置 | |
CN108733668B (zh) | 用于查询数据的方法和装置 | |
CN113780921B (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 |