CN110019352B - 用于存储数据的方法和装置 - Google Patents
用于存储数据的方法和装置 Download PDFInfo
- Publication number
- CN110019352B CN110019352B CN201710828770.9A CN201710828770A CN110019352B CN 110019352 B CN110019352 B CN 110019352B CN 201710828770 A CN201710828770 A CN 201710828770A CN 110019352 B CN110019352 B CN 110019352B
- Authority
- CN
- China
- Prior art keywords
- target data
- identification value
- historical
- user behavior
- occurrence 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
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/24—Querying
- G06F16/245—Query processing
- G06F16/2455—Query execution
- G06F16/24553—Query execution of query operations
- G06F16/24554—Unary operations; Data partitioning operations
-
- 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/24568—Data stream processing; Continuous queries
-
- 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/2458—Special types of queries, e.g. statistical queries, fuzzy queries or distributed queries
- G06F16/2474—Sequence data queries, e.g. querying versioned data
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- General Physics & Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Software Systems (AREA)
- Mathematical Physics (AREA)
- Fuzzy Systems (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本申请公开了用于存储数据的方法和装置。该方法的一具体实施方式包括:接收目标数据;根据所述来源终端的标识确定所述目标数据的存储区域;响应于确定所述存储区域内已保存历史用户行为发生时间和历史标识值,计算所述目标数据包括的用户行为发生时间与所述历史用户行为发生时间的差值;响应于确定所述差值大于第一预设时间,则基于所述历史标识值,生成所述目标数据的标识值;关联存储所述目标数据和所述目标数据的标识值至所述存储区域。该实施方式提高了存储目标数据的效率。
Description
技术领域
本申请涉及计算机技术领域,具体涉及互联网技术领域,尤其涉及用于存储数据的方法和装置。
背景技术
在信息技术时代,大数据的应用深入到各种业务场景,而在大数据的应用中,数据特征的提取和加工至关重要。常见的数据处理方式是对数据进行逐条处理,这种方式适合大多数的数据处理场景,但在点击数据流等具有上下文关系的时间序列数据流处理中,逐条处理的方式使数据流失去了与上下文的关联信息,无法更深入地挖掘数据的价值,因此基于时间序列的数据流处理方式被广泛地应用。
现有的时间序列数据流的处理方式大多适用于离线数据处理,在需要实时地处理数据的场景中,现有技术方案需要对数据整体进行存储和标记,存储数据的效率不高。
发明内容
本申请的目的在于提出一种改进的用于存储数据的方法和装置,来解决以上背景技术部分提到的技术问题。
第一方面,本申请实施例提供了一种用于存储数据的方法,该方法包括:接收目标数据,其中,目标数据包括目标数据的来源终端所记录的用户行为发生时间和来源终端的标识;根据来源终端的标识确定目标数据的存储区域;响应于确定存储区域内已保存历史用户行为发生时间和历史标识值,计算目标数据包括的用户行为发生时间与历史用户行为发生时间的差值,其中,历史用户行为发生时间为存储至存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间,历史标识值为历史用户行为发生时间所对应的历史目标数据的标识值;响应于确定差值大于第一预设时间,则基于历史标识值,生成目标数据的标识值;关联存储目标数据和目标数据的标识值至存储区域。
在一些实施例中,根据来源终端的标识确定目标数据的存储区域之后,该方法还包括:响应于确定存储区域内未保存历史标识值和历史用户行为发生时间,则根据目标数据包括的用户行为发生时间生成目标数据的标识值,关联存储目标数据和所生成的目标数据的标识值至存储区域。
在一些实施例中,根据目标数据包括的用户行为发生时间生成目标数据的标识值包括:将目标数据包括的用户行为发生时间的各个计时单位所对应的数值组合为目标数据的标识值。
在一些实施例中,在计算目标数据包括的用户行为发生时间与历史用户行为发生时间的差值之后,该方法还包括:响应于确定差值小于等于第一预设时间,则确定历史标识值作为目标数据的标识值。
在一些实施例中,在关联存储目标数据和目标数据的标识值至存储区域之后,该方法还包括:响应于确定当前时间与历史用户行为时间之差大于第二预设时间,则删除历史标识值和历史用户行为发生时间,其中第二预设时间大于第一预设时间。
在一些实施例中,基于历史标识值,生成目标数据的标识值包括:将历史标识值与预设值相加,生成目标数据的标识值。
第二方面,本申请实施例提供了一种用于存储数据的装置,该装置包括:接收单元,配置用于接收目标数据,其中,目标数据包括目标数据的来源终端所记录的用户行为发生时间和来源终端的标识;第一确定单元,配置用于根据来源终端的标识确定目标数据的存储区域;计算单元,配置用于响应于确定存储区域内已保存历史用户行为发生时间和历史标识值,计算目标数据包括的用户行为发生时间与历史用户行为发生时间的差值,其中,历史用户行为发生时间为存储至存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间,历史标识值为历史用户行为发生时间所对应的历史目标数据的标识值;生成单元,配置用于响应于确定差值大于第一预设时间,则基于历史标识值,生成目标数据的标识值;存储单元,配置用于关联存储目标数据和目标数据的标识值至存储区域。
在一些实施例中,确定单元进一步配置用于:响应于确定存储区域内未保存历史标识值和历史用户行为发生时间,则根据目标数据包括的用户行为发生时间生成目标数据的标识值,关联存储目标数据和所生成的目标数据的标识值至存储区域。
在一些实施例中,确定单元进一步配置用于:将目标数据包括的用户行为发生时间的各个计时单位所对应的数值组合为目标数据的标识值。
在一些实施例中,用于存储数据的装置还包括:第二确定单元,配置用于响应于确定差值小于等于第一预设时间,则确定历史标识值作为目标数据的标识值。
在一些实施例中,用于存储数据的装置还包括:删除单元,配置用于响应于确定当前时间与历史用户行为时间之差大于第二预设时间,则删除历史标识值和历史用户行为发生时间,其中第二预设时间大于第一预设时间。
在一些实施例中,生成单元进一步配置用于:将历史标识值与预设值相加,生成目标数据的标识值。
第三方面,本申请实施例提供了一种服务器,该服务器包括:一个或多个处理器;存储装置,用于存储一个或多个程序;当一个或多个程序被一个或多个处理器执行,使得一个或多个处理器实现如第一方面中任一实现方式描述的方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该计算机程序被处理器执行时实现如第一方面中任一实现方式描述的方法。
本申请实施例提供的用于存储数据的方法和装置,通过对接收的目标数据进行分区域存储,并且基于存储区域中已经存储的历史目标数据的标识值和历史目标数据包括的用户行为发生时间,生成接收的目标数据的标识值,提高了存储目标数据的效率。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显:
图1是本申请可以应用于其中的示例性系统架构图;
图2是根据本申请的用于存储数据的方法的一个实施例的流程图;
图3是根据本申请的用于存储数据的方法的又一个实施例的流程图;
图4是根据本申请的用于存储数据的装置的一个实施例的结构示意图;
图5是适于用来实现本申请实施例的服务器的计算机系统的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的用于存储数据的方法或用于存储数据的装置的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving Picture ExpertsGroup Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving PictureExperts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上显示的网页提供支持的后台网页服务器。后台网页服务器可以对接收到的点击数据流等数据进行分析、存储等处理。
需要说明的是,本申请实施例所提供的用于存储数据的方法一般由服务器105执行,相应地,用于存储数据的装置一般设置于服务器105中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了根据本申请的用于存储数据的方法的一个实施例的流程200。该用于存储数据的方法包括以下步骤:
步骤201,接收目标数据。
在本实施例中,用于存储数据的方法运行于其上的电子设备(例如图1所示的服务器)可以通过有线连接方式或者无线连接方式从用户利用其进行浏览的终端接收目标数据。其中,上述目标数据可以包括流数据,例如用户利用其进行浏览的终端进行网页浏览时产生的点击流数据或用户的移动终端所产生的地理位置数据等。需要指出的是,上述无线连接方式可以包括但不限于3G/4G连接、WiFi连接、蓝牙连接、WiMAX连接、Zigbee连接、UWB(ultra wideband)连接、以及其他现在已知或将来开发的无线连接方式。
在本实施例中,上述目标数据还可以包括上述目标数据的来源终端所记录的用户行为发生时间和上述来源终端的标识。其中,上述用户行为发生时间可以是用户所使用的终端响应于用户的触发动作而产生相应数据的时间。例如,用户所使用的终端记录下的用户点击网址时的时间、自动切换网址时的时间、自动记录地理位置数据时的时间等。
上述来源终端的标识可以用于表征产生目标数据的来源终端(例如终端的硬件序列号、终端的网络地址等)。可选的,上述来源终端的标识可以由终端的硬件序列号和终端的IP(Internet Protocol,网际协议)地址组成。上述目标数据可以是以来源终端的标识作为键、以用户行为发生时间作为值所组成的键值对数据,其中,上述键值对数据中的值可以是元组(Tuple)类数据。
示例性的,上述电子设备可以接收来自消息发布系统(例如Kafka、RabbitMQ等,其中,Kafka是一种高吞吐量的分布式发布订阅消息系统,可以处理消费者规模的网站中的所有动作流数据,RabbitMQ是一个可复用的企业消息系统。他遵循Mozilla Public License开源协议)的实时数据作为目标数据,然后使用实时数据流计算框架(例如SparkStreaming,Spark Streaming是Spark核心应用程序编程接口的一个扩展,可以实现高吞吐量的、具备容错机制的实时流数据的处理,并且支持从多种数据源获取数据)对目标数据进行处理等操作。
步骤202,根据来源终端的标识确定目标数据的存储区域。
在本实施例中,基于步骤201中接收的目标数据,上述电子设备可以根据目标数据所包含的来源终端的标识确定目标数据的存储区域。上述电子设备可以首先解析出接收的目标数据包含的目标数据的来源终端的标识,然后将包含有相同的来源终端的标识的各个目标数据存储至同一存储区域。或者,上述电子设备将所包括的来源终端标识处于预设字段内(例如IP地址处于同一网段)的目标数据存储至同一存储区域。
示例性的,上述电子设备可以利用一致性哈希(Consistent Hash)算法将携带有相同键(即来源终端的标识)的目标数据存储在同一个存储区域中。
步骤203,响应于确定存储区域内已保存历史用户行为发生时间和历史标识值,计算目标数据包括的用户行为发生时间与历史用户行为发生时间的差值。
在本实施例中,基于步骤202中确定的存储目标数据的存储区域,上述电子设备首先确定在上述存储区域中是否已保存历史用户行为发生时间和历史标识值,如果确定已保存历史用户行为发生时间和历史标识值,则计算目标数据包括的用户行为发生时间与上述历史用户行为发生时间的差值。
在本实施例中,上述历史用户行为发生时间可以为存储至上述存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间。上述历史标识值可以为上述历史用户行为发生时间所对应的历史目标数据的标识值。可选的,上述历史标识值和上述历史用户行为发生时间可以分别存储在上述存储区域内的预设的存储空间,以使上述电子设备能够在上述预设的存储空间内确定是否已保存历史用户行为发生时间和历史标识值。
在本实施例中,上述存储区域内存储的每个目标数据均具有与其对应的标识值,同理,上述历史目标数据同样具有与该历史目标数据对应的历史标识值。目标数据的标识值可以是时间序列标识值,时间序列标识值用于标识按时间顺序(例如按用户行为发生时间)排列的目标数据,并且可以用于反映用户行为发生的频率。多个目标数据的标识值可以相同,具有相同标识值且按照存储到存储空间的先后顺序排序的各个目标数据中,相邻的两个目标数据分别包括的用户行为发生时间之差不超过预设时间(例如1分钟),即在相同标识值的各个目标数据包括的用户行为发生时间所组成的时间段内,用户行为发生的频率较大。
示例性的,假设上述预设时间为1分钟,第一目标数据、第二目标数据和第三目标数据为先后存储在存储区域中的三个具有相同标识值的目标数据,且第一目标数包括的用户行为发生时间为2017年1月1日0时0分0秒,第二目标数包括的用户行为发生时间为2017年1月1日0时0分30秒,第三目标数包括的用户行为发生时间为2017年1月1日0时1分20秒,该三个目标数据中任意相邻的两个目标数据所包括的用户行为发生时间之差均未超过1分钟,则表示在2017年1月1日0时0分0秒~2017年1月1日0时1分20秒这段时间内,用户行为发生的频率较大(例如用户的点击操作频率较大)。
步骤204,响应于确定差值大于第一预设时间,则基于历史标识值,生成目标数据的标识值。
在本实施例中,基于步骤203计算得出的目标数据包括的用户行为发生时间与上述历史用户行为发生时间的差值,上述电子设备可以确定上述差值是否大于第一预设时间,如果是,则上述电子设备可以基于历史标识值,生成目标数据的标识值。其中,第一预设时间可以是在上述电子设备中预先设置的时间段(例如第一预设时间可以设置为3分钟)。
在本实施例中,上述电子设备可以对历史标识值进行处理,以生成目标数据的标识值,使生成的目标数据的标识值与已经存储在存储区域内的标识值不同。例如,上述电子设备将历史标识值与预设值进行相加、相乘等运算,生成目标数据的标识值。
在本实施例的一些可选的实现方式中,上述电子设备可以将上述历史标识值与预设值相加,生成目标数据的标识值。示例性的,假设存储的历史标识值为“201701021020”,预设值为“1”,在接收到的目标数据包括的用户行为发生时间与历史用户行为发生时间的差值大于上述第一预设时间(例如3分钟)的情况下,则将历史标识值与预设值“1”相加后,得到的目标数据的标识值为“201701021021”。为了避免将历史标识值与预设值相加后大于接收到的目标数据包括的用户行为发生时间,造成生成的目标数据的标识值与存储区域内已经存储的目标数据的标识值可能相同,通常设置的上述预设值小于第一预设时间的时间单位对应的数值。
上述电子设备还可以将历史标识值与不等于0或1的预设值相乘,得到目标数据的标识值;或者对历史标识值进行哈希运算,将获得的哈希值确定为目标数据的标识值。
步骤205,关联存储目标数据和目标数据的标识值至存储区域。
在本实施例中,上述电子设备可以将接收到的目标数据和生成的目标数据的标识值关联存储至上述存储区域。上述电子设备在执行完本步骤后,存储在上述存储区域内的目标数据均具有相应的标识值,并且,每个标识值可以对应至少一个目标数据。
在本实施例的一些可选的实现方式中,上述电子设备执行完步骤205之后,响应于确定当前时间与历史用户行为时间之差大于第二预设时间,即接收到目标数据后,在第二预设时间内没有接收到新的目标数据,则删除历史标识值和历史用户行为发生时间,其中,第二预设时间大于第一预设时间。例如,设置第一预设时间为3分钟,第二预设时间为10分钟,则接收到目标数据后十分钟内没有接收到新的目标数据,则删除保存的历史标识值和历史用户行为发生时间。
示例性的,表1是根据本实施例的用于存储数据的方法的存储的目标数据及标识值的一个示意性表格。如表1所示,上述电子设备将包括相同的来源终端的标识(终端的硬件序列号相同、终端的IP地址相同)的数据(点击流数据)存储在同一个存储区域中,设置的第一预设时间为3分钟,设置的与历史标识值(即最近一次接收并存储到相应的存储区域的目标数据的标识值)相加的预设值为1,表1中的目标数据的序号为按照上述电子设备接收目标数据的时间顺序排列的序号,目标数据的标识值由用户的点击时间的时间单位(年、月、日、时、分)对应的数值组合生成。
表1
本申请的上述实施例提供的方法通过对接收的目标数据进行分区域存储,并且基于存储区域中已经存储的历史目标数据的标识值和历史目标数据包括的用户行为发生时间,生成接收的目标数据的标识值,提高了存储目标数据的效率。
进一步参考图3,其示出了用于存储数据的方法的又一个实施例的流程300。该用于存储数据的方法的流程300,包括以下步骤:
步骤301,接收目标数据。
在本实施例中,在本实施例中,步骤301与图2对应实施例中的步骤201基本一致,这里不再赘述。
步骤302,根据来源终端的标识确定目标数据的存储区域。
在本实施例中,步骤302与图2对应实施例中的步骤202基本一致,这里不再赘述。
步骤303,确定存储区域内是否已保存历史用户行为发生时间和历史标识值。
在本实施例中,基于步骤302中确定的存储接收的目标数据的存储区域,上述电子设备首先确定在上述存储区域中是否已保存历史用户行为发生时间和历史标识值,如果确定已保存历史用户行为发生时间和历史标识值,则执行步骤3031,如果确定未保存历史用户行为发生时间和历史标识值,则执行步骤3032。
在本实施例中,上述历史用户行为发生时间可以为存储至上述存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间,上述历史标识值可以为上述历史用户行为发生时间所对应的历史目标数据的标识值,并且上述历史标识值和上述历史用户行为发生时间可以分别存储在上述存储区域内的预设的存储空间,以使上述电子设备能够在上述预设的存储空间内确定是否已保存历史用户行为发生时间和历史标识值。
步骤3031,响应于确定存储区域内已保存历史用户行为发生时间和历史标识值,计算目标数据包括的用户行为发生时间与历史用户行为发生时间的差值。
在本实施例中,上述电子设备响应于确定存储区域中已保存历史用户行为发生时间和历史标识值,上述电子设备可以计算目标数据包括的用户行为发生时间与历史用户行为发生时间的差值。
步骤3032,响应于确定存储区域内未保存历史用户行为发生时间和历史标识值,根据目标数据包括的用户行为发生时间生成目标数据的标识值。
在本实施例中,上述电子设备响应于确定存储区域内未保存历史用户行为发生时间和历史标识值,上述电子设备可以根据目标数据包括的用户行为发生时间生成目标数据的标识值。
在本实施例中,上述电子设备可以将目标数据包括的用户行为发生时间的各个计时单位所对应的数值组合为目标数据的标识值。通常,为了使根据目标数据包括的用户行为发生时间生成的目标数据的标识值与已经存储在存储区域内的标识值不同,上述电子设备可以在接收到目标数据后,提取接收到的目标数据包括的用户行为发生时间的各个计时单位所对应的数值(例如用户行为发生时间包括的年、月、日、时、分、秒等分别对应的数值),进一步将提取到的各个数值组合为接收到的目标数据的标识值,其中,上述电子设备可以将上述各个数值按预设的时间单位排列顺序组合为接收到的目标数据的标识值。
在本实施例中,上述电子设备还可以将提取的目标数据包括的用户行为发生时间的各个计时单位所对应的数值组合后,对组合后的数值进行处理以生成接收到的目标数据的标识值。例如对组合后的数值进行哈希运算以获得哈希值,进一步将获得的哈希值确定为接收到的目标数据的标识值。
示例性的,上述电子设备如果确定在上述存储区域中未保存历史用户行为发生时间和历史标识值,如果接收到的目标数据包括的用户行为发生时间为2017年1月2日10时20分,则提取并按年、月、日、时、分的顺序组合各时间单位对应的数值,得到接收到的目标数据的标识值为201701021020,或者按日、月、年、时、分的顺序组合各时间单位对应的数值,得到接收到的目标数据的标识值为020120171020。
需要说明的是,在本实施例中,上述电子设备是将提取到的各个时间单位对应的数值按预设的时间单位排列顺序组合为接收到的目标数据的标识值,在该思想下,使用其他方法获得目标数据的标识值,以使根据目标数据包括的用户行为发生时间生成的目标数据的标识值与已经存储在存储区域内的标识值不同的技术方案,同样在本发明的保护范围内。
步骤304,确定差值是否大于第一预设时间。
在本实施例中,基于步骤3031确定的目标数据包括的用户行为发生时间与历史用户行为发生时间的差值,判断该差值是否大于第一预设时间。如果是,则执行步骤3041,如果否,则执行步骤3042。其中,第一预设时间可以是在所述电子设备中预先设置的时间段。
步骤3041,响应于确定差值大于第一预设时间,基于历史标识值,生成目标数据的标识值。
在本实施例中,上述电子设备可以对历史标识值进行处理,以生成目标数据的标识值,使生成的目标数据的标识值与已经存储在存储区域内的标识值不同。例如,上述电子设备将历史标识值与预设值进行相加、相乘等运算,生成目标数据的标识值。上述电子设备还可以将历史标识值与不等于0或1的预设值相乘,得到目标数据的标识值;或者对历史标识值进行哈希运算,将获得的哈希值确定为目标数据的标识值。
步骤3042,响应于确定差值不大于第一预设时间,确定历史标识值作为目标数据的标识值。
在本实施例中,上述电子设备响应于确定差值不大于第一预设时间,可以进一步确定在存储区域中已保存的历史标识值作为目标数据的标识值。其中,差值不大于第一预设时间分为以下两种场景:
第一种场景,差值大于零,此场景下,上述电子设备接收的目标数据包括的用户行为发生时间晚于历史用户行为发生时间;
第二种场景,差值小于零,此场景下,由于数据传输过程中的延时,造成上述电子设备接收的目标数据包括的用户行为发生时间早于历史用户行为发生时间(即虽然接收的目标数据包括的用户行为发生时间较早,但上述电子设备接收到该目标数据的时间较晚)。
步骤305,关联存储目标数据和目标数据的标识值至存储区域。
在本实施例中,上述电子设备可以将接收到的目标数据和生成的目标数据的标识值关联存储至上述存储区域,并将目标数据的标识值确定为历史标识值,将目标数据包括的用户行为发生时间确定为历史用户行为发生时间。
在本实施例中,上述电子设备可以将存储区域中已存储的历史标识值替换为接收的目标数据的标识值,以使上述电子设备确定目标数据的标识值作为历史标识值;上述电子设备可以将存储区域中已存储的历史用户行为发生时间替换为接收的目标数据包括的用户行为发生时间,以使上述电子设备确定目标数据包括的用户行为发生时间作为历史用户行为发生时间。
从图3中可以看出,与图2对应的实施例相比,本实施例中的用于存储数据的方法的流程300突出了步骤3032、步骤3042和步骤305。由此,本实施例描述的方案更加全面,从而实现更全面的目标数据的存储。
进一步参考图4,作为对上述各图所示方法的实现,本申请提供了一种用于存储数据的装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图4所示,本实施例的用于存储数据的装置400包括:接收单元401,配置用于接收目标数据,其中,目标数据包括目标数据的来源终端所记录的用户行为发生时间和来源终端的标识;第一确定单元402,配置用于根据来源终端的标识确定目标数据的存储区域;计算单元403,配置用于响应于确定存储区域内已保存历史用户行为发生时间和历史标识值,计算目标数据包括的用户行为发生时间与历史用户行为发生时间的差值,其中,历史用户行为发生时间为存储至存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间,历史标识值为历史用户行为发生时间所对应的历史目标数据的标识值;生成单元404,配置用于响应于确定差值大于第一预设时间,则基于历史标识值,生成目标数据的标识值;存储单元405,配置用于关联存储目标数据和目标数据的标识值至存储区域。
在本实施例中,用于存储数据的装置400的接收单元401可以通过有线连接方式或者无线连接方式从用户利用其进行浏览的终端接收目标数据。其中,上述目标数据可以包括流数据,例如用户利用其进行浏览的终端进行网页浏览时产生的点击流数据或用户的移动终端所产生的地理位置数据等。
在本实施例中,上述目标数据还可以包括上述目标数据的来源终端所记录的用户行为发生时间和上述来源终端的标识。其中,上述用户行为发生时间可以是用户所使用的终端响应于用户的触发动作而产生相应数据的时间。
在本实施例中,基于接收单元401接收的目标数据,上述第一确定单元402可以根据目标数据所包含的来源终端的标识确定目标数据的存储区域。上述第一确定单元402可以首先解析出接收的目标数据包含的目标数据的来源终端的标识,然后将包含有相同的来源终端的标识的各个目标数据存储至同一存储区域。或者,上述第一确定单元402将所包括的来源终端标识处于预设字段内(例如IP地址处于同一网段)的目标数据存储至同一存储区域。
在本实施例中,基于第一确定单元402确定的存储目标数据的存储区域,上述计算单元403首先确定在上述存储区域中是否已保存历史用户行为发生时间和历史标识值,如果确定已保存历史用户行为发生时间和历史标识值,则计算目标数据包括的用户行为发生时间与上述历史用户行为发生时间的差值。
在本实施例中,上述历史用户行为发生时间可以为存储至上述存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间。上述历史标识值可以为上述历史用户行为发生时间所对应的历史目标数据的标识值。
在本实施例中,基于计算单元403计算得出的目标数据包括的用户行为发生时间与上述历史用户行为发生时间的差值,上述生成单元404可以确定上述差值是否大于第一预设时间,如果是,则上述电子设备可以基于历史标识值,生成目标数据的标识值。其中,第一预设时间可以是在上述电子设备中预先设置的时间段(例如第一预设时间可以设置为3分钟)。
上述生成单元404电子设备可以对历史标识值进行处理,以生成目标数据的标识值,使生成的目标数据的标识值与已经存储在存储区域内的标识值不同。例如,上述生成单元404将历史标识值与预设值进行相加、相乘等运算,生成目标数据的标识值。
在本实施例中,存储单元405可以将接收到的目标数据和生成的目标数据的标识值关联存储至上述存储区域。上述存储单元405在执行完本步骤后,存储在上述存储区域内的目标数据均具有相应的标识值,并且,每个标识值可以对应至少一个目标数据。
在本实施例的一些可选的实现方式中,上述确定单元可以进一步配置用于:响应于确定存储区域内未保存历史标识值和历史用户行为发生时间,则根据目标数据包括的用户行为发生时间生成目标数据的标识值,关联存储目标数据和所生成的目标数据的标识值至存储区域。
在本实施例的一些可选的实现方式中,上述确定单元可以进一步配置用于:将目标数据包括的用户行为发生时间的各个计时单位所对应的数值组合为目标数据的标识值。
在本实施例的一些可选的实现方式中,上述用于存储数据的装置400还可以包括:第二确定单元,配置用于响应于确定差值小于等于第一预设时间,则确定历史标识值作为目标数据的标识值。
在本实施例的一些可选的实现方式中,上述用于存储数据的装置400还可以包括:删除单元,配置用于响应于确定当前时间与历史用户行为时间之差大于第二预设时间,则删除历史标识值和历史用户行为发生时间,其中第二预设时间大于第一预设时间。
在本实施例的一些可选的实现方式中,上述生成单元404可以进一步配置用于:将历史标识值与预设值相加,生成目标数据的标识值。
本申请的上述实施例提供的装置通过对接收的目标数据进行分区域存储,并且基于存储区域中已经存储的历史目标数据的标识值和历史目标数据包括的用户行为发生时间,生成接收的目标数据的标识值,提高了存储目标数据的效率。
下面参考图5,其示出了适于用来实现本申请实施例的服务器的计算机系统500的结构示意图。图5示出的服务器仅仅是一个示例,不应对本申请实施例的功能和使用范围带来任何限制。
如图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:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分507;包括硬盘等的存储部分508;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分509。通信部分509经由诸如因特网的网络执行通信处理。驱动器510也根据需要连接至I/O接口505。可拆卸介质511,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器510上,以便于从其上读出的计算机程序根据需要被安装入存储部分508。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分509从网络上被下载和安装,和/或从可拆卸介质511被安装。在该计算机程序被中央处理单元(CPU)501执行时,执行本申请的方法中限定的上述功能。
需要说明的是,本申请所述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本申请中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本申请中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本申请实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括接收单元、第一确定单元、计算单元、生成单元和存储单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,接收单元还可以被描述为“接收目标数据的单元”。
作为另一方面,本申请还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的服务器中所包含的;也可以是单独存在,而未装配入该服务器中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该服务器执行时,使得该服务器:接收目标数据,其中,所述目标数据包括所述目标数据的来源终端所记录的用户行为发生时间和所述来源终端的标识;根据所述来源终端的标识确定所述目标数据的存储区域;响应于确定所述存储区域内已保存历史用户行为发生时间和历史标识值,计算所述目标数据包括的用户行为发生时间与所述历史用户行为发生时间的差值,其中,所述历史用户行为发生时间为存储至所述存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间,所述历史标识值为所述历史用户行为发生时间所对应的历史目标数据的标识值;响应于确定所述差值大于第一预设时间,则基于所述历史标识值,生成所述目标数据的标识值;关联存储所述目标数据和所述目标数据的标识值至所述存储区域。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
Claims (14)
1.一种用于存储数据的方法,其特征在于,所述方法包括:
接收目标数据,其中,所述目标数据包括所述目标数据的来源终端所记录的用户行为发生时间和所述来源终端的标识;
根据所述来源终端的标识确定所述目标数据的存储区域;
响应于确定所述存储区域内已保存历史用户行为发生时间和历史标识值,计算所述目标数据包括的用户行为发生时间与所述历史用户行为发生时间的差值,其中,所述历史用户行为发生时间为存储至所述存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间,所述历史标识值为所述历史用户行为发生时间所对应的历史目标数据的标识值;
响应于确定所述差值大于第一预设时间,则基于所述历史标识值,生成所述目标数据的标识值;
关联存储所述目标数据和所述目标数据的标识值至所述存储区域。
2.根据权利要求1所述的方法,其特征在于,所述根据所述来源终端的标识确定所述目标数据的存储区域之后,所述方法还包括:
响应于确定所述存储区域内未保存所述历史标识值和所述历史用户行为发生时间,则根据所述目标数据包括的用户行为发生时间生成所述目标数据的标识值,关联存储所述目标数据和所生成的所述目标数据的标识值至所述存储区域。
3.根据权利要求2所述的方法,其特征在于,所述根据所述目标数据包括的用户行为发生时间生成所述目标数据的标识值包括:
将所述目标数据包括的用户行为发生时间的各个计时单位所对应的数值组合为所述目标数据的标识值。
4.根据权利要求1所述的方法,其特征在于,在所述计算所述目标数据包括的用户行为发生时间与所述历史用户行为发生时间的差值之后,所述方法还包括:
响应于确定所述差值小于等于所述第一预设时间,则确定所述历史标识值作为所述目标数据的标识值。
5.根据权利要求1所述的方法,其特征在于,在所述关联存储所述目标数据和所述目标数据的标识值至所述存储区域之后,所述方法还包括:
响应于确定当前时间与所述历史用户行为时间之差大于第二预设时间,则删除所述历史标识值和所述历史用户行为发生时间,其中所述第二预设时间大于所述第一预设时间。
6.根据权利要求1-5之一所述的方法,其特征在于,所述基于所述历史标识值,生成所述目标数据的标识值包括:
将所述历史标识值与预设值相加,生成所述目标数据的标识值。
7.一种用于存储数据的装置,其特征在于,所述装置包括:
接收单元,配置用于接收目标数据,其中,所述目标数据包括所述目标数据的来源终端所记录的用户行为发生时间和所述来源终端的标识;
第一确定单元,配置用于根据所述来源终端的标识确定所述目标数据的存储区域;
计算单元,配置用于响应于确定所述存储区域内已保存历史用户行为发生时间和历史标识值,计算所述目标数据包括的用户行为发生时间与所述历史用户行为发生时间的差值,其中,所述历史用户行为发生时间为存储至所述存储区域时的时间距离当前时间最近的历史目标数据所包括的用户行为发生时间,所述历史标识值为所述历史用户行为发生时间所对应的历史目标数据的标识值;
生成单元,配置用于响应于确定所述差值大于第一预设时间,则基于所述历史标识值,生成所述目标数据的标识值;
存储单元,配置用于关联存储所述目标数据和所述目标数据的标识值至所述存储区域。
8.根据权利要求7所述的装置,其特征在于,所述确定单元进一步配置用于:
响应于确定所述存储区域内未保存所述历史标识值和所述历史用户行为发生时间,则根据所述目标数据包括的用户行为发生时间生成所述目标数据的标识值,关联存储所述目标数据和所生成的所述目标数据的标识值至所述存储区域。
9.根据权利要求8所述的装置,其特征在于,所述确定单元进一步配置用于:
将所述目标数据包括的用户行为发生时间的各个计时单位所对应的数值组合为所述目标数据的标识值。
10.根据权利要求7所述的装置,其特征在于,所述装置还包括:
第二确定单元,配置用于响应于确定所述差值小于等于所述第一预设时间,则确定所述历史标识值作为所述目标数据的标识值。
11.根据权利要求7所述的装置,其特征在于,所述装置还包括:
删除单元,配置用于响应于确定当前时间与所述历史用户行为时间之差大于第二预设时间,则删除所述历史标识值和所述历史用户行为发生时间,其中所述第二预设时间大于所述第一预设时间。
12.根据权利要求7-11之一所述的装置,其特征在于,所述生成单元进一步配置用于:
将所述历史标识值与预设值相加,生成所述目标数据的标识值。
13.一种服务器,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-6中任一所述的方法。
14.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-6中任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710828770.9A CN110019352B (zh) | 2017-09-14 | 2017-09-14 | 用于存储数据的方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710828770.9A CN110019352B (zh) | 2017-09-14 | 2017-09-14 | 用于存储数据的方法和装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110019352A CN110019352A (zh) | 2019-07-16 |
CN110019352B true CN110019352B (zh) | 2021-09-03 |
Family
ID=67186277
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710828770.9A Active CN110019352B (zh) | 2017-09-14 | 2017-09-14 | 用于存储数据的方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110019352B (zh) |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103488727A (zh) * | 2013-09-16 | 2014-01-01 | 河海大学 | 基于周期对数的二维时序数据存储和查询方法 |
CN104598557A (zh) * | 2015-01-05 | 2015-05-06 | 华为技术有限公司 | 数据栅格化、用户行为分析的方法和装置 |
CN104834657A (zh) * | 2014-08-27 | 2015-08-12 | 腾讯科技(北京)有限公司 | 用户行为分析方法及服务器 |
CN105100295A (zh) * | 2014-05-21 | 2015-11-25 | 北京秒针信息咨询有限公司 | 一种识别独立用户的方法和装置 |
CN105242882A (zh) * | 2015-10-13 | 2016-01-13 | 东方网力科技股份有限公司 | 时序数据的帧存储方法及装置、时序数据查询方法及装置 |
CN105516938A (zh) * | 2015-12-08 | 2016-04-20 | 北京奇虎科技有限公司 | 一种通信标识标记信息的处理方法及装置 |
CN106648446A (zh) * | 2015-10-30 | 2017-05-10 | 阿里巴巴集团控股有限公司 | 一种用于时序数据的存储方法、装置及电子设备 |
CN106682077A (zh) * | 2016-11-18 | 2017-05-17 | 山东鲁能软件技术有限公司 | 一种基于Hadoop技术的海量时序数据存储实现方法 |
CN106973125A (zh) * | 2017-03-16 | 2017-07-21 | 中国联合网络通信集团有限公司 | 域名解析实现方法及装置 |
Family Cites Families (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7698511B2 (en) * | 2005-05-19 | 2010-04-13 | Honeywell International Inc. | Interface for writing to memories having different write times |
US8234240B2 (en) * | 2007-04-26 | 2012-07-31 | Microsoft Corporation | Framework for providing metrics from any datasource |
CN101420603B (zh) * | 2008-09-05 | 2011-10-26 | 中兴通讯股份有限公司 | 一种分片存储实现媒体分发、定位的方法及其流媒体系统 |
US9064116B2 (en) * | 2010-11-08 | 2015-06-23 | Intel Corporation | Techniques for security management provisioning at a data storage device |
EP2728829A1 (en) * | 2012-10-30 | 2014-05-07 | Thomson Licensing | Method for downloading content according to communication parameters, and associated content receiver |
JP2014194647A (ja) * | 2013-03-28 | 2014-10-09 | Murata Mach Ltd | 情報処理装置、情報処理方法、及び、プログラム |
CN104298675B (zh) * | 2013-07-18 | 2017-06-16 | 国际商业机器公司 | 用于缓存管理的方法和装置 |
CN105989048B (zh) * | 2015-02-05 | 2019-12-24 | 浙江大华技术股份有限公司 | 一种数据记录处理方法、设备及系统 |
CN105260404B (zh) * | 2015-09-22 | 2019-03-26 | 北京百度网讯科技有限公司 | 存储时间序列数据的方法和装置 |
CN105426408B (zh) * | 2015-11-02 | 2019-03-08 | 北京锐安科技有限公司 | 一种多索引的数据处理方法及装置 |
CN107103490B (zh) * | 2017-04-11 | 2021-07-09 | 华为机器有限公司 | 一种数据处理方法、网络服务器及终端 |
-
2017
- 2017-09-14 CN CN201710828770.9A patent/CN110019352B/zh active Active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103488727A (zh) * | 2013-09-16 | 2014-01-01 | 河海大学 | 基于周期对数的二维时序数据存储和查询方法 |
CN105100295A (zh) * | 2014-05-21 | 2015-11-25 | 北京秒针信息咨询有限公司 | 一种识别独立用户的方法和装置 |
CN104834657A (zh) * | 2014-08-27 | 2015-08-12 | 腾讯科技(北京)有限公司 | 用户行为分析方法及服务器 |
CN104598557A (zh) * | 2015-01-05 | 2015-05-06 | 华为技术有限公司 | 数据栅格化、用户行为分析的方法和装置 |
CN105242882A (zh) * | 2015-10-13 | 2016-01-13 | 东方网力科技股份有限公司 | 时序数据的帧存储方法及装置、时序数据查询方法及装置 |
CN106648446A (zh) * | 2015-10-30 | 2017-05-10 | 阿里巴巴集团控股有限公司 | 一种用于时序数据的存储方法、装置及电子设备 |
CN105516938A (zh) * | 2015-12-08 | 2016-04-20 | 北京奇虎科技有限公司 | 一种通信标识标记信息的处理方法及装置 |
CN106682077A (zh) * | 2016-11-18 | 2017-05-17 | 山东鲁能软件技术有限公司 | 一种基于Hadoop技术的海量时序数据存储实现方法 |
CN106973125A (zh) * | 2017-03-16 | 2017-07-21 | 中国联合网络通信集团有限公司 | 域名解析实现方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN110019352A (zh) | 2019-07-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11038975B2 (en) | Information pushing method and device | |
CN107944481B (zh) | 用于生成信息的方法和装置 | |
CN111046237B (zh) | 用户行为数据处理方法、装置、电子设备及可读介质 | |
US11244153B2 (en) | Method and apparatus for processing information | |
CN108595448B (zh) | 信息推送方法和装置 | |
CN107908662B (zh) | 搜索系统的实现方法和实现装置 | |
CN110515968B (zh) | 用于输出信息的方法和装置 | |
CN108810047B (zh) | 用于确定信息推送准确率的方法、装置及服务器 | |
US11800201B2 (en) | Method and apparatus for outputting information | |
CN112835904A (zh) | 一种数据处理方法和数据处理装置 | |
CN115423030A (zh) | 一种设备识别的方法和装置 | |
CN108011936B (zh) | 用于推送信息的方法和装置 | |
CN113761565B (zh) | 数据脱敏方法和装置 | |
CN110807095A (zh) | 一种物品匹配方法和装置 | |
CN113312553A (zh) | 一种用户标签的确定方法和装置 | |
CN110300222B (zh) | 一种短信显示方法、系统、终端设备及计算机可读存储介质 | |
CN109087097B (zh) | 一种更新链码同一标识的方法和装置 | |
CN111597439A (zh) | 信息处理方法、装置和电子设备 | |
CN110019352B (zh) | 用于存储数据的方法和装置 | |
CN110557351A (zh) | 用于生成信息的方法和装置 | |
CN115563134A (zh) | 一种交互方法、装置、电子设备、计算机可读介质 | |
CN110781523B (zh) | 用于处理信息的方法和装置 | |
CN112035581B (zh) | 基于模型的任务处理方法、装置、设备和介质 | |
CN113590447A (zh) | 埋点处理方法和装置 | |
CN112799863A (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 |