一种数据查询的方法、服务器及终端的制作方法

文档序号:10655355阅读:378来源:国知局
一种数据查询的方法、服务器及终端的制作方法
【专利摘要】本发明公开了一种数据查询的方法,包括:服务器接收到终端的查询请求消息后,将所述查询请求消息中的多项待查询数据的信息发送给指定搜索服务器;接收所述指定搜索服务器返回的查询结果,将所述查询结果发送给所述终端。通过本方案不仅可以避免直接操作数据库,还可以提升传输效率。
【专利说明】
一种数据查询的方法、服务器及终端
技术领域
[0001]本申请涉及但不限于通信领域,尤指一种数据查询的方法、服务器及终端。
【背景技术】
[0002]在客户端与服务端交互的过程中,难免要对数据库进行查询,但当数据量多的时候,直接操作数据库会使得查询效率大大降低,不符合API (Applicat1n ProgrammingInterface,应用程序编程接口)追求高性能的特点。
[0003]相关技术采用了直接从数据库查询和多次从SolH搜索应用服务器)搜索引擎查询两种方案,后者虽然避免了直接对数据库的操作,但多次访问Solr搜索引擎也会导致性能降低的问题。

【发明内容】

[0004]本发明实施例提供了一种数据查询的方法、服务器及终端,不仅避免了对数据库的直接操作,还提高数据查询效率。
[0005]本发明实施例提供了一种业务服务器,包括:
[0006]第一传输模块,用于接收到终端的查询请求消后,将所述查询请求消息中的待查询数据的信息发送给指定搜索服务器;
[0007]第二传输模块,用于接收所述指定搜索服务器返回的查询结果,将所述查询结果发送给所述终端。
[0008]本实施例的业务服务器避免了对数据库的直接操作,还提高数据查询效率。
[0009]可选地,所述业务服务器还可以包括:
[0010]获取模块,用于从所述待查询数据中获取多项查询关键数据;
[0011]封装模块,用于将所述查询关键数据封装成查询列表,将所述查询列表发送给所述第一传输模块;
[0012]所述第一传输模块,用于将所述查询列表发送给指定搜索服务器。
[0013]本实施例的业务服务器仅将查询关键数据发给搜索服务器,只把有价值的字段传输给搜索服务器,可以减少传输冗余字段。
[0014]可选地,所述业务服务器还可以包括:
[0015]删除模块,用于将所述指定搜索服务器返回的所述查询结果中的指定字段删除,将删除后的所述查询结果发送给所述第二传输模块,由所述第二传输模块发送给所述终端。
[0016]本实施例中,业务服务器将返回给客户端的数据中,去掉不必要的字段,这样可以减少传输数据的大小。
[0017]可选地,所述业务服务器还可以包括:
[0018]封装模块,用于利用指定格式对所述查询结果进行封装,将封装后的查询结果发送给所述第二传输模块,由所述第二传输模块发送给所述终端。
[0019]本实施例的业务服务器对多项查询结果进行封装,一次性发送给终端,这样可以减少传输次数。
[0020]可选地,所述业务服务器还可以包括:
[0021 ]压缩模块,用于对所述指定搜索服务器返回的所述查询结果进行压缩处理,将压缩处理后的查询结果发送给所述第二传输模块,由所述第二传输模块发送给所述终端。
[0022]本实施例的所述业务服务器对查询结果进行压缩处理,这样可以减少传输时数据包的大小。
[0023]本发明实施例提供一种数据查询的方法,包括:
[0024]业务服务器接收到终端的查询请求消息后,将所述查询请求消息中的待查询数据的信息发送给指定搜索服务器;
[0025]所述业务服务器接收所述指定搜索服务器返回的查询结果,将所述查询结果发送给所述终端。
[0026]本实施例的方法避免了对数据库的直接操作,还提高数据查询效率。
[0027]可选地,所述业务服务器将所述查询请求消息中的待查询数据的信息发送给指定搜索服务器,包括:
[0028]所述业务服务器从所述待查询数据中获取多项查询关键数据,将所述查询关键数据封装成查询列表,将所述查询列表发送给所述指定搜索服务器。
[0029]本实施例的方法仅将查询关键数据发给搜索服务器,只把有价值的字段传输给搜索服务器,可以减少传输冗余字段。
[0030]可选地,所述业务服务器将所述查询结果发送给所述终端之前,还包括:
[0031]所述业务服务器将所述指定搜索服务器返回的所述查询结果中的指定字段删除。
[0032]本实施例中,业务服务器将返回给客户端的数据中,去掉不必要的字段,这样可以减少传输数据的大小。
[0033]可选地,所述业务服务器将所述查询结果发送给所述终端之前,还包括:
[0034]所述业务服务器利用指定格式对所述查询结果进行封装。
[0035]本实施例的业务服务器对多项查询结果进行封装,一次性发送给终端,这样可以减少传输次数。
[0036]可选地,所述指定格式包括:Java脚本对象表示法格式,该格式易于人的阅读和编写,同时也易于解析。
[0037]可选地,所述业务服务器将所述查询结果发送给所述终端之前,还包括:
[0038]所述业务服务器对所述查询结果进行压缩处理。
[0039]本实施例中,所述业务服务器对查询结果进行压缩处理,这样可以减少传输时数据包的大小。
[0040]本发明实施例还提供一种搜索服务器,包括:
[0041 ]接收模块,用于接收业务服务器发送的待查询数据的信息;
[0042]查询模块,用于根据所述待查询数据的信息进行查询;
[0043]发送模块,用于将查询结果一次性发送给所述业务服务器。
[0044]本实施例通过第三方搜索服务器查询数据,可以避免对数据库的直接操作。
[0045]可选地,所述搜索服务器还包括封装模块,
[0046]所述接收模块,接收所述业务服务器发送的多项待查询数据的信息包括:接收所述业务服务器发送的包括多项查询关键数据的查询列表;
[0047]所述查询模块,用于根据所述多项查询关键数据进行查询;
[0048]所述封装模块,用于将多项查询结果封装为查询结果列表;
[0049]所述发送模块,用于将所述查询结果列表发送给所述业务服务器。
[0050]本实施例中,搜索服务器接收多项查询请求,对多项查询结果进行封装,一次性发给业务服务器,可以减少传输次数。
[0051]可选地,所述搜索服务器还包括:
[0052]建立模块,用于建立索引和定时任务;
[0053]获取模块,用于根据所述定时任务定时从数据库中获取与所述索引相关的数据;
[0054]存储模块,用于保存所述获取模块获取的数据。
[0055]本实施例中,搜索服务器可以定时获取数据库中的相关数据,可以及时更新数据。
[0056]本发明实施例还提供一种数据查询的方法,包括:
[0057]搜索服务器接收业务服务器发送的待查询数据的信息;
[0058]所述搜索服务器根据所述待查询数据的信息进行查询;
[0059]所述搜索服务器将查询结果一次性发送给所述业务服务器。
[0060]本实施例的方法,通过第三方搜索服务器查询数据,可以避免对数据库的直接操作。
[0061]可选地,所述搜索服务器接收所述业务服务器发送的多项待查询数据的信息,包括:接收所述业务服务器发送的包括多项查询关键数据的查询列表;
[0062]所述搜索服务器根据所述多项查询关键数据进行查询,将多项查询结果封装为查询结果列表,将所述查询结果列表发送给所述业务服务器。
[0063]本实施例中,搜索服务器接收多项查询请求,对多项查询结果进行封装,一次性发给业务服务器,可以减少传输次数。
[0064]可选地,所述方法还包括:
[0065]所述搜索服务器建立索引和定时任务;
[0066]所述搜索服务器根据所述定时任务定时从数据库中获取与所述索引相关的数据,
并保存。
[0067]本实施例中,搜索服务器可以定时获取数据库中的相关数据,可以及时更新数据。
[0068]本发明实施例还提供一种终端,包括:
[0069]发送模块,用于向业务服务器发送查询请求消息,携带待查询数据的信息;
[0070]接收模块,用于接收所述业务服务器返回的查询结果。
[0071]可选地,所述终端还可包括:
[0072]封装模块,用于利用指定格式将多项待查询数据进行封装;
[0073]所述发送模块,用于通过所述查询请求消息将封装后的待查询数据发送给所述业务服务器。
[0074]本实施例的终端一次性向业务服务器发起查询多项数据的请求,可以减少传输次数。
[0075]本发明实施例还提供一种数据查询的方法,包括:
[0076]终端向业务服务器发送查询请求消息,携带待查询数据的信息;
[0077]所述终端接收所述业务服务器返回的查询结果。
[0078]可选地,所述终端向业务服务器发送查询请求消息,包括:
[0079]所述终端利用指定格式对多项待查询数据进行封装;
[0080]所述终端通过所述查询请求消息将封装后的待查询数据发送给业务服务器。
[0081]本实施例的终端一次性向业务服务器发起查询多项数据的请求,可以减少传输次数。
[0082]可选地,所述指定格式包括:Java脚本对象表示法格式,该格式易于人的阅读和编写,同时也易于解析。
[0083]综上,本发明实施例提供了一种数据查询的方法、服务器及终端,不仅避免了对数据库的直接操作,还提高数据查询效率。
【附图说明】
[0084]附图用来提供对本发明技术方案的进一步理解,并且构成说明书的一部分,与本申请的实施例一起用于解释本发明的技术方案,并不构成对本发明技术方案的限制。
[0085]图1为实现本发明各个实施例的移动终端一个可选的硬件结构示意图;
[0086]图2为如图1所示的移动终端的无线通信系统示意图;
[0087]图3为本发明实施例的终端侧的数据查询的方法的流程图;
[0088]图4为本发明实施例的服务器侧的一种数据查询的方法的流程图;
[0089]图5为本发明实施例的搜索服务器侧的一种数据查询的方法的流程图;
[0090]图6为本发明实施例一的数据查询的方法的流程图;
[0091 ]图7为本发明实施例的一种服务器的示意图;
[0092]图8为本发明实施例的搜索服务器的示意图;
[0093]图9为本发明实施例的终端的示意图。
[0094]本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
【具体实施方式】
[0095]应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
[0096]现在将参考附图描述实现本发明各个实施例的移动终端。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身并没有特定的意义。因此,"模块"与"部件"可以混合地使用。
[0097]移动终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如移动电话、智能电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、导航装置等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。下面,假设终端是移动终端。然而,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
[0098]图1为实现本发明各个实施例的移动终端一个可选的硬件结构示意图。
[0099]移动终端100可以包括无线通信单元110、A/V(音频/视频)输入单元120、用户输入单元130、感测单元140、输出单元150、存储器160、接口单元170、控制器180和电源单元190等等。图1示出了具有各种组件的移动终端,但是应理解的是,并不要求实施所有示出的组件。可以替代地实施更多或更少的组件。将在下面详细描述移动终端的元件。
[0100]无线通信单元110通常包括一个或多个组件,其允许移动终端100与无线通信系统或网络之间的无线电通信。例如,无线通信单元可以包括广播接收模块111、移动通信模块112、无线互联网模块113、短程通信模块114和位置信息模块115中的至少一个。
[0101]广播接收模块111经由广播信道从外部广播管理服务器接收广播信号和/或广播相关信息。广播信道可以包括卫星信道和/或地面信道。广播管理服务器可以是生成并发送广播信号和/或广播相关信息的服务器或者接收之前生成的广播信号和/或广播相关信息并且将其发送给终端的服务器。广播信号可以包括TV广播信号、无线电广播信号、数据广播信号等等。而且,广播信号可以进一步包括与TV或无线电广播信号组合的广播信号。广播相关信息也可以经由移动通信网络提供,并且在该情况下,广播相关信息可以由移动通信模块112来接收。广播信号可以以各种形式存在,例如,其可以以数字多媒体广播(DMB)的电子节目指南(EPG)、数字视频广播手持(DVB-H)的电子服务指南(ESG)等等的形式而存在。广播接收模块111可以通过使用各种类型的广播系统接收信号广播。特别地,广播接收模块111可以通过使用诸如多媒体广播-地面(DMB-T)、数字多媒体广播-卫星(DMB-S)、数字视频广播-手持(DVB-H),前向链路媒体(MediaFLO?)的数据广播系统、地面数字广播综合服务(ISDB-T)等等的数字广播系统接收数字广播。广播接收模块111可以被构造为适合提供广播信号的各种广播系统以及上述数字广播系统。经由广播接收模块111接收的广播信号和/或广播相关信息可以存储在存储器160(或者其它类型的存储介质)中。
[0102]移动通信模块112将无线电信号发送到基站(例如,接入点、节点B等等)、外部终端以及服务器中的至少一个和/或从其接收无线电信号。这样的无线电信号可以包括语音通话信号、视频通话信号、或者根据文本和/或多媒体消息发送和/或接收的各种类型的数据。
[0103]无线互联网模块113支持移动终端的无线互联网接入。该模块可以内部或外部地耦接到终端。该模块所涉及的无线互联网接入技术可以包括WLAN(无线LAN)(W1-Fi)、Wibro(无线宽带)、Wimax(全球微波互联接入)、HSDPA(高速下行链路分组接入)等等。
[0104]短程通信模块114是用于支持短程通信的模块。短程通信技术的一些示例包括蓝牙?、射频识别(RFID)、红外数据协会(IrDA)、超宽带(UWB)、紫蜂?等等。
[0105]位置信息模块115是用于检查或获取移动终端的位置信息的模块。位置信息模块的典型示例是GPS(全球定位系统)。根据当前的技术,GPS模块115计算来自三个或更多卫星的距离信息和准确的时间信息并且对于计算的信息应用三角测量法,从而根据经度、玮度和高度准确地计算三维当前位置信息。当前,用于计算位置和时间信息的方法使用三颗卫星并且通过使用另外的一颗卫星校正计算出的位置和时间信息的误差。此外,GPS模块115能够通过实时地连续计算当前位置信息来计算速度信息。
[0106]A/V输入单元120用于接收音频或视频信号。A/V输入单元120可以包括相机121和麦克风1220,相机121对在视频捕获模式或图像捕获模式中由图像捕获装置获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元151上。经相机121处理后的图像帧可以存储在存储器160(或其它存储介质)中或者经由无线通信单元110进行发送,可以根据移动终端的构造提供两个或更多相机1210。麦克风122可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由移动通信模块112发送到移动通信基站的格式输出。麦克风122可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
[0107]用户输入单元130可以根据用户输入的命令生成键输入数据以控制移动终端的各种操作。用户输入单元130允许用户输入各种类型的信息,并且可以包括键盘、锅仔片、触摸板(例如,检测由于被接触而导致的电阻、压力、电容等等的变化的触敏组件)、滚轮、摇杆等等。特别地,当触摸板以层的形式叠加在显示单元151上时,可以形成触摸屏。
[0108]感测单元140检测移动终端100的当前状态,(例如,移动终端100的打开或关闭状态)、移动终端100的位置、用户对于移动终端100的接触(S卩,触摸输入)的有无、移动终端100的取向、移动终端100的加速或减速移动和方向等等,并且生成用于控制移动终端100的操作的命令或信号。例如,当移动终端100实施为滑动型移动电话时,感测单元140可以感测该滑动型电话是打开还是关闭。另外,感测单元140能够检测电源单元190是否提供电力或者接口单元170是否与外部装置耦接。感测单元140可以包括接近传感器1410将在下面结合触摸屏来对此进行描述。
[0109]接口单元170用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。识别模块可以是存储用于验证用户使用移动终端100的各种信息并且可以包括用户识别模块(UIM)、客户识别模块(SIM)、通用客户识别模块(USM)等等。另外,具有识别模块的装置(下面称为"识别装置")可以采取智能卡的形式,因此,识别装置可以经由端口或其它连接装置与移动终端100连接。接口单元170可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端和外部装置之间传输数据。
[0110]另外,当移动终端100与外部底座连接时,接口单元170可以用作允许通过其将电力从底座提供到移动终端100的路径或者可以用作允许从底座输入的各种命令信号通过其传输到移动终端的路径。从底座输入的各种命令信号或电力可以用作用于识别移动终端是否准确地安装在底座上的信号。输出单元150被构造为以视觉、音频和/或触觉方式提供输出信号(例如,音频信号、视频信号、警报信号、振动信号等等)。输出单元150可以包括显示单元151、音频输出模块152、警报单元153等等。
[0111]显示单元151可以显示在移动终端100中处理的信息。例如,当移动终端100处于电话通话模式时,显示单元151可以显示与通话或其它通信(例如,文本消息收发、多媒体文件下载等等)相关的用户界面(UI)或图形用户界面(GUI)。当移动终端100处于视频通话模式或者图像捕获模式时,显示单元151可以显示捕获的图像和/或接收的图像、示出视频或图像以及相关功能的UI或GUI等等。
[0112]同时,当显示单元151和触摸板以层的形式彼此叠加以形成触摸屏时,显示单元151可以用作输入装置和输出装置。显示单元151可以包括液晶显示器(LCD)、薄膜晶体管IXD(TFT-1XD)、有机发光二极管(OLED)显示器、柔性显示器、三维(3D)显示器等等中的至少一种。这些显示器中的一些可以被构造为透明状以允许用户从外部观看,这可以称为透明显示器,典型的透明显示器可以例如为TOLED(透明有机发光二极管)显示器等等。根据特定想要的实施方式,移动终端100可以包括两个或更多显示单元(或其它显示装置),例如,移动终端可以包括外部显示单元(未示出)和内部显示单元(未示出)。触摸屏可用于检测触摸输入压力以及触摸输入位置和触摸输入面积。
[0113]音频输出模块152可以在移动终端处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将无线通信单元110接收的或者在存储器160中存储的音频数据转换音频信号并且输出为声音。而且,音频输出模块152可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出模块152可以包括扬声器、蜂鸣器等等。
[0114]警报单元153可以提供输出以将事件的发生通知给移动终端100。典型的事件可以包括呼叫接收、消息接收、键信号输入、触摸输入等等。除了音频或视频输出之外,警报单元153可以以不同的方式提供输出以通知事件的发生。例如,警报单元153可以以振动的形式提供输出,当接收到呼叫、消息或一些其它进入通信(incomingcommunicat1n)时,警报单元153可以提供触觉输出(S卩,振动)以将其通知给用户。通过提供这样的触觉输出,即使在用户的移动电话处于用户的口袋中时,用户也能够识别出各种事件的发生。警报单元153也可以经由显示单元151或音频输出模块152提供通知事件的发生的输出。
[0115]存储器160可以存储由控制器180执行的处理和控制操作的软件程序等等,或者可以暂时地存储己经输出或将要输出的数据(例如,电话簿、消息、静态图像、视频等等)。而且,存储器160可以存储关于当触摸施加到触摸屏时输出的各种方式的振动和音频信号的数据。
[0116]存储器160可以包括至少一种类型的存储介质,所述存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(R0M)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等等。而且,移动终端100可以与通过网络连接执行存储器160的存储功能的网络存储装置协作。
[0117]控制器180通常控制移动终端的总体操作。例如,控制器180执行与语音通话、数据通信、视频通话等等相关的控制和处理。另外,控制器180可以包括用于再现(或回放)多媒体数据的多媒体模块1810,多媒体模块1810可以构造在控制器180内,或者可以构造为与控制器180分离。控制器180可以执行模式识别处理,以将在触摸屏上执行的手写输入或者图片绘制输入识别为字符或图像。
[0118]电源单元190在控制器180的控制下接收外部电力或内部电力并且提供操作各元件和组件所需的适当的电力。
[0119]这里描述的各种实施方式可以以使用例如计算机软件、硬件或其任何组合的计算机可读介质来实施。对于硬件实施,这里描述的实施方式可以通过使用特定用途集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理装置(DSPD)、可编程逻辑装置(PLD)、现场可编程门阵列(FPGA)、处理器、控制器、微控制器、微处理器、被设计为执行这里描述的功能的电子单元中的至少一种来实施,在一些情况下,这样的实施方式可以在控制器180中实施。对于软件实施,诸如过程或功能的实施方式可以与允许执行至少一种功能或操作的单独的软件模块来实施。软件代码可以由以任何适当的编程语言编写的软件应用程序(或程序)来实施,软件代码可以存储在存储器160中并且由控制器180执行。
[0120]至此,己经按照其功能描述了移动终端。下面,为了简要起见,将描述诸如折叠型、直板型、摆动型、滑动型移动终端等等的各种类型的移动终端中的滑动型移动终端作为示例。因此,本发明能够应用于任何类型的移动终端,并且不限于滑动型移动终端。
[0121]如图1中所示的移动终端100可以被构造为利用经由帧或分组发送数据的诸如有线和无线通信系统以及基于卫星的通信系统来操作。
[0122]现在将参考图2描述其中根据本发明的移动终端能够操作的通信系统。
[0123]这样的通信系统可以使用不同的空中接口和/或物理层。例如,由通信系统使用的空中接口包括例如频分多址(FDMA)、时分多址(TDMA)、码分多址(CDMA)和通用移动通信系统(UMTS)(特别地,长期演进(LTE))、全球移动通信系统(GSM)等等。作为非限制性示例,下面的描述涉及CDMA通信系统,但是这样的教导同样适用于其它类型的系统。
[0124]参考图2,⑶MA无线通信系统可以包括多个移动终端100、多个基站(BS)270、基站控制器(BSC)275和移动交换中心(MSCUSOJSCSSO被构造为与公共电话交换网络(PSTN)290形成接口。MSC280还被构造为与可以经由回程线路耦接到基站270的BSC275形成接口。回程线路可以根据若干己知的接口中的任一种来构造,所述接口包括例如E1/T1、ATM,IP、PPP、帧中继、HDSL、ADSL或xDSL。将理解的是,如图2中所示的系统可以包括多个BSC2750。
[0125]每个BS270可以服务一个或多个分区(或区域),由多向天线或指向特定方向的天线覆盖的每个分区放射状地远离BS270。或者,每个分区可以由用于分集接收的两个或更多天线覆盖。每个BS270可以被构造为支持多个频率分配,并且每个频率分配具有特定频谱(例如,1.25MHz,5MHz 等等)。
[0126]分区与频率分配的交叉可以被称为CDMA信道。BS270也可以被称为基站收发器子系统(BTS)或者其它等效术语。在这样的情况下,术语“基站”可以用于笼统地表示单个BSC275和至少一个BS270。基站也可以被称为“蜂窝站”。或者,特定BS270的各分区可以被称为多个蜂窝站。
[0127]如图2中所示,广播发射器(BT)295将广播信号发送给在系统内操作的移动终端100。如图1中所示的广播接收模块111被设置在移动终端100处以接收由BT295发送的广播信号。在图2中,示出了几个全球定位系统(GPS)卫星300。卫星300帮助定位多个移动终端100中的至少一个。
[0128]在图2中,描绘了多个卫星300,但是理解的是,可以利用任何数目的卫星获得有用的定位信息。如图1中所示的GPS模块115通常被构造为与卫星300配合以获得想要的定位信息。替代GPS跟踪技术或者在GPS跟踪技术之外,可以使用可以跟踪移动终端的位置的其它技术。另外,至少一个GPS卫星300可以选择性地或者额外地处理卫星DMB传输。
[0129]作为无线通信系统的一个典型操作,BS270接收来自各种移动终端100的反向链路信号。移动终端100通常参与通话、消息收发和其它类型的通信。特定基站270接收的每个反向链路信号被在特定BS270内进行处理。获得的数据被转发给相关的BSC275 ASC提供通话资源分配和包括BS270之间的软切换过程的协调的移动管理功能。BSC275还将接收到的数据路由到MSC280,其提供用于与PSTN290形成接口的额外的路由服务。类似地,PSTN290与MSC280形成接口,MSC与BSC275形成接口,并且BSC275相应地控制BS270以将正向链路信号发送到移动终端100。
[0130]图3为本发明实施例的终端侧的数据查询的方法的流程图,如图3所示,本实施例的方法包括:
[0131 ]步骤11、终端向业务服务器发送查询请求消息,携带待查询数据的信息;
[0132]步骤12、终端接收所述业务服务器返回的查询结果。
[0133]可选地,终端可以利用指定格式对多项待查询数据进行封装;通过查询请求消息将封装后的查询数据发送给业务服务器。
[0134]本实施例中,客户端(终端,例如手机)把所有需要查询的数据以指定格式一次性传给业务服务器,减少传输次数。
[0135]本方案适用于对复杂数据进行批量查询,比如应用中心,获取应用的可更新列表,需要把手机端所有应用信息上传到业务服务器,业务服务器对数据进行比较,返回所有可更新应用的信息给客户端。
[0136]本实施例中,采用Json(JavaScript Object Notat1n,Java脚本对象表示法)的格式来封装待查询数据。JSON是一种轻量级的数据交换方式,通过名称/值的方式来保存数据,易于人的阅读和编写,同时也易于解析。
[0137]所述指定格式可以是客户端与业务服务器约定的可用于封装所述查询数据的任何格式,例如:直接通过字符串传输的方式。
[0138]本实施例中,终端还可以接收业务服务器返回的终端所请求的所有待查询的查询结果。查询结果也是一次性接收的,减少传输次数。
[0139]图4为本发明实施例的服务器侧的一种数据查询的方法的流程图,如图4所示,本实施例的方法包括:
[0140]步骤21、业务服务器接收到终端的查询请求消息后,将所述查询请求消息中的多项待查询数据的信息发送给指定搜索服务器;
[0141]步骤22、业务服务器接收所述指定搜索服务器返回的查询结果,将所述查询结果发送给所述终端。
[0142]当大量数据直接操作数据库时,会导致查询速度变慢,甚至数据库崩溃等问题。为了避免直接操作数据库,业务服务器将查询请求发送给第三方搜索引擎(即上述的搜索服务器),从第三方搜索引擎上查询相关数据,这样就可以避免直接访问数据库。
[0143]本实施例中,业务服务器将待查询数据一次性发送给第三方搜索引擎,这样可以减少访问第三方搜索引擎的次数。
[0144]例如,业务服务器获取到客户端传来的Json数据,直接从Solr搜索引擎中进行比较查询。以前的方案是,业务服务器解析Json数据,每解析一条,就从Solr搜索引擎中查询,看该条数据有没有可更新信息,这样频繁查询Solr搜索引擎,并没有解决提高效率的问题。本方案在这方面进行改进,在对Json数据解析时,把所有待查询的应用信息封装在Map(列表)中,以包名为Key(关键)值,版本号等信息为value值。同时,不再采用单条数据访问Solr搜索引擎的方案,而是把Map中的Key值封装成列表,只访问一次Solr搜索引擎,便可得到所有可更新信息的列表。
[0145]可选地,所述业务服务器从所述待查询数据中获取多项查询关键数据,将所述查询关键数据封装成查询列表,将所述查询列表发送给所述指定搜索服务器。这样,可以减少传输冗余字段,只把有价值的字段传输给搜索引擎,如应用的包名。
[0146]可选地,所述业务服务器将所述查询结果发送给所述终端之前,还包括:
[0147]所述业务服务器将所述指定搜索服务器返回的所述查询结果中的指定字段删除。本实施例中,业务服务器将返回给客户端的数据中,去掉不必要的字段,这样可以减少传输数据的大小。由于要返回给客户端的信息往往是多条可更新数据,数据量多,导致传输慢,该方案对接口返回的数据进行精简,去掉不需要的字段,以保证传输速度。
[0148]可选地,所述业务服务器将所述查询结果发送给所述终端之前,还包括:
[0149]所述业务服务器利用指定格式对所述查询结果进行封装。
[0150]其中,所述指定格式包括:Java脚本对象表示法格式。
[0151]可选地,所述业务服务器将所述查询结果发送给所述终端之前,还包括:
[0152]所述业务服务器对所述查询结果进行压缩处理。例如,业务服务器对传输的数据进行GZIP压缩处理,可以减少传输时数据包的大小。
[0153]图5为本发明实施例的搜索服务器侧的一种数据查询的方法的流程图,如图5所示,本实施例的方法包括:
[0154]步骤31、搜索服务器接收业务服务器发送的待查询数据的信息;
[0155]步骤32、搜索服务器根据所述待查询数据的信息进行查询;
[0156]步骤33、搜索服务器将查询结果一次性发送给所述业务服务器。
[0157]本实施例的方法,业务服务器借助第三方搜索引擎,从第三方搜索引擎上查询相关数据,这样就可以避免直接访问数据库,避免当大量数据直接操作数据库时,导致查询速度变慢,甚至数据库崩溃等问题。
[0158]可选地,所述搜索服务器还可以建立索引和定时任务;搜索服务器根据所述定时任务定时从数据库中获取与所述索引相关的数据,并保存。
[0159]例如,在Solr搜索引擎上建立索引和定时任务,定时把数据库中索引相关的数据保存在Solr搜索引擎中,可以及时更新Solr搜索引擎中的数据,保证Solr搜索引擎中的数据与数据库中的数据的一致性。
[0160]本实施例中,服务器把key(关键)值封装成列表,在Solr搜索引擎中查询,Solr搜索引擎把查询结果以列表的形式返回,这样可以避免多次访问Solr搜索引擎,不会给Solr搜索引擎带来太大的负担。
[0161]本实施例的方法适用于需要从数据库获取大量数据的情况,以下以几个应用示例对本申请的一种数据查询的方法进行详细的说明。
[0162]应用示例一
[0163]如图6所示,包括以下步骤:
[0164]步骤601、客户端(例如手机)收集本机装载的所有的应用信息;
[0165]比如,手机上装载了η个应用,手机收集本机装载的所有的应用信息,包括:
[0166]应用I的包名、应用I的版本号、应用I的描述信息、应用I的签名;
[0167]应用2的包名、应用2的版本号、应用2的描述信息、应用2的签名;
[0168]应用3的包名、应用3的版本号、应用3的描述信息、应用2的签名;
[0169]……
[0170]应用η的包名、应用η的版本号、应用η的描述信息、应用2的签名。
[0171]通过包名和版本号可以确定上报应用的版本,同时可以判断出有没有最新版本。签名用来检验上报的应用和数据库中的应用签名是否一致,只对签名一致的应用进行可更新操作,若不一致,将有其他机制进行处理,不在本方案的考虑范围。
[0172]步骤602、手机采用Json格式对本机上所有的应用信息进行封装,将封装后的待查询的应用信息发送给服务端。
[0173]本实施例中的JSON的语法规则如下:
[0174]1、使用[]来保存数组,可以存在多个数组;
[0175]2、使用{}来保存对象,一个数组中可以存在多个对象;
[0176]3、数据之间用逗号隔开;
[0177]4、所有的数据,通过名称和值的方式进行保存。
[0178]步骤611、服务端调用接口,接收客户端发送的待查询的数据包;
[0179]步骤612、服务端进行Json解析,将解析出的数据封装成列表,以包名为key值;
[0180]每个应用都有唯一的包名,通过包名可以确定是哪个应用,例如:
[0181 ]应用商店的包名:cn.nubia.neostore ;
[0182]中控程序的包名:com.nubia.triff iccontroIler。
[0183]因为包名和应用是一对一的关系,比如:通过应用商店,就能确定它的包名是cn.nubia.neostore;通过包名cn.nubia, neostore,就能确定这个应用是应用商店,所以可以将包名作为key值。
[0184]本实施例中,业务服务器进行Json解析,获取应用i,把应用i的相关数据封装在Map中,以包名为key值;
[0185]判断i是否小于Json数组的大小,如i小于Json数组的大小,则令i = i + l,再进行Json解析;如i不小于Json数组的大小,则获取包名列表(即Map中的Key的集合),然后访问Solr搜索引擎,将包名列表发送给Solr搜索引擎。
[0? 86] Map相当于一个容器,可以存放数据,它的格式是key/value。
[0187]比如:
[0188]应用I的包名为packageNamel的数据,把版本号(vl.0.1)和签名(SDFASFGB1243654)存放到一个对象Al中。可以以包名为key值,把这个Al的对象存放在Map中。例如:
[0189]map.put(“packageNamel”,Al);
[0190]map.put(“packageName2”,A3);
[0191]……
[0192]Map自带方法,可以获取到key的集合:
[0193]Set<String>keys =map.keySet()。
[0194]步骤613、业务服务器调用Solr搜索引擎进行查询,从Solr搜索引擎获取到可更新数据的列表;
[0195]Solr搜索引擎接收到服务端的包名列表后,遍历包名列表,获取应用可更新数据,将应用可更新信息封装成列表,返回给所述服务器。
[0196]Solr搜索引擎还可以建立索引和定时任务。
[0197]Solr搜索引擎建立索引,这样可以按照数据库的格式把想要的数据同步到Solr搜索引擎中,可以及时更新Solr搜索引擎的数据。
[0198]本实施例的定时任务:在Iinux下通过命令的方式,在约定好的时间,执行建立索引的命令。
[0199]建立索引的命令可以包括:
[0200]1、增量索引:对比数据库和搜索引擎中的数据,当数据在数据库中有更高版本的时候,才对改数据进行同步
[0201]2、全量索引:不需要对比数据库和搜索引擎的数据,把数据库中所有的最新版本的应用信息,同步到搜索引擎中去。
[0202]步骤614、业务服务器向客户端返回获取到可更新数据。
[0203]业务服务器获取到Solr搜索引擎返回的应用可更新数据列表,删除列表中不必要的字段。
[0204]业务服务器获取到的可更新应用的信息可以包括:应用ID,应用名称,应用的版本ID版本号,包名,简介,详细介绍,创建时间,创建者,最近更新时间,最近更新者,星级,下载量,访问量,下载地址,市场来源等。
[0205]其中,在可更新列表需要用到的字段有:应用ID,应用名称,应用的版本ID,版本号,包名,简介,星级。其他字段,在该接口返回的数据中都可以删除。
[0206]业务服务端向客户端返回获取到可更新数据之前,还可以对所述可更新数据进行压缩处理。
[0207]步骤603、客户端获取到可更新数据。
[0208]应用示例二
[0209]本应用示例为获取朋友圈的信息。客户端需要一次性获取到很多条朋友圈的信息,包括其中的评论。业务服务器可以通过索引的方式,把数据库中朋友圈的信息同步到第三搜索引擎中。客户端调用接口,请求获取朋友圈信息的时候,业务服务器直接从第三搜索引擎中获取相应数据,返回给客户端,避免直接从数据库中进行操作。包括以下步骤:
[0210]步骤701、手机向业务服务器发送获取微信朋友圈信息的请求;
[0211]所述获取微信朋友圈信息的请求携带用户标识。
[0212]步骤702、业务服务器接收到请求后,将用户标识发送给第三搜索服务器;
[0213]比如,手机端调用获取朋友圈的接口user/get_friends。访问的地址为:http: / /nubia.XX.com.cn?user_id = 7152&time = 12312212212,其中,user_id为用户标识的字段。[Ο214] 业务服务器的接口118617^1:_;^1611(18接收到客户端的访问,可以获取到地址中所带的参数user_id,time等。
[0215]业务服务器获取到请求信息中的userjd字段,把该字段传给第三方搜索服务器,读取该用户的朋友圈信息。
[0216]步骤703、第三搜索服务器接收到请求后,查询对应用户的微信朋友圈信息,将查询结果返回给业务服务器。
[0217]第三搜索服务器查询出的微信朋友圈信息,例如包括:
[0218]朋友1:用户标识(uSer_id),昵称,朋友圈信息ID,朋友圈内容,评论列表;
[0219]朋友2:用户标识(uSer_id),昵称,朋友圈信息ID,朋友圈内容,评论列表;
[0220]……
[0221]其中,评论列表包括:
[0222]评论id,评论内容,评论者Id(user_id)......等。
[0223]搜索引擎把该用户下前η条朋友圈信息封装起来,传给业务服务器。其中,η具体多少条,可以自定义,可以按时间进行降序排列,不在本方案考虑范围。
[0224]搜索引擎返回的列表,以朋友的用户标识和朋友圈信息的ID为key,信息的内容和评论内容为value值。
[0225]比如:要查看用户A的朋友圈,用户A的朋友圈有朋友B,朋友C分别发送了两条朋友圈信息。
[0226]列表的内容:
[0227]map.put( “朋友Bji友B发的第一条信息ID”,“信息内容,评论列表”)
[0228]map.put( “朋友Bji友B发的第二条信息ID”,“信息内容,评论列表”)
[0229]map.put( “朋友Cji友C发的第一条信息ID”,“信息内容,评论列表”)
[0230]map.put( “朋友Cji友C发的第二条信息ID”,“信息内容,评论列表”)
[0231 ]业务服务器可以获取到封装好的map集合。
[0232]根据map中的key值,读取每一条朋友圈信息的内容和评论列表。
[0233]步骤704、业务服务器接收到第三方搜索服务器的查询结果后,将查询结果返回给客户端。
[0234]业务服务器可以朋友圈信息封装成JSON的形式,返回给手机端。例如,业务服务器读取到搜索引擎返回的map集合后,读取里面的每一条记录。把记录中的值封装到JSON中返回给手机端。
[0235]图7为本发明实施例的一种业务服务器的示意图,如图7所示,本实施例的业务服务器300包括:
[0236]第一传输模块301,用于接收到终端的查询请求消息后,将所述查询请求消息中的待查询数据的信息发送给指定搜索服务器;
[0237]第二传输模块302,用于接收所述指定搜索服务器返回的查询结果,将所述查询结果发送给所述终端。
[0238]可选地,业务服务器300还可以包括:
[0239]获取模块303,用于从第一传输模块301接收到的多项待查询数据中获取多项查询关键数据;
[0240]封装模块304,用于将所述查询关键数据封装成查询列表,将所述查询列表发送给所述第一传输模块;
[0241]第一传输模块301,用于将所述查询列表发送给指定搜索服务器。
[0242]可选地,业务服务器300还可以包括:
[0243]删除模块305,用于将所述指定搜索服务器返回的所述查询结果中的指定字段删除,将删除后的所述查询结果发送给第二传输模块302,由第二传输模块302发送给所述终端。
[0244]可选地,业务服务器300还可以包括:
[0245]封装模块307,用于利用指定格式对所述查询结果进行封装,将封装后的查询结果发送给所述第二传输模块,由所述第二传输模块发送给所述终端。
[0246]可选地,业务服务器300还可以包括:
[0247]压缩模块306,用于对所述指定搜索服务器返回的所述查询结果进行压缩处理,将压缩处理后的查询结果发送给第二传输模块302,由第二传输模块302发送给所述终端。
[0248]图8为本发明实施例的搜索服务器的示意图,如图8所示,本实施例的搜索服务器400包括:
[0249]接收模块401,用于接收业务服务器发送的待查询数据的信息;
[0250]查询模块402,用于根据所述待查询数据的信息进行查询;
[0251]发送模块403,用于将查询结果一次性发送给所述业务服务器。
[0252]可选地,本实施例的搜索服务器400还可以包括:封装模块404,
[0253]接收模块401,接收业务服务器发送的待查询数据的信息包括:接收业务服务器发送的包括多项查询关键数据的查询列表;
[0254]查询模块402,用于根据所述多项查询关键数据进行查询;
[0255]封装模块404,用于将多项查询结果封装为查询结果列表;
[0256]发送模块403,用于将所述查询结果列表发送给所述业务服务器。
[0257]可选地,本实施例的搜索服务器400还可以包括:
[0258]建立模块405,用于建立索引和定时任务;
[0259]获取模块406,用于根据所述定时任务定时从数据库中获取与所述索引相关的数据;
[0260]存储模块407,用于保存所述获取模块获取的数据。
[0261]图9为本发明实施例的终端的示意图,如图9所示,本实施例的终端500包括:
[0262]发送模块502,用于向业务服务器发送查询请求消息,携带待查询数据的信息;
[0263]接收模块503,用于接收所述业务服务器返回的查询结果。
[0264]可选地,本实施例的终端500还可以包括:
[0265]封装模块501,用于利用指定格式将多项待查询数据进行封装;
[0266]发送模块502,用于通过所述查询请求消息将封装后的待查询数据发送给所述业务服务器。
[0267]需要说明的是,本发明实施例提供的终端500中的封装模块501可以设置在图1中的控制器180中,发送模块502和接收模块503可以设置在图1中的接口单元170中。
[0268]需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
[0269]上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
[0270]通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如R0M/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,月艮务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
[0271]以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
【主权项】
1.一种业务服务器,其特征在于,包括: 第一传输模块,用于接收到终端的查询请求消后,将所述查询请求消息中的待查询数据的信息发送给指定搜索服务器; 第二传输模块,用于接收所述指定搜索服务器返回的查询结果,将所述查询结果发送给所述终端。2.根据权利要求1所述的业务服务器,其特征在于,还包括: 获取模块,用于从所述待查询数据中获取多项查询关键数据; 封装模块,用于将所述查询关键数据封装成查询列表,将所述查询列表发送给所述第一传输模块; 所述第一传输模块,用于将所述查询列表发送给指定搜索服务器。3.一种数据查询的方法,包括: 业务服务器接收到终端的查询请求消息后,将所述查询请求消息中的待查询数据的信息发送给指定搜索服务器; 所述业务服务器接收所述指定搜索服务器返回的查询结果,将所述查询结果发送给所述终端。4.根据权利要求3所述的方法,其特征在于,所述业务服务器将所述查询请求消息中的待查询数据的信息发送给指定搜索服务器,包括: 所述业务服务器从所述待查询数据中获取多项查询关键数据,将所述查询关键数据封装成查询列表,将所述查询列表发送给所述指定搜索服务器。5.一种搜索服务器,其特征在于,包括: 接收模块,用于接收业务服务器发送的待查询数据的信息; 查询模块,用于根据所述待查询数据的信息进行查询; 发送模块,用于将查询结果一次性发送给所述业务服务器。6.根据权利要求5所述的搜索服务器,其特征在于,还包括封装模块, 所述接收模块,接收所述业务服务器发送的多项待查询数据的信息包括:接收所述业务服务器发送的包括多项查询关键数据的查询列表; 所述查询模块,用于根据所述多项查询关键数据进行查询; 所述封装模块,用于将多项查询结果封装为查询结果列表; 所述发送模块,用于将所述查询结果列表发送给所述业务服务器。7.一种数据查询的方法,包括: 搜索服务器接收业务服务器发送的待查询数据的信息; 所述搜索服务器根据所述待查询数据的信息进行查询; 所述搜索服务器将查询结果一次性发送给所述业务服务器。8.根据权利要求7所述的方法,其特征在于, 所述搜索服务器接收所述业务服务器发送的多项待查询数据的信息,包括:接收所述业务服务器发送的包括多项查询关键数据的查询列表; 所述搜索服务器根据所述多项查询关键数据进行查询,将多项查询结果封装为查询结果列表,将所述查询结果列表发送给所述业务服务器。9.一种终端,其特征在于,包括:发送模块,用于向业务服务器发送查询请求消息,携带待查询数据的信息;接收模块,用于接收所述业务服务器返回的查询结果。10.一种数据查询的方法,包括:终端向业务服务器发送查询请求消息,携带待查询数据的信息;所述终端接收所述业务服务器返回的查询结果。
【文档编号】G06F17/30GK106021518SQ201610349310
【公开日】2016年10月12日
【申请日】2016年5月24日
【发明人】彭小春
【申请人】努比亚技术有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1