CN107133350A - 基于搜索引擎的数据更新方法、移动终端及存储介质 - Google Patents

基于搜索引擎的数据更新方法、移动终端及存储介质 Download PDF

Info

Publication number
CN107133350A
CN107133350A CN201710377246.4A CN201710377246A CN107133350A CN 107133350 A CN107133350 A CN 107133350A CN 201710377246 A CN201710377246 A CN 201710377246A CN 107133350 A CN107133350 A CN 107133350A
Authority
CN
China
Prior art keywords
data
index
search engine
indexed
updating method
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.)
Pending
Application number
CN201710377246.4A
Other languages
English (en)
Inventor
李悦
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nubia Technology Co Ltd
Original Assignee
Nubia Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Nubia Technology Co Ltd filed Critical Nubia Technology Co Ltd
Priority to CN201710377246.4A priority Critical patent/CN107133350A/zh
Publication of CN107133350A publication Critical patent/CN107133350A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • G06F16/2379Updates performed during online database operations; commit processing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • G06F16/2228Indexing structures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/28Databases characterised by their database models, e.g. relational or object models
    • G06F16/284Relational databases

Abstract

本申请公开了一种基于搜索引擎的数据更新方法、移动终端及存储介质。该方法包括以下步骤:监测更新搜索引擎中第一数据的指令;判断所述第一数据是否指向与所述第一数据对应的第一索引;若是,则创建第二索引;在所述第二索引中导入所述第一数据的原始数据和更新数据,以对所述第一数据进行更新。本申请的基于搜索引擎的数据更新方法、移动终端及存储介质可以保证在处理最新数据的同时,对外服务无中断,提高用户的使用体验。

Description

基于搜索引擎的数据更新方法、移动终端及存储介质
技术领域
本申请涉及搜索引擎技术领域,尤其涉及基于搜索引擎的数据更新方法、移动终端及存储介质。
背景技术
随着大数据时代的发展,搜索引擎中具有海量的数据,在对外提供搜索服务时,文档数据需要适时的同业务数据全量对接同步,建立索引后,才能保证最新的文档数据能够被检索到。
传统网站在进行数据库升级时,常常会提前向用户发布公告,例如:将在凌晨期间进行网站升级,或者数据库升级,期间服务将中断,无法提供服务。通过这样的公告以告知用户合理安排使用网站的时间,避免因更新网站而影响使用,然而,这对用户来说是非常不好的体验过程。
发明内容
本申请的主要目的在于提出一种基于搜索引擎的数据更新方法、移动终端及存储介质,旨在解决更新搜索引擎数据的同时,不影响用户正常使用搜索引擎,提高用户体验。
为实现上述目的,本申请提供的一种基于搜索引擎的数据更新方法,所述方法包括步骤:
监测更新搜索引擎中第一数据的指令;
判断所述第一数据是否指向与所述第一数据对应的第一索引;
若是,则创建第二索引;
在所述第二索引中导入所述第一数据的原始数据和更新数据,以对所述第一数据进行更新。
可选的,所述方法还包括:当对所述第一数据更新完成时,将所述第一数据的指向切换至所述第二索引。
可选的,所述方法还包括:
移除所述第一数据与所述第一索引的映射关系;
删除所述第一索引中的所述第一数据。
可选的,所述方法还包括:
接收查询第一数据的请求;
获取所述第一数据当前所指向的索引;
提取所述索引中的所述第一数据。
可选的,当判断所述第一数据没有指向与所述第一数据对应的第一索引时,所述方法还包括:
判断所述第一数据是否指向第二索引;
若是,则创建所述第一索引;
在所述第一索引中导入所述第一数据,以对所述第一数据进行更新;
将所述第一数据的指向切换至所述第一索引。
可选的,判断所述第一数据是否指向与所述第一数据对应的第一索引,包括:
判断是否存在所述第一数据;
若是,则获取所述第一数据所指向的索引名称;
判断所述索引名称是否是所述第一索引。
可选的,当判断不存在所述第一数据时,所述方法还包括:
判断是否存在所述第一索引;
若是,则创建第三索引;
在所述第三索引中导入更新后的第一数据;
将所述更新后的第一数据指向所述第三索引。
可选的,当判断不存在所述第一索引时,所述方法还包括:
创建所述第一索引;
在所述第三索引中导入更新后的第一数据;
将所述更新后的第一数据指向所述第三索引。
此外,为实现上述目的,本申请还提出一种移动终端,所述移动终端包括处理器以及存储器,所述处理器用于执行存储器中存储的基于搜索引擎的数据更新程序,以实现上述的方法。
此外,为实现上述目的,本申请还提出一种计算机可读存储介质,所述计算机可读存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述的方法。
本申请提出的基于搜索引擎的数据更新方法、移动终端及存储介质,通过检测监测更新搜索引擎中第一数据的指令,当判断第一数据指向与第一数据对应的第一索引时,创建第二索引,并在第二索引中导入第一数据的原始数据和更新数据,以实现对第一数据的更新,可以保证在处理最新数据的同时,对外服务无中断,提高用户的体验。
附图说明
图1为实现本申请各个实施例一个可选的移动终端的硬件结构示意图;
图2为如图1所示的移动终端的通信网络系统示意图;
图3为本申请第一实施例提出的基于搜索引擎的数据更新方法的流程示意图;
图4为本申请第一实施例提出的另一基于搜索引擎的数据更新方法的流程示意图;
图5为本申请第一实施例提出的另一基于搜索引擎的数据更新方法的流程示意图;
图6为本申请第二实施例提出的基于搜索引擎的数据更新方法的流程示意图;
图7为本申请第三实施例提出的基于搜索引擎的数据更新方法的流程示意图;
图8为本申请第四实施例中移动终端的结构框图。
本申请目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本申请的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本申请中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本申请的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本申请各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本申请实施例,下面对本申请的移动终端所基于的通信网络系统进行描述。
请参阅图2,图2为本申请实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的LTE系统,该LTE系统包括依次通讯连接的UE(UserEquipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving GateWay,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子系统)或其它IP业务等。
虽然上述以LTE系统为例进行了介绍,但本领域技术人员应当知晓,本申请不仅仅适用于LTE系统,也可以适用于其他无线通信系统,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络系统等,此处不做限定。
基于上述移动终端硬件结构以及通信网络系统,提出本申请方法各个实施例。
第一实施例
如图3所示,本申请一实施例提供一种基于搜索引擎的数据更新方法,所述方法包括步骤:
步骤301,监测更新搜索引擎中第一数据的指令;
步骤302,判断所述第一数据是否指向与所述第一数据对应的第一索引;若是,则进入步骤303;
步骤303,创建第二索引;
步骤304,在所述第二索引中导入所述第一数据的原始数据和更新数据,以对所述第一数据进行更新。
具体的,在步骤301中,搜索引擎中具有数据库,数据库中包括多个索引库,每个索引库对应一个索引名称,以存储不同索引名称的数据,索引名称可以是:第一数据、第二数据等。
本领域技术人员可以理解的是,在步骤301之前或者之后,都可以随时接收用户输入查询第一数据的指令,该指令代表查询第一数据的信息,即使程序没有完成对第一数据的更新,可以调取索引库中与第一数据对应的索引库中的当前数据,并将搜搜结果返回给用户。也就是说,本申请实施例可以实现更新搜索引擎中的数据库与接收用户查询指令同步进行。
进一步的,在数据库或者索引库中,对外提供搜索服务时,统一以别名(Alias)提供搜索服务,也就是说,用户在搜索引擎中使用带搜索的Alias别名进行查询,例如:AliasA、AliasB等。
预先在索引库和Alias设置映射关系,在程序一开始执行导入数据完毕时,就可以将该Alias名称和索引表名称的映射关系存储下来,索引表名称以第一索引(简称:AV)、第二索引(简称:BV)来表示。存储的方法可以采用:可持久化到硬盘文件,或者数据库文件等等。例如,存储的内容可以是:Alias A对应AV1,AliasB对应BV1的形式。
以搜索服务器Elastic Search(简称:ES)为例,ES自动存储索引表与其别名的映射关系,并以java map的形式进行存储和查找。这里可以采用现有技术来实现,本实施例不再赘述。
在步骤302中,根据更新第一数据的指令,先判断该第一数据是否指向第一索引,其中,第一索引是预先在ES中设置的与第一数据具有映射关系的索引。当判断第一数据指向第一索引时,说明第一索引正在使用的状态,则进入步骤303,即创建第二索引。
在步骤304中,当创建第二索引之后,在第二索引中导入第一数据的原始数据和更新数据,以对第一数据进行更新。此时,第一索引和第二索引中都包括第一数据的原始数据。这样一来,一旦用户发起查询第一数据的指令时,就可以从第一索引中提取第一数据,同时在第二索引中更新第一数据,进而不影响用户的正常使用,提高了用户的使用体验。
进一步的,新建索引库的过程是根据数据存储系统采用的不同而有不同的方法,例如,在MYSQL数据库中,使用create database V2库就可以完成新建索引库的过程。在本申请实施例中,以Elastic Search服务器为例,新建库的方法就是新建一张索引表,具体是使用es的jdbc插件执行相应的脚本就可以完成新建索引表。
可选的,在步骤304之后,如图4所示,所述方法还包括:
步骤401,当对所述第一数据更新完成时,将所述第一数据的指向切换至所述第二索引;
步骤402,移除所述第一数据与所述第一索引的映射关系;
步骤403,删除所述第一索引中的所述第一数据。
具体的,检测完成对第一数据的更新,则将第一数据的指向由第一索引切换至第二索引,同时,移除第一数据与第一索引的映射关系,并删除第一索引中的第一数据,从而节约了数据库的使用空间。当用户此时输入查询第一数据的指令时,则从第二索引中调取第一数据,也就是将第二索引中更新后的第一数据返回给用户。
在实施例中,由于切换索引的瞬时性,且对于用户在极短时间内的搜索结果容忍度较高,完全可以在下一个瞬时,正常通过别名搜索到第二索引中的数据,使用户察觉不到更新数据的过程,进而为用户带来顺畅的使用体验。
进一步的,本实施例中的步骤401和步骤402之间的顺序可以调换。
可选的,当步骤302的判断结果为否时,即:判断第一数据没有指向与所述第一数据对应的第一索引时,如图5所示,所述方法还包括:
步骤501,判断所述第一数据是否指向第二索引;若是,则进入步骤502;若否,则进入步骤505;
步骤502,创建第一索引;
步骤503,在所述第一索引中导入所述第一数据,以对所述第一数据进行更新;
步骤504,将所述第一数据的指向切换至所述第一索引;
步骤505,创建第一索引;
步骤506,在所述第一索引中导入第一数据的原始数据和更新数据;
步骤507,将更新后的第一数据指向所述第一索引。
具体的,当判断第一数据没有指向第一索引时,说明第一数据可能是在上一次更新数据之后,切换为指向了其他索引,进而再判断第一数据是否指向第二索引。当判断第一数据指向第二索引时,说明第二索引正在使用的状态,则进入步骤502,即创建第一索引,并在第一索引中导入第一数据,以对第一数据进行更新,当检测对第一数据更新完成时,将第一数据的指向切换至第一索引,相应的,移除第一数据与第二索引的映射关系并删除第二索引中的第一数据。
当判断第一数据没有指向第二索引时,说明第一数据既没有对应的第一索引也没有对应的第二索引,可以理解为索引库中没有第一数据,则需要创建第一索引,并将更新后的第一数据存入第一索引中,然后将更新后的第一数据指向第一索引,以便于用户下次查询第一数据时,从第一索引中提取更新后的第一数据。
也就是说,在本申请实施例中,当判断第一数据指向第一索引,则创建第二索引并在第二索引中导入第一数据的原始数据和更新后的数据,当判断第一数据指向第二索引,则创建第一索引并在第一索引中导入第一数据的原始数据和更新后的数据。
为了使本申请实施例的基于搜索引擎的数据更新方法更加清楚易懂,以如下示例加以说明:
示例一:
步骤1,监测更新搜索引擎中Alias A的指令一;
步骤2,判断Alias A指向AV1;
步骤3,创建BV1;
步骤4,在BV1中导入Alias A的原始数据和更新数据,并将Alias A的指向切换至BV1;
步骤5,解除Alias A与AV1的关系,以及删除AV1中Alias A的数据;
步骤6,监测更新搜索引擎中Alias A的指令二;
步骤7,判断Alias A指向BV1;
步骤8,创建AV1;
步骤9,在AV1中导入Alias A的第一次更新数据和第二次更新数据,并将Alias A的指向切换至AV1;
步骤10,解除Alias A与BV1的关系,以及删除BV1中Alias A的数据。
本申请实施例的基于搜索引擎的数据更新方法,通过检测监测更新搜索引擎中第一数据的指令,当判断第一数据指向与第一数据对应的第一索引时,创建第二索引,并在第二索引中导入第一数据的原始数据和更新数据,以实现对第一数据的更新,可以保证在处理最新数据的同时,对外服务无中断,并且能在无需修改程序对外接口的情况下,切换Alias指向完成用户流量的导向。
第二实施例
如图6所示,本申请另一实施例的基于搜索引擎的数据更新方法。所述基于搜索引擎的数据更新方法是在第一实施例的基础上提出的,该方法包括如下步骤:
步骤601,监测更新搜索引擎中第一数据的指令;
步骤602,判断是否存在所述第一数据;若是,则进入步骤603,若否,则进入步骤609;
步骤603,获取所述第一数据所指向的索引名称;
步骤604,判断所述索引名称是否是所述第一索引,若是,则进入步骤605;若否,则进入步骤607;
步骤605,创建第二索引;
步骤606,在所述第二索引中导入所述第一数据的原始数据和更新数据,以对所述第一数据进行更新;
步骤607,当判断存在第二索引时,创建第一索引,在第一索引中导入第一数据的原始数据和更新数据,并将第一数据的指向切换至所述第一索引;
步骤608,当判断不存在第二索引时,创建第一索引,在第一索引中导入第一数据的原始数据和更新数据,并将第一数据的指向所述第一索引;
步骤609,判断是否存在所述第一索引;若是,则进入步骤610;若否,则进入步骤613;
步骤610,创建第三索引;
步骤611,在所述第三索引中导入第一数据的原始数据和更新数据;
步骤612,将所述更新后的第一数据指向所述第三索引;
步骤613,创建第一索引;
步骤614,在所述第一索引中导入更新后的第一数据;
步骤615,将第一数据指向第一索引。
本领域技术人员可以理解的是,每次在重新指向新的索引之后,都要移除数据别名与之前索引表的映射关系,并删除之前索引表中的数据,以节约空间占用率,本申请不再一一赘述。
本申请实施例的基于搜索引擎的数据更新方法,进一步细化了判断第一数据是否指向第一数据对应的第一索引的过程,进而完善了数据更新方法,以给用户带来更顺畅的体验。
第三实施例
如图7所示,本申请另一实施例的基于搜索引擎的数据更新方法。所述基于搜索引擎的数据更新方法是在第一实施例的基础上提出的,区别仅在于,该方法还包括如下步骤:
步骤701,接收查询第一数据的请求;
步骤702,获取所述第一数据当前所指向的索引;
步骤703,提取所述索引中的所述第一数据。
具体的,在步骤701中,服务端收到请求,截取url获得第一数据,然后在本地中查找第一数据现在指向的是哪个索引表,然后以对应第一索引或者第二索引进行查询。也就是说,在ES中的查询,自动转发http请求到ES进行查询。
若在第二索引中更新完毕第一数据之前,接收到查询请求,则返回的是第一索引中的第一数据。若在第二索引中更新完毕第一数据之后,接收到查询请求,则返回的是第二索引中更新后的第一数据。使得切换索引的过程具有瞬时性,这对于用户在极短时间内的搜索结果容忍度较高,完全可以在下一个瞬时,正常通过别名搜索到第二索引中的数据,使用户察觉不到更新数据的过程,进而为用户带来顺畅的使用体验。
第四实施例
如图8所示,本申请另一实施例提供的移动终端,基于上述的实施例,移动终端包括处理器810以及存储器820;
处理器810用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
监测更新搜索引擎中第一数据的指令;
判断所述第一数据是否指向与所述第一数据对应的第一索引;若是,则创建第二索引;
在所述第二索引中导入所述第一数据的原始数据和更新数据,以对所述第一数据进行更新。
具体的,搜索引擎中具有数据库,数据库中包括多个索引库,每个索引库对应一个索引名称,以存储不同索引名称的数据,索引名称可以是:第一数据、第二数据等。
本领域技术人员可以理解的是,在监测更新搜索引擎中第一数据的指令之前或者之后,都可以随时接收用户输入查询第一数据的指令,该指令代表查询第一数据的信息,即使程序没有完成对第一数据的更新,可以调取索引库中与第一数据对应的索引库中的当前数据,并将搜搜结果返回给用户。也就是说,本申请实施例可以实现更新搜索引擎中的数据库与接收用户查询指令同步进行。
进一步的,在数据库或者索引库中,对外提供搜索服务时,统一以别名(Alias)提供搜索服务,也就是说,用户在搜索引擎中使用带搜索的Alias别名进行查询,例如:AliasA、AliasB等。
预先在索引库和Alias设置映射关系,在程序一开始执行导入数据完毕时,就可以将该Alias名称和索引表名称的映射关系存储下来,索引表名称以第一索引(简称:AV)、第二索引(简称:BV)来表示。存储的方法可以采用:可持久化到硬盘文件,或者数据库文件等等。例如,存储的内容可以是:Alias A对应AV1,AliasB对应BV1的形式。
以搜索服务器Elastic Search(简称:ES)为例,ES自动存储索引表与其别名的映射关系,并以java map的形式进行存储和查找。这里可以采用现有技术来实现,本实施例不再赘述。
可选的,根据更新第一数据的指令,先判断该第一数据是否指向第一索引,其中,第一索引是预先在ES中设置的与第一数据具有映射关系的索引。当判断第一数据指向第一索引时,说明第一索引正在使用的状态,则进入步骤303,即创建第二索引。
当创建第二索引之后,在第二索引中导入第一数据的原始数据和更新数据,以对第一数据进行更新。此时,第一索引和第二索引中都包括第一数据的原始数据。这样一来,一旦用户发起查询第一数据的指令时,就可以从第一索引中提取第一数据,同时在第二索引中更新第一数据,进而不影响用户的正常使用,提高了用户的使用体验。
进一步的,新建索引库的过程是根据数据存储系统采用的不同而有不同的方法,例如,在MYSQL数据库中,使用create database V2库就可以完成新建索引库的过程。在本申请实施例中,以Elastic Search服务器为例,新建库的方法就是新建一张索引表,具体是使用es的jdbc插件执行相应的脚本就可以完成新建索引表。
可选的,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
当对所述第一数据更新完成时,将所述第一数据的指向切换至所述第二索引;
移除所述第一数据与所述第一索引的映射关系;
删除所述第一索引中的所述第一数据。
具体的,检测完成对第一数据的更新,则将第一数据的指向由第一索引切换至第二索引,同时,移除第一数据与第一索引的映射关系,并删除第一索引中的第一数据,从而节约了数据库的使用空间。当用户此时输入查询第一数据的指令时,则从第二索引中调取第一数据,也就是将第二索引中更新后的第一数据返回给用户。
在实施例中,由于切换索引的瞬时性,且对于用户在极短时间内的搜索结果容忍度较高,完全可以在下一个瞬时,正常通过别名搜索到第二索引中的数据,使用户察觉不到更新数据的过程,进而为用户带来顺畅的使用体验。
可选的,当判断第一数据没有指向与所述第一数据对应的第一索引时,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
判断所述第一数据是否指向第二索引。
可选的,当判断第一数据指向第二索引时,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
创建所述第一索引;
在所述第一索引中导入所述第一数据,以对所述第一数据进行更新;
将所述第一数据的指向切换至所述第一索引。
可选的,当判断第一数据没有指向第二索引时,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
创建所述第一索引;
在所述第一索引中导入第一数据的原始数据和更新数据;
将更新后的第一数据指向所述第一索引。
具体的,当判断第一数据没有指向第一索引时,说明第一数据可能是在上一次更新数据之后,切换为指向了其他索引,进而再判断第一数据是否指向第二索引。当判断第一数据指向第二索引时,说明第二索引正在使用的状态,则创建第一索引,并在第一索引中导入第一数据,以对第一数据进行更新,当检测对第一数据更新完成时,将第一数据的指向切换至第一索引,相应的,移除第一数据与第二索引的映射关系并删除第二索引中的第一数据。
当判断第一数据没有指向第二索引时,说明第一数据既没有对应的第一索引也没有对应的第二索引,可以理解为索引库中没有第一数据,则需要创建第一索引,并将更新后的第一数据存入第一索引中,然后将更新后的第一数据指向第一索引,以便于用户下次查询第一数据时,从第一索引中提取更新后的第一数据。
也就是说,在本申请实施例中,当判断第一数据指向第一索引,则创建第二索引并在第二索引中导入第一数据的原始数据和更新后的数据,当判断第一数据指向第二索引,则创建第一索引并在第一索引中导入第一数据的原始数据和更新后的数据。
可选的,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
判断是否存在所述第一数据。
当判断存在第一数据时,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
获取所述第一数据所指向的索引名称;
判断所述索引名称是否是所述第一索引,若是,则创建第二索引,并在所述第二索引中导入所述第一数据的原始数据和更新数据,以对所述第一数据进行更新;若否,实现以下步骤:
当判断存在第二索引时,创建第一索引,在第一索引中导入第一数据的原始数据和更新数据,并将第一数据的指向切换至所述第一索引;
当判断不存在第二索引时,创建第一索引,在第一索引中导入第一数据的原始数据和更新数据,并将第一数据的指向所述第一索引。
当判断不存在第一数据时,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
判断是否存在所述第一索引;若是,则创建第三索引;
在所述第三索引中导入第一数据的原始数据和更新数据;
将所述更新后的第一数据指向所述第三索引;
若判断不存在第一索引,则实现以下步骤:
创建第一索引;
在所述第一索引中导入更新后的第一数据;
将第一数据指向第一索引。
本领域技术人员可以理解的是,每次在重新指向新的索引之后,都要移除数据别名与之前索引表的映射关系,并删除之前索引表中的数据,以节约空间占用率,本申请不再一一赘述。
通过细化了判断第一数据是否指向第一数据对应的第一索引的过程,进而完善了数据更新方法,以给用户带来更顺畅的体验。
可选的,处理器810还用于执行存储器820中存储的基于搜索引擎的数据更新程序,以实现以下步骤:
接收查询第一数据的请求;
获取所述第一数据当前所指向的索引;
提取所述索引中的所述第一数据。
具体的,服务端收到请求,截取url获得第一数据,然后在本地中查找第一数据现在指向的是哪个索引表,然后以对应第一索引或者第二索引进行查询。也就是说,在ES中的查询,自动转发http请求到ES进行查询。
若在第二索引中更新完毕第一数据之前,接收到查询请求,则返回的是第一索引中的第一数据。若在第二索引中更新完毕第一数据之后,接收到查询请求,则返回的是第二索引中更新后的第一数据。使得切换索引的过程具有瞬时性,这对于用户在极短时间内的搜索结果容忍度较高,完全可以在下一个瞬时,正常通过别名搜索到第二索引中的数据,使用户察觉不到更新数据的过程,进而为用户带来顺畅的使用体验。
为了使本申请实施例的基于搜索引擎的数据更新方法更加清楚易懂,以如下示例加以说明:
示例一:
步骤1,监测更新搜索引擎中Alias A的指令一;
步骤2,判断Alias A指向AV1;
步骤3,创建BV1;
步骤4,在BV1中导入Alias A的原始数据和更新数据,并将Alias A的指向切换至BV1;
步骤5,解除Alias A与AV1的关系,以及删除AV1中Alias A的数据;
步骤6,监测更新搜索引擎中Alias A的指令二;
步骤7,判断Alias A指向BV1;
步骤8,创建AV1;
步骤9,在AV1中导入Alias A的第一次更新数据和第二次更新数据,并将Alias A的指向切换至AV1;
步骤10,解除Alias A与BV1的关系,以及删除BV1中Alias A的数据。
本申请实施例的基于搜索引擎的移动终端,通过检测监测更新搜索引擎中第一数据的指令,当判断第一数据指向与第一数据对应的第一索引时,创建第二索引,并在第二索引中导入第一数据的原始数据和更新数据,以实现对第一数据的更新,可以保证在处理最新数据的同时,对外服务无中断,并且能在无需修改程序对外接口的情况下,切换Alias指向完成用户流量的导向。
第五实施例
本申请实施例还提供了一种计算机可读存储介质。这里的计算机可读存储介质存储有一个或者多个程序。其中,计算机可读存储介质可以包括易失性存储器,例如随机存取存储器;存储器也可以包括非易失性存储器,例如只读存储器、快闪存储器、硬盘或固态硬盘;存储器还可以包括上述种类的存储器的组合。当计算机可读存储介质中一个或者多个程序可被一个或者多个处理器执行,以实现上述第一实施例至第三实施例中任一实施例所提供的基于搜索引擎的数据更新方法。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本申请实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
上面结合附图对本申请的实施例进行了描述,但是本申请并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本申请的启示下,在不脱离本申请宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本申请的保护之内。

Claims (10)

1.一种基于搜索引擎的数据更新方法,其特征在于,所述方法包括步骤:
监测更新搜索引擎中第一数据的指令;
判断所述第一数据是否指向与所述第一数据对应的第一索引;
若是,则创建第二索引;
在所述第二索引中导入所述第一数据的原始数据和更新数据,以对所述第一数据进行更新。
2.根据权利要求1所述的基于搜索引擎的数据更新方法,其特征在于,所述方法还包括:当对所述第一数据更新完成时,将所述第一数据的指向切换至所述第二索引。
3.根据权利要求2所述的基于搜索引擎的数据更新方法,其特征在于,所述方法还包括:
移除所述第一数据与所述第一索引的映射关系;
删除所述第一索引中的所述第一数据。
4.根据权利要求1所述的基于搜索引擎的数据更新方法,其特征在于,所述方法还包括:
接收查询第一数据的请求;
获取所述第一数据当前所指向的索引;
提取所述索引中的所述第一数据。
5.根据权利要求1所述的基于搜索引擎的数据更新方法,其特征在于,当判断所述第一数据没有指向与所述第一数据对应的第一索引时,所述方法还包括:
判断所述第一数据是否指向第二索引;
若是,则创建所述第一索引;
在所述第一索引中导入所述第一数据,以对所述第一数据进行更新;
将所述第一数据的指向切换至所述第一索引。
6.根据权利要求1所述的基于搜索引擎的数据更新方法,其特征在于,判断所述第一数据是否指向与所述第一数据对应的第一索引,包括:
判断是否存在所述第一数据;
若是,则获取所述第一数据所指向的索引名称;
判断所述索引名称是否是所述第一索引。
7.根据权利要求6所述的基于搜索引擎的数据更新方法,其特征在于,当判断不存在所述第一数据时,所述方法还包括:
判断是否存在所述第一索引;
若是,则创建第三索引;
在所述第三索引中导入更新后的第一数据;
将所述更新后的第一数据指向所述第三索引。
8.根据权利要求7所述的基于搜索引擎的数据更新方法,其特征在于,当判断不存在所述第一索引时,所述方法还包括:
创建所述第一索引;
在所述第三索引中导入更新后的第一数据;
将所述更新后的第一数据指向所述第三索引。
9.一种移动终端,其特征在于,所述移动终端包括处理器以及存储器,所述处理器用于执行存储器中存储的基于搜索引擎的数据更新程序,以实现权利要求1-8任一项所述的方法。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现权利要求1-8任一项所述的方法。
CN201710377246.4A 2017-05-25 2017-05-25 基于搜索引擎的数据更新方法、移动终端及存储介质 Pending CN107133350A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710377246.4A CN107133350A (zh) 2017-05-25 2017-05-25 基于搜索引擎的数据更新方法、移动终端及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710377246.4A CN107133350A (zh) 2017-05-25 2017-05-25 基于搜索引擎的数据更新方法、移动终端及存储介质

Publications (1)

Publication Number Publication Date
CN107133350A true CN107133350A (zh) 2017-09-05

Family

ID=59732039

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710377246.4A Pending CN107133350A (zh) 2017-05-25 2017-05-25 基于搜索引擎的数据更新方法、移动终端及存储介质

Country Status (1)

Country Link
CN (1) CN107133350A (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109558408A (zh) * 2018-11-27 2019-04-02 北京微播视界科技有限公司 更新列表的方法、装置、电子设备及可读存储介质
CN110019200A (zh) * 2017-09-30 2019-07-16 阿里巴巴集团控股有限公司 一种索引的建立、使用方法及装置
CN112328695A (zh) * 2020-11-17 2021-02-05 中国平安财产保险股份有限公司 数据同步方法、装置、设备及存储介质
CN112579117A (zh) * 2019-09-30 2021-03-30 北京国双科技有限公司 数据升级方法及装置

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090106216A1 (en) * 2007-10-19 2009-04-23 Oracle International Corporation Push-model based index updating
CN102169507A (zh) * 2011-05-26 2011-08-31 厦门雅迅网络股份有限公司 一种分布式实时搜索引擎
CN103559301A (zh) * 2013-11-14 2014-02-05 华为技术有限公司 更新数据的方法、数据库触发器和搜索引擎
CN104598550A (zh) * 2014-12-31 2015-05-06 北京奇艺世纪科技有限公司 一种网络视频索引的更新方法和装置
CN106709042A (zh) * 2016-12-30 2017-05-24 北京小度互娱科技有限公司 索引更新方法及设备

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090106216A1 (en) * 2007-10-19 2009-04-23 Oracle International Corporation Push-model based index updating
CN102169507A (zh) * 2011-05-26 2011-08-31 厦门雅迅网络股份有限公司 一种分布式实时搜索引擎
CN103559301A (zh) * 2013-11-14 2014-02-05 华为技术有限公司 更新数据的方法、数据库触发器和搜索引擎
CN104598550A (zh) * 2014-12-31 2015-05-06 北京奇艺世纪科技有限公司 一种网络视频索引的更新方法和装置
CN106709042A (zh) * 2016-12-30 2017-05-24 北京小度互娱科技有限公司 索引更新方法及设备

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
既然2015: "Elasticsearch索引重建(Rebuild)", 《HTTPS://BLOG.CSDN.NET/CHANGONG28/ARTICLE/DETAILS/38491185》 *

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110019200A (zh) * 2017-09-30 2019-07-16 阿里巴巴集团控股有限公司 一种索引的建立、使用方法及装置
CN110019200B (zh) * 2017-09-30 2023-05-09 阿里巴巴集团控股有限公司 一种索引的建立、使用方法及装置
CN109558408A (zh) * 2018-11-27 2019-04-02 北京微播视界科技有限公司 更新列表的方法、装置、电子设备及可读存储介质
CN112579117A (zh) * 2019-09-30 2021-03-30 北京国双科技有限公司 数据升级方法及装置
CN112328695A (zh) * 2020-11-17 2021-02-05 中国平安财产保险股份有限公司 数据同步方法、装置、设备及存储介质

Similar Documents

Publication Publication Date Title
CN107330035A (zh) 一种数据库中操作日志同步方法、移动终端以及计算机可读存储介质
CN107967322A (zh) 文件分类显示方法、移动终端及计算机可读存储介质
CN107038245A (zh) 页面切换方法、移动终端及存储介质
CN107145385A (zh) 一种多任务界面显示方法、移动终端和计算机存储介质
CN107329682A (zh) 边缘交互方法及移动终端
CN107229390A (zh) 一种桌面图标排列方法、移动终端以及计算机可读存储介质
CN107729103A (zh) 一种主题切换方法、移动终端以及计算机存储介质
CN107239567A (zh) 一种目标景物的识别方法、设备及计算机可读存储介质
CN108241752A (zh) 照片显示方法、移动终端及计算机可读存储介质
CN107133350A (zh) 基于搜索引擎的数据更新方法、移动终端及存储介质
CN108021698A (zh) 存储文件的删除方法、装置和计算机存储介质
CN107483556A (zh) 一种远程配置方法、设备及计算机可读存储介质
CN110180181A (zh) 精彩时刻视频的截图方法、装置及计算机可读存储介质
CN107862217A (zh) 一种位置信息获取方法、移动终端以及计算机存储介质
CN109299039A (zh) 一种文件管理方法、设备及计算机可读存储介质
CN109460170A (zh) 屏幕扩展及交互方法、终端及计算机可读存储介质
CN107229410A (zh) 交互操作方法、移动终端及计算机可读存储介质
CN107135086A (zh) 一种广播推送方法及设备、计算机可读存储介质
CN109241079A (zh) 问题精确检索的方法、移动终端及计算机存储介质
CN107566608A (zh) 一种系统导航方法、设备及计算机可读存储介质
CN107656743A (zh) 一种应用的卸载方法、终端及可读存储介质
CN107608727A (zh) 一种应用程序的显示方法、移动终端及存储介质
CN107124708A (zh) 国际漫游服务的显示方法、装置、计算机可读存储介质
CN110069458A (zh) 一种删除安卓系统中无效资源的方法、设备及存储介质
CN108040172A (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
RJ01 Rejection of invention patent application after publication

Application publication date: 20170905

RJ01 Rejection of invention patent application after publication