本發明涉及互聯網
技術領域:
,尤其涉及一種信息處理方法及裝置。
背景技術:
:隨著互聯網技術的快速發展,人們越來越傾向于在網絡上享受各種便捷服務。對于服務提供商而言,在特定的領域如何為用戶提供精準的服務,也是獲取用戶肯定的一個重要因素。為了滿足用戶的個性化需求以及能夠向用戶提供精準的服務,需要采集用戶的個性化屬性并進行存儲,以便于之后根據用戶的個性化屬性為用戶提供精準的服務。個性化屬性包括用戶的一些行為習慣、興趣偏好以及定制需求等等。例如,用戶偏好的支付方式,用戶偏好的支付賬號,用戶感興趣的商品的類別,用戶經常瀏覽的商戶,以及用戶自己設置的默認登錄賬號等等。用戶的個性化屬性包括個性化屬性的屬性名稱以及個性化屬性的屬性值。例如,用戶的一個個性化屬性的屬性名稱為“默認支付方式”,以及屬性值為“在線支付”;再例如,用戶的另一個性化屬性的屬性名稱為“感興趣的商品的類別”,以及屬性值為“數碼家電類”。目前現有技術中通常采用如下表1所示方式存儲用戶的個性化屬性,表1中的最左側的一列中的每個字段中分別存儲每一用戶的id(),例如分別為用戶a~用戶m;表1中的最上面一行中的每個字段中分別存儲技術人員事先統計出的每一個性化屬性的屬性名稱,例如分別存儲了屬性名稱1~屬性名稱n,表1一共包括(m+1)*(n+1)個字段。當需要在表1中存儲某一用戶的個性化屬性的屬性值時,在表1中查找該用戶的用戶id所在的行,以及查找該個性化屬性的屬性名稱所在的列,然后確定出同時位于查找到的該行中以及查找到的該列中的字段,在該字段中填入該個性化屬性的屬性值。其中,在表1中,如果位于某一用戶id所在行中且位于某一屬性名稱所在列中的字段為空字段,則說明該用戶id對應的用戶不具備該屬性名稱對應的個性化屬性。表1屬性名稱1屬性名稱2屬性名稱3……屬性名稱n用戶aa1a2an用戶bb2b3……用戶mm1m3發明人在實現本發明的過程中發現,相關技術中的這種方案至少存在如下缺點。技術人員事先統計出的個性化屬性有很多種,這樣表1中的第一行中包括的字段就會很多,但是有時候不同的用戶具備的個性化屬性差別較大,重合度較低,且每一用戶具備的個性化屬性在技術人員事先統計出的所有個性化屬性中僅僅占一小部分,這樣,一個用戶id所在行中可能只有幾個字段中填入了屬性值,而其他字段都為空字段,如此表1中就會存在非常多的空字段,由于空字段會占用一定的存儲空間,這樣表1中非常多的空字段就會耗費巨大的存儲空間。技術實現要素:為克服相關技術中存在的問題,本發明提供一種信息處理方法及裝置。根據本發明實施例的第一方面,提供一種信息處理方法,所述方法包括:獲取用戶標識以及所述用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;對于每一個所述個性化屬性,根據所述個性化屬性的屬性標識和屬性值生成所述個性化屬性的目標屬性對應關系;判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存在與所述用戶標識相對應的目標屬性存儲字段;當所述第一對應關系中存在與所述用戶標識相對應的目標屬性存儲字段時,在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系;當所述第一對應關系中不存在與所述用戶標識相對應的目標屬性存儲字段時,創建與所述用戶標識相對應屬性存儲字段;在所述創建的屬性存儲字段中存儲所有所述目標屬性對應關系。其中,所述根據所述個性化屬性的屬性標識和屬性值生成所述個性化屬性的目標屬性對應關系,包括:建立所述個性化屬性的屬性標識與所述個性化屬性的屬性值之間的目標屬性對應關系;或者,獲取已存儲的屬性標識與順序索引的索引標識之間的第二對應關系;在所述第二對應關系中查找與所述屬性標識相對應的索引標識;建立所述索引標識與所述個性化屬性的屬性值之間的目標屬性對應關系。其中,所述在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系,包括:判斷所有所述目標屬性對應關系所占存儲空間是否小于或等于所述目標屬性存儲字段的空閑存儲空間;當所有所述目標屬性對應關系所占存儲空間小于或等于所述目標屬性存儲字段的空閑存儲空間時,在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系;當所有所述目標屬性對應關系所占存儲空間大于所述目標屬性存儲字段的空閑存儲空間時,創建至少一個與所述用戶標識相對應的新的屬性存儲字段;在所述新的屬性存儲字段中存儲所有所述目標屬性對應關系或在所述目標屬性存儲字段和所述新的屬性存儲字段中存儲所有所述目標屬性對應關系。其中,所述在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系,包括:根據所述目標屬性對應關系中的索引標識與所述目標屬性字段中存儲的所有屬性對應關系中的索引標識確定所述目標屬性對應關系在所述目標屬性存儲字段中的待存儲位置;將所述目標屬性對應關系存儲在所述待存儲位置處。根據本發明實施例的第二方面,提供一種信息處理方法,所述方法包括:當獲取到攜帶用戶標識和個性化屬性的屬性標識的獲取請求時,在用戶標識與屬性存儲字段之間的第一對應關系中查找是否存在與所述用戶標識相對應的屬性存儲字段;當存在在與所述用戶標識相對應的屬性存儲字段時,在所述屬性存儲字段中查找是否存在與所述屬性標識對應的屬性對應關系;當存在與所述屬性標識對應的屬性對應關系時,獲取所述屬性對應關系中的屬性值。其中,所述在所述屬性存儲字段中查找是否存在與所述屬性標識對應的屬性對應關系,包括:在所述屬性存儲字段中查找是否存在包括所述屬性標識的屬性對應關系;當存在包括所述屬性標識的屬性對應關系時,確定所述屬性存儲字段中存在與所述屬 性標識對應的屬性對應關系。其中,所述在所述屬性存儲字段中查找是否存在與所述屬性標識對應的屬性對應關系,包括:獲取屬性標識與索引標識之間的第二對應關系;在所述第二對應關系中查找與所述屬性標識相對應的索引標識;在所述屬性存儲字段中查找是否存在包括所述索引標識的屬性對應關系。當存在包括所述索引標識的屬性對應關系時,確定所述屬性存儲字段中存在與所述屬性標識對應的屬性對應關系。根據本發明實施例的第三方面,提供一種信息處理裝置,所述裝置包括:第一獲取模塊,用于獲取用戶標識以及所述用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;生成模塊,用于對于每一個所述個性化屬性,根據所述個性化屬性的屬性標識和屬性值生成所述個性化屬性的目標屬性對應關系;判斷模塊,用于判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存在與所述用戶標識相對應的目標屬性存儲字段;第一存儲模塊,用于當所述第一對應關系中存在與所述用戶標識相對應的目標屬性存儲字段時,在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系;創建模塊,用于當所述第一對應關系中不存在與所述用戶標識相對應的目標屬性存儲字段時,創建與所述用戶標識相對應屬性存儲字段;第二存儲模塊,用于在所述創建的屬性存儲字段中存儲所有所述目標屬性對應關系。其中,所述生成模塊包括:第一建立單元,用于建立所述個性化屬性的屬性標識與所述個性化屬性的屬性值之間的目標屬性對應關系;或者,第一獲取單元,用于獲取已存儲的屬性標識與順序索引的索引標識之間的第二對應關系;查找單元,用于在所述第二對應關系中查找與所述屬性標識相對應的索引標識;第二建立單元,用于建立所述索引標識與所述個性化屬性的屬性值之間的目標屬性對應關系。其中,所述第一存儲模塊包括:判斷單元,用于判斷所有所述目標屬性對應關系所占存儲空間是否小于或等于所述目 標屬性存儲字段的空閑存儲空間;第一存儲單元,用于當所有所述目標屬性對應關系所占存儲空間小于或等于所述目標屬性存儲字段的空閑存儲空間時,在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系;創建單元,用于當所有所述目標屬性對應關系所占存儲空間大于所述目標屬性存儲字段的空閑存儲空間時,創建至少一個與所述用戶標識相對應的新的屬性存儲字段;第二存儲單元,用于在所述新的屬性存儲字段中存儲所有所述目標屬性對應關系或在所述目標屬性存儲字段和所述新的屬性存儲字段中存儲所有所述目標屬性對應關系。其中,所述第一存儲模塊包括:第一確定單元,用于根據所述目標屬性對應關系中的索引標識與所述目標屬性字段中存儲的所有屬性對應關系中的索引標識確定所述目標屬性對應關系在所述目標屬性存儲字段中的待存儲位置;第三存儲單元,用于將所述目標屬性對應關系存儲在所述待存儲位置處。根據本發明實施例的第四方面,提供一種信息處理裝置,所述裝置包括:第一查找模塊,用于當獲取到攜帶用戶標識和個性化屬性的屬性標識的獲取請求時,在用戶標識與屬性存儲字段之間的第一對應關系中查找是否存在與所述用戶標識相對應的屬性存儲字段;第二查找模塊,用于當存在在與所述用戶標識相對應的屬性存儲字段時,在所述屬性存儲字段中查找是否存在與所述屬性標識對應的屬性對應關系;第二獲取模塊,用于當存在與所述屬性標識對應的屬性對應關系時,獲取所述屬性對應關系中的屬性值。其中,所述第二查找模塊包括:第一查找單元,用于在所述屬性存儲字段中查找是否存在包括所述屬性標識的屬性對應關系;第二確定單元,用于當存在包括所述屬性標識的屬性對應關系時,確定所述屬性存儲字段中存在與所述屬性標識對應的屬性對應關系。其中,所述第二查找模塊包括:第二獲取單元,用于獲取屬性標識與索引標識之間的第二對應關系;第二查找單元,用于在所述第二對應關系中查找與所述屬性標識相對應的索引標識;第三查找單元,用于在所述屬性存儲字段中查找是否存在包括所述索引標識的屬性對應關系。第三確定單元,用于當存在包括所述索引標識的屬性對應關系時,確定所述屬性存儲字段中存在與所述屬性標識對應的屬性對應關系。本發明的實施例提供的技術方案可以包括以下有益效果:在本發明所示的實施例中,獲取用戶標識以及該用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;對于每一個個性化屬性,根據該個性化屬性的屬性標識和屬性值生成該個性化屬性的目標屬性對應關系;判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存在與該用戶標識相對應的目標屬性存儲字段;當第一對應關系中存在與該用戶標識相對應的目標屬性存儲字段時,在目標屬性存儲字段中存儲所有目標屬性對應關系;當第一對應關系中不存在與該用戶標識相對應的目標屬性存儲字段時,創建與該用戶標識相對應屬性存儲字段;在創建的屬性存儲字段中存儲所有目標屬性對應關系。本發明實施例摒棄了現有技術中的存儲結構,首先,不會存在空字段,從而避免了空字段浪費存儲空間的問題,實現了節省存儲空間的目的;其次,現有技術中每一字段中僅僅存儲一個屬性值,而本發明實施例中一個屬性存儲字段中存儲了多個屬性對應關系,每個屬性對應關系中都包括屬性值,這樣,相對于現有技術,在本發明實施例中,相當于一個屬性存儲字段中存儲了多個屬性值,充分利用了一個屬性存儲字段中的存儲空間,從而節省了存儲空間。再次,隨著服務業務地快速發展,用戶的個性化需求層出不窮,因此常常需要開拓出新的個性化屬性,此時在現有技術中,就需要在表1的第一行的最右側新增加一個字段,并將新的個性化屬性的屬性名稱添加該新增加的字段中,然后需要在表1中的每一用戶id所在的行的最右側新增加一個字段,以使之后當某一用戶具備該新的個性化屬性時,再在該用戶id所在的行的最右側新增加的字段中填入該個性化屬性的屬性值。但是,此時表1中的每一用戶id對應的用戶并不全都具備該新的個性化屬性,因此,此時不會在全部的用戶id所在的行的最右側的新增加的字段中填入屬性值,或多或少都會導致一些字段為空字段,浪費了存儲空間。除此之外,在為表1新增加字段的過程中需要將表1鎖定,鎖定時的表1不能被使用,當表1中存儲的用戶id非常多時,也即表1中的行數非常多時,將每一用戶id所在的行的最右側新增加一個字段會耗費較多的時間,這樣會造成表1不能被使用的時間過多,從而導致不能為用戶提供精準的服務的時間過多。而在本發明實施例中,即使開拓出新的個性化屬性,不需要為開拓出的新的個性化屬性分配字段,也就無需對存儲的個性化屬性進行鎖定,使得可以持續性不間斷地為用戶提供精準的服務,不會出現不能為用戶提供精準 的服務的時間。其次,不需要與開拓出的新的個性化屬性分配字段,也就不存在出現空字段的情況,這樣就避免了浪費存儲空間的問題。應當理解的是,以上的一般描述和后文的細節描述僅是示例性和解釋性的,并不能限制本發明。附圖說明此處的附圖被并入說明書中并構成本說明書的一部分,示出了符合本發明的實施例,并與說明書一起用于解釋本發明的原理。圖1是根據一示例性實施例示出的一種信息處理方法的流程圖;圖2是根據一示例性實施例示出的一種信息處理方法的流程圖;圖3是根據一示例性實施例示出的一種信息處理方法的流程圖;圖4是根據一示例性實施例示出的一種信息處理方法的流程圖;圖5是根據一示例性實施例示出的一種信息處理裝置的框圖;圖6是根據一示例性實施例示出的一種信息處理裝置的框圖。具體實施方式這里將詳細地對示例性實施例進行說明,其示例表示在附圖中。下面的描述涉及附圖時,除非另有表示,不同附圖中的相同數字表示相同或相似的要素。以下示例性實施例中所描述的實施方式并不代表與本發明相一致的所有實施方式。相反,它們僅是與如所附權利要求書中所詳述的、本發明的一些方面相一致的裝置和方法的例子。圖1是根據一示例性實施例示出的一種信息處理方法的流程圖,如圖1所示,該方法包括以下步驟。在步驟s101中,獲取用戶標識以及該用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;用戶標識可以為用戶的賬號等,例如用戶事先可以在服務器中注冊一個用戶賬戶,用戶的用戶標識可以為該用戶賬戶的賬號。個性化屬性的屬性標識可以為個性化屬性的名稱:例如,“默認支付方式”和“默認支付賬號等”。當個性化屬性的名稱為“默認支付方式”時,個性化屬性的屬性值可以為“在線支付” 或“貨到付款”等。當個性化屬性的名稱為“默認支付賬號”時,個性化屬性的屬性值可以為一個賬號,例如“273356214”或“178549624”等。當個性化屬性的名稱為“感興趣的商品的類別”時,個性化屬性的屬性值可以為“數碼家電類”、“美食類”或“鞋包類”等。在本發明實施例中,當服務器第一次存儲某一用戶的個性化屬性時,服務器可以從用戶的用戶賬戶中獲取用戶的用戶標識、用戶的每一個性化屬性的屬性標識和屬性值。之后,當用戶在自己終端上使用自己的用戶標識登錄服務器之后,如果用戶在自己的用戶賬戶中更新一個或多個已有的個性化屬性的屬性標識對應的屬性值,則終端會獲取用戶的用戶標識、該更新的一個或多個個性化屬性的屬性標識以及該更新的一個或多個個性化屬性的屬性標識中的每一屬性標識分別對應的屬性值,然后將獲取的用戶標識、屬性標識和屬性值發送給服務器,服務器接收終端發送的用戶標識、屬性標識和屬性值。以及,當用戶在自己終端上使用自己的用戶標識登錄服務器之后,如果用戶在自己的用戶賬戶中增加一個或多個新的個性化屬性的屬性標識以及每一新的屬性標識對應的屬性值,則終端會獲取用戶的用戶標識、每一新的個性化屬性的屬性標識以及每一新的個性化屬性的屬性標識分別對應的屬性值,然后將獲取的用戶標識、屬性標識和屬性值發送給服務器,服務器接收終端發送的用戶標識、屬性標識和屬性值。在步驟s102中,對于每一個個性化屬性,根據該個性化屬性的屬性標識和屬性值生成該個性化屬性的目標屬性對應關系;在本發明一個實施例中,對于任一個個性化屬性,可以建立該個性化屬性的屬性標識與該個性化屬性的屬性值之間的目標屬性對應關系,目標屬性對應關系包括該個性化屬性的屬性標識和該個性化屬性的屬性值。其中,可以將該個性化屬性的屬性標識與該個性化屬性的屬性值組成一個鍵值對,例如“keyvalue”形式的鍵值對。對于其他每一個個性化屬性均執行上述操作。其中,在“keyvalue”形式的鍵值對中,“key”用于表示個性化屬性的屬性標識,“value”用于表示個性化屬性的屬性值,屬性標識與屬性值之間利用第一預設標識符連接,第一預設標識符可以為“=”、“-”、或“+”等,本發明對此不加以限定。例如,假設個性化屬性的屬性標識為“默認支付方式”,以及個性化屬性的屬性值為“在線支付”,則目標屬性對應關系可以為“默認支付方式=在線支付”。在前述實施例中,個性化屬性的屬性標識通常為個性化屬性的名稱,例如:“默認支付方式”、“默認支付賬號”和“感興趣的商品的類別”等,但是,個性化屬性的名稱中一般 包含的字符較多,從而導致個性化屬性的屬性標識所占存儲空間較大,由于屬性對應關系中會包含個性化屬性的屬性標識,因此,在屬性標識所占存儲空間較大的情況下,屬性對應關系所占存儲空間也較大。而本發明是為了在一個屬性存儲字段中盡可能多地存儲屬性對應關系,但是,一個屬性存儲字段的總存儲空間是有限的,因此,在屬性對應關系所占存儲空間較大的情況下,一個屬性存儲字段中能夠存儲的屬性對應關系的個數就較少。所以,為了使得一個屬性存儲字段中盡可能地可以存儲更多的屬性對應關系。在本發明另一實施例中,可以事先為每一個性化屬性分別分配一個索引標識,為不同的個性化屬性分配的索引標識不同,每一個性化屬性的屬性標識所占存儲空間小于為該個性化屬性的屬性標識的分配的索引標識所占存儲空間。然后對于任一個性化屬性,將該個性化屬性的屬性標識與為該個性化屬性分配的索引標識存儲在屬性標識與順序索引的索引標識之間的第二對應關系中,對于其他每一個性化屬性,均執行上述操作。其中,在分配的所有索引標識之間具備預設索引順序,例如,索引標識為數字編號,例如1、2、3、4和5等,這些數字編號之間具有遞增順序。這樣,在本發明另一實施例中,根據該個性化屬性的屬性標識和屬性值生成該個性化屬性的目標屬性對應關系,可以為:對于任一個個性化屬性,獲取已存儲的屬性標識與順序索引的索引標識之間的第二對應關系,在第二對應關系中查找與該屬性標識相對應的索引標識,建立該索引標識與該個性化屬性的屬性值之間的目標屬性對應關系,以實現根據該個性化屬性的屬性標識和屬性值生成該個性化屬性的目標屬性對應關系。目標屬性對應關系包括與該個性化屬性的屬性標識相對應的索引標識和該個性化屬性的屬性值。其中,可以將與該個性化屬性的屬性標識相對應的索引標識與該個性化屬性的屬性值組成一個鍵值對,例如“keyvalue”形式的鍵值對。對于其他每一個個性化屬性均執行上述操作。其中,在“keyvalue”形式的鍵值對中,“key”用于表示與個性化屬性的屬性標識相對應的索引標識,“value”用于表示個性化屬性的屬性值,索引標識與屬性值之間利用第一預設標識符連接,第一預設標識符可以為“=”、“-”、或“+”等,本發明對此不加以限定。例如,假設個性化屬性的屬性標識為“默認支付方式”,個性化屬性的屬性值為“在線支付”,以及與個性化屬性的屬性標識“默認支付方式”相對應的索引標識為“1”,則目標屬性對應關系可以為“1=在線支付”。在步驟s103中,判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存 在與該用戶標識相對應的目標屬性存儲字段;對于在服務器中注冊賬戶的任一用戶,當服務器第一次存儲該用戶的屬性對應關系時,會在用戶標識與屬性存儲字段之間的第一對應關系中建立一個與該用戶標識的相對應的屬性存儲字段,然后在該屬性存儲字段中存儲該用戶的屬性對應關系。在本發明實施例中,如果之后增加了一個該用戶的新的個性化屬性,則在根據該新的個性化屬性的屬性標識和屬性值生成該新的個性化屬性的新的屬性對應關系之后,還可以在該屬性存儲字段中繼續存儲該新的屬性對應關系。對于在服務器中注冊賬戶的其他每一用戶,同樣如此。因此,在生成了目標屬性對應關系之后,需要判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存在與用戶標識相對應的目標屬性存儲字段。如果存在與用戶標識相對應的目標屬性存儲字段,則就可以直接在目標屬性字段中存儲目標屬性對應關系。如果不存在與用戶標識相對應的目標屬性存儲字段,則說明之前還未存儲過該用戶的屬性對應關系,也即,還未創建過與該用戶標識的相對應的屬性存儲字段。所以,此時需要在第一對應關系中創建與該用戶標識相對應屬性存儲字段,然后在創建的屬性存儲字段中存儲目標屬性對應關系。當第一對應關系中存在與該用戶標識相對應的目標屬性存儲字段時,在步驟s104中,在目標屬性存儲字段中存儲所有目標屬性對應關系;當第一對應關系中不存在與該用戶標識相對應的目標屬性存儲字段時,在步驟s105中,創建與該用戶標識相對應屬性存儲字段,然后執行步驟s106;在步驟s106中,在創建的屬性存儲字段中存儲所有目標屬性對應關系。在本發明圖1所示的實施例中,獲取用戶標識以及該用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;對于每一個個性化屬性,根據該個性化屬性的屬性標識和屬性值生成該個性化屬性的目標屬性對應關系;判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存在與該用戶標識相對應的目標屬性存儲字段;當第一對應關系中存在與該用戶標識相對應的目標屬性存儲字段時,在目標屬性存儲字段中存儲所有目標屬性對應關系;當第一對應關系中不存在與該用戶標識相對應的目標屬性存儲字段時,創建與該用戶標識相對應屬性存儲字段;在創建的屬性存儲字段中存儲所有目標屬性對應關系。本發明實施例摒棄了現有技術中的存儲結構,首先,不會存在空字段,從而避免了空字段浪費存儲空間的問題,實現了節省存儲空間的目的;其次,現有技術中每一字段中僅僅存儲一個屬性值,而本發明實施例中一個屬性存儲字段中存儲了多個屬性對應關系,每個屬性對應關系中都包括屬性值,這樣,相對于現有技術,在本發明實施例中,相當于一 個屬性存儲字段中存儲了多個屬性值,充分利用了一個屬性存儲字段中的存儲空間,從而節省了存儲空間。再次,隨著服務業務地快速發展,用戶的個性化需求層出不窮,因此常常需要開拓出新的個性化屬性,此時在現有技術中,就需要在表1的第一行的最右側新增加一個字段,并將新的個性化屬性的屬性名稱添加該新增加的字段中,然后需要在表1中的每一用戶id所在的行的最右側新增加一個字段,以使之后當某一用戶具備該新的個性化屬性時,再在該用戶id所在的行的最右側新增加的字段中填入該個性化屬性的屬性值。但是,此時表1中的每一用戶id對應的用戶并不全都具備該新的個性化屬性,因此,此時不會在全部的用戶id所在的行的最右側的新增加的字段中填入屬性值,或多或少都會導致一些字段為空字段,浪費了存儲空間。除此之外,在為表1新增加字段的過程中需要將表1鎖定,鎖定時的表1不能被使用,當表1中存儲的用戶id非常多時,也即表1中的行數非常多時,將每一用戶id所在的行的最右側新增加一個字段會耗費較多的時間,這樣會造成表1不能被使用的時間過多,從而導致不能為用戶提供精準的服務的時間過多。而在本發明實施例中,即使開拓出新的個性化屬性,不需要為開拓出的新的個性化屬性分配字段,也就無需對存儲的個性化屬性進行鎖定,使得可以持續性不間斷地為用戶提供精準的服務,不會出現不能為用戶提供精準的服務的時間。其次,不需要與開拓出的新的個性化屬性分配字段,也就不存在出現空字段的情況,這樣就避免了浪費存儲空間的問題。其中,在本發明另一實施例中,參見圖2,步驟s104包括:在步驟s201中,判斷所有目標屬性對應關系所占存儲空間是否小于或等于目標屬性存儲字段的空閑存儲空間;在本發明實施例中,每個字符都會占用一個單位的存儲空間,且每一屬性對應關系都包括多個字符,因此,每一屬性對應關系都會占用一定的存儲空間,由于一個屬性存儲字段的可用存儲空間是有限的,當需要將一個屬性對應關系存儲在一個屬性存儲字段中時,必須滿足一個客觀條件:該一個屬性對應關系所占存儲空間小于或等于該一個屬性存儲字段的可用存儲空間,這樣才能將該一個屬性對應關系成功地存儲在該一個屬性存儲字段中,否則,當該一個屬性對應關系所占存儲空間大于該一個屬性存儲字段的可用存儲空間時,就無法將該一個屬性對應關系成功地存儲在該一個屬性存儲字段中。同理,當需要將多個屬性對應關系存儲在一個屬性存儲字段中時,也需要判斷該多個屬性對應關系所占存儲空間是否小于或等于該一個屬性存儲字段的空閑存儲空間。當所有目標屬性對應關系所占存儲空間小于或等于目標屬性存儲字段的空閑存儲空間時,在步驟s202中,在目標屬性存儲字段中存儲所有目標屬性對應關系;當所有目標屬性對應關系所占存儲空間小于或等于目標屬性存儲字段的空閑存儲空間時,則說明在目標屬性字段中是能夠存儲完所有目標屬性對應關系的,因此,可以直接在目標屬性存儲字段中存儲所有目標屬性對應關系。當所有目標屬性對應關系所占存儲空間大于目標屬性存儲字段的空閑存儲空間時,在步驟s203中,創建至少一個與該用戶標識相對應的新的屬性存儲字段,然后執行步驟s204;當所有目標屬性對應關系所占存儲空間大于目標屬性存儲字段的空閑存儲空間時,則說明在目標屬性字段中是無法存儲完所有目標屬性對應關系的,因此,需要再創建至少一個與用戶標識相對應的新的屬性存儲字段。其中,創建新的屬性存儲字段的個數可以根據一個屬性存儲字段的可用存儲空間、所有目標屬性對應關系所占存儲空間和目標屬性字段的可用存儲空間來確定,本發明對具體的確定方法不做限定。在步驟s204中,在新的屬性存儲字段中存儲所有目標屬性對應關系,或在目標屬性存儲字段和新的屬性存儲字段中存儲所有目標屬性對應關系。其中,如果目標屬性存儲字段被占滿,則在新的屬性存儲字段中存儲目標屬性對應關系。如果目標屬性存儲字段未被占滿,則可以先在目標屬性存儲字段中存儲一部分目標屬性對應關系,當目標屬性存儲字段被占滿之后,再在新的屬性存儲字段中存儲另一部分目標屬性對應關系。在存儲所有目標屬性對應關系時,可以利用預設第二分隔符將相鄰的屬性對應關系分隔開,以免不同的屬性對應關系相互混淆。預設第二分隔符可以為“|”或“*”或“~”等,本發明對此不加以限定。例如,假設一個屬性對應關系為“默認支付方式=在線支付”,另一屬性對應關系為“感興趣的商品的類別=數碼家電類”,以及又一屬性對應關系為“默認支付賬號=123456789”,則將這三個屬性對應關系在屬性存儲字段中存儲時可以利用第二預設標識符“|”將這三個屬性對應關系分隔開:“默認支付方式=在線支付|感興趣的商品的類別=數碼家電類|默認支付賬號=123456789”。在前述一個實施例中,屬性對應關系中包括個性化屬性的屬性標識對應的索引標識和個性化屬性的屬性值,所有的個性化屬性的索引標識之間具有預設索引順序,因此,在本發明實施例中,可以按照其包括的索引標識與已存儲的屬性對應關系中的索引標識之間的 預設索引順序將目標屬性對應關系進行存儲,以提高之后在查詢某一個性化屬性的屬性值時的查詢效率。因此,在本發明又一實施例中,參見圖3,步驟s104包括:在步驟s301中,根據目標屬性對應關系中的索引標識與在目標屬性存儲字段中存儲的所有屬性對應關系中的索引標識確定目標屬性對應關系在目標屬性存儲字段中的待存儲位置;本發明實施例中各個屬性對應關系在屬性存儲字段中的位置是根據其包括的索引標識的之間的預設索引順序進行排序后確定的。例如,假設索引標識為編號,例如1、2、3、4和5等,在屬性對應關系中,對于任一屬性存儲字段,在于該屬性存儲字段相鄰的兩個屬性存儲字段中,其中一個屬性存儲字段中的編號大于該屬性存儲字段,另一個屬性存儲字段中的編號小于該屬性存儲字段。對于其他每一屬性存儲字段,同樣如此。在本步驟中,可以根據目標屬性對應關系中的索引標識與所有已存儲的屬性對應關系中的索引標識將目標屬性對應關系在所有已存儲的屬性對應關系中進行排序,確定出目標屬性對應關系應位于目標屬性存儲字段中的哪兩個屬性對應關系之間,這兩個屬性對應關系中,一個屬性對應關系中的編號大于目標屬性對應關系中的編號,另一個屬性對應關系中的編號小于目標屬性對應關系中的編號,將這兩個屬性對應關系之間的位置確定為待存儲位置。在步驟s302中,將目標屬性對應關系存儲在待存儲位置處。之后,當需要對用戶提供精準的服務時,服務器需要查詢用戶的一個或多個個性化屬性的屬性值。參見圖4,可以通過如下方法進行查詢,包括:在步驟s401中,當獲取到攜帶用戶標識和個性化屬性的屬性標識的獲取請求時,在用戶標識與屬性存儲字段之間的第一對應關系中查找是否存在與該用戶標識相對應的屬性存儲字段;在本發明實施例中,當需要對用戶提供精準的服務器時,需要獲取用戶的一個或多個個性化屬性的屬性值,首先會根據用戶的用戶標識和需要獲取的個性化屬性的屬性標識生成獲取請求,以實現獲取到獲取請求,之后可以獲取用戶標識與屬性存儲字段之間的第一對應關系,然后在第一對應關系中查找是否存在與該用戶標識相對應的屬性存儲字段。當存在與該用戶標識相對應的屬性存儲字段時,在步驟s402中,在該屬性存儲字段中查找是否存在與該屬性標識對應的屬性對應關系;在本發明一個實施例中,如果屬性對應關系為屬性標識與屬性值之間的對應關系,則在本步驟中,可以在該屬性存儲字段中查找是否存在包括該屬性標識的屬性對應關系;當存在包括該屬性標識的屬性對應關系時,確定該屬性存儲字段中存在與該屬性標識對應的屬性對應關系。具體地,在屬性存儲字段中,獲取第一個屬性對應關系,然后獲取該屬性對應關系中的屬性標識,判斷第一個屬性對應關系中的屬性標識是否與該屬性標識相同;當二者相同時,將第一個屬性對應關系確定與屬性標識對應的屬性對應關系;當二者不相同時,獲取第二個屬性對應關系,并獲取該屬性對應關系中的屬性標識,判斷第二個屬性對應關系中的屬性標識是否與該屬性標識相同;當二者相同時,將第二個屬性對應關系確定與屬性標識對應的屬性對應關系;當二者不相同時,繼續獲取下一個屬性對應關系,同樣執行上述流程,直至獲取的一個屬性對應關系中的屬性標識與該屬性標識相同為止,則將獲取的該一個屬性對應關系確定為與屬性標識對應的屬性對應關系。如果屬性存儲字段中所有屬性對應關系中的屬性標識都與該屬性標識不相同,則確定屬性存儲字段中不存在與屬性標識對應的屬性對應關系。其中,當不存在與該用戶標識相對應的屬性存儲字段時,結束流程。通常情況下,屬性存儲字段中存儲了多個屬性對應關系,如果該屬性標識對應的屬性對應關系存儲在屬性存儲字段中比較靠后的位置,則按照第一種方式時會將大部分屬性對應關系都遍歷一遍,耗時較長,查找效率較低。在本發明另一實施例中,如果屬性對應關系為屬性標識對應的索引標識與屬性值之間的對應關系,則在本步驟中,可以獲取屬性標識與索引標識之間的第二對應關系;在第二對應關系中查找與該屬性標識相對應的索引標識;在該屬性存儲字段中查找是否存在包括該索引標識的屬性對應關系;當存在包括該索引標識的屬性對應關系時,確定該屬性存儲字段中存在與該屬性標識對應的屬性對應關系。其中,本發明實施例中各個屬性對應關系在屬性存儲字段中的位置是根據其包括的索引標識的之間的預設索引順序進行排序后確定的。因此,為了提高查找效率,在該屬性存儲字段中查找是否存在包括該索引標識的屬性對應關系時,可以先將該索引標識與位于該屬性存儲字段的一個或多個預設位置的屬性對應關系中的索引標識進行比較,根據比較結果確定出包括該索引標識的屬性對應關系在該屬性存儲字段中的大致位置,然后將該索引標識與位于該大致位置的一個或多個屬性對應關系中的屬性索引標識進行比較,以確定出是否存在包括該索引標識的屬性對應關系。當存在與該屬性標識對應的屬性對應關系時,在步驟s403中,獲取該屬性對應關系中的屬性值。其中,當不存在與該屬性標識對應的屬性對應關系時,則說明該用戶標識對應的用戶用戶不具備該個性化屬性,可以提示該用戶標識對應的用戶用戶不具備該個性化屬性。圖5是根據一示例性實施例示出的一種信息處理裝置的框圖。參照圖5,該裝置包括:第一獲取模塊11,用于獲取用戶標識以及所述用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;生成模塊12,用于對于每一個所述個性化屬性,根據所述個性化屬性的屬性標識和屬性值生成所述個性化屬性的目標屬性對應關系;判斷模塊13,用于判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存在與所述用戶標識相對應的目標屬性存儲字段;第一存儲模塊14,用于當所述第一對應關系中存在與所述用戶標識相對應的目標屬性存儲字段時,在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系;創建模塊15,用于當所述第一對應關系中不存在與所述用戶標識相對應的目標屬性存儲字段時,創建與所述用戶標識相對應屬性存儲字段;第二存儲模塊16,用于在所述創建的屬性存儲字段中存儲所有所述目標屬性對應關系。其中,所述生成模塊12包括:第一建立單元,用于建立所述個性化屬性的屬性標識與所述個性化屬性的屬性值之間的目標屬性對應關系;或者,第一獲取單元,用于獲取已存儲的屬性標識與順序索引的索引標識之間的第二對應關系;查找單元,用于在所述第二對應關系中查找與所述屬性標識相對應的索引標識;第二建立單元,用于建立所述索引標識與所述個性化屬性的屬性值之間的目標屬性對應關系。其中,所述第一存儲模塊14包括:判斷單元,用于判斷所有所述目標屬性對應關系所占存儲空間是否小于或等于所述目標屬性存儲字段的空閑存儲空間;第一存儲單元,用于當所有所述目標屬性對應關系所占存儲空間小于或等于所述目標屬性存儲字段的空閑存儲空間時,在所述目標屬性存儲字段中存儲所有所述目標屬性對應關系;創建單元,用于當所有所述目標屬性對應關系所占存儲空間大于所述目標屬性存儲字 段的空閑存儲空間時,創建至少一個與所述用戶標識相對應的新的屬性存儲字段;第二存儲單元,用于在所述新的屬性存儲字段中存儲所有所述目標屬性對應關系或在所述目標屬性存儲字段和所述新的屬性存儲字段中存儲所有所述目標屬性對應關系。其中,所述第一存儲模塊14包括:第一確定單元,用于根據所述目標屬性對應關系中的索引標識與所述目標屬性字段中存儲的所有屬性對應關系中的索引標識確定所述目標屬性對應關系在所述目標屬性存儲字段中的待存儲位置;第三存儲單元,用于將所述目標屬性對應關系存儲在所述待存儲位置處。在本發明圖5所示的實施例中,獲取用戶標識以及該用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;對于每一個個性化屬性,根據該個性化屬性的屬性標識和屬性值生成該個性化屬性的目標屬性對應關系;判斷已存儲的用戶標識與屬性存儲字段之間的第一對應關系中是否存在與該用戶標識相對應的目標屬性存儲字段;當第一對應關系中存在與該用戶標識相對應的目標屬性存儲字段時,在目標屬性存儲字段中存儲所有目標屬性對應關系;當第一對應關系中不存在與該用戶標識相對應的目標屬性存儲字段時,創建與該用戶標識相對應屬性存儲字段;在創建的屬性存儲字段中存儲所有目標屬性對應關系。本發明實施例摒棄了現有技術中的存儲結構,首先,不會存在空字段,從而避免了空字段浪費存儲空間的問題,實現了節省存儲空間的目的;其次,現有技術中每一字段中僅僅存儲一個屬性值,而本發明實施例中一個屬性存儲字段中存儲了多個屬性對應關系,每個屬性對應關系中都包括屬性值,這樣,相對于現有技術,在本發明實施例中,相當于一個屬性存儲字段中存儲了多個屬性值,充分利用了一個屬性存儲字段中的存儲空間,從而節省了存儲空間。再次,隨著服務業務地快速發展,用戶的個性化需求層出不窮,因此常常需要開拓出新的個性化屬性,此時在現有技術中,就需要在表1的第一行的最右側新增加一個字段,并將新的個性化屬性的屬性名稱添加該新增加的字段中,然后需要在表1中的每一用戶id所在的行的最右側新增加一個字段,以使之后當某一用戶具備該新的個性化屬性時,再在該用戶id所在的行的最右側新增加的字段中填入該個性化屬性的屬性值。但是,此時表1中的每一用戶id對應的用戶并不全都具備該新的個性化屬性,因此,此時不會在全部的用戶id所在的行的最右側的新增加的字段中填入屬性值,或多或少都會導致一些字段為空字段,浪費了存儲空間。除此之外,在為表1新增加字段的過程中需要將表1鎖定,鎖定時的表1不能被使用,當表1中存儲的用戶id非常多時,也即表1中的行數非常多時,將每一用戶id所在的行 的最右側新增加一個字段會耗費較多的時間,這樣會造成表1不能被使用的時間過多,從而導致不能為用戶提供精準的服務的時間過多。而在本發明實施例中,即使開拓出新的個性化屬性,不需要為開拓出的新的個性化屬性分配字段,也就無需對存儲的個性化屬性進行鎖定,使得可以持續性不間斷地為用戶提供精準的服務,不會出現不能為用戶提供精準的服務的時間。其次,不需要與開拓出的新的個性化屬性分配字段,也就不存在出現空字段的情況,這樣就避免了浪費存儲空間的問題。圖6是根據一示例性實施例示出的一種信息處理裝置的框圖。參照圖6,該裝置包括:第一查找模塊21,用于當獲取到攜帶用戶標識和個性化屬性的屬性標識的獲取請求時,在用戶標識與屬性存儲字段之間的第一對應關系中查找是否存在與所述用戶標識相對應的屬性存儲字段;第二查找模塊22,用于當存在在與所述用戶標識相對應的屬性存儲字段時,在所述屬性存儲字段中查找是否存在與所述屬性標識對應的屬性對應關系;第二獲取模塊23,用于當存在與所述屬性標識對應的屬性對應關系時,獲取所述屬性對應關系中的屬性值。其中,所述第二查找模塊22包括:第一查找單元,用于在所述屬性存儲字段中查找是否存在包括所述屬性標識的屬性對應關系;第二確定單元,用于當存在包括所述屬性標識的屬性對應關系時,確定所述屬性存儲字段中存在與所述屬性標識對應的屬性對應關系。其中,所述第二查找模塊22包括:第二獲取單元,用于獲取屬性標識與索引標識之間的第二對應關系;第二查找單元,用于在所述第二對應關系中查找與所述屬性標識相對應的索引標識;第三查找單元,用于在所述屬性存儲字段中查找是否存在包括所述索引標識的屬性對應關系。第三確定單元,用于當存在包括所述索引標識的屬性對應關系時,確定所述屬性存儲字段中存在與所述屬性標識對應的屬性對應關系。在本發明圖6所示的實施例支持本發明圖1所示的實施例獲取用戶標識以及該用戶標識對應的至少一個個性化屬性的屬性標識和屬性值;對于每一個個性化屬性,根據該個性化屬性的屬性標識和屬性值生成該個性化屬性的目標屬性對應關系;判斷已存儲的用戶標 識與屬性存儲字段之間的第一對應關系中是否存在與該用戶標識相對應的目標屬性存儲字段;當第一對應關系中存在與該用戶標識相對應的目標屬性存儲字段時,在目標屬性存儲字段中存儲所有目標屬性對應關系;當第一對應關系中不存在與該用戶標識相對應的目標屬性存儲字段時,創建與該用戶標識相對應屬性存儲字段;在創建的屬性存儲字段中存儲所有目標屬性對應關系。在本發明圖6所示的實施例支持本發明圖1所示的實施例摒棄了現有技術中的存儲結構,首先,不會存在空字段,從而避免了空字段浪費存儲空間的問題,實現了節省存儲空間的目的;其次,現有技術中每一字段中僅僅存儲一個屬性值,而在本發明圖6所示的實施例支持本發明圖1所示的實施例中一個屬性存儲字段中存儲了多個屬性對應關系,每個屬性對應關系中都包括屬性值,這樣,相對于現有技術,在本發明圖6所示的實施例支持:本發明圖1所示的實施例中,相當于一個屬性存儲字段中存儲了多個屬性值,充分利用了一個屬性存儲字段中的存儲空間,從而節省了存儲空間。再次,隨著服務業務地快速發展,用戶的個性化需求層出不窮,因此常常需要開拓出新的個性化屬性,此時在現有技術中,就需要在表1的第一行的最右側新增加一個字段,并將新的個性化屬性的屬性名稱添加該新增加的字段中,然后需要在表1中的每一用戶id所在的行的最右側新增加一個字段,以使之后當某一用戶具備該新的個性化屬性時,再在該用戶id所在的行的最右側新增加的字段中填入該個性化屬性的屬性值。但是,此時表1中的每一用戶id對應的用戶并不全都具備該新的個性化屬性,因此,此時不會在全部的用戶id所在的行的最右側的新增加的字段中填入屬性值,或多或少都會導致一些字段為空字段,浪費了存儲空間。除此之外,在為表1新增加字段的過程中需要將表1鎖定,鎖定時的表1不能被使用,當表1中存儲的用戶id非常多時,也即表1中的行數非常多時,將每一用戶id所在的行的最右側新增加一個字段會耗費較多的時間,這樣會造成表1不能被使用的時間過多,從而導致不能為用戶提供精準的服務的時間過多。而在本發明圖6所示的實施例支持:本發明圖1所示的實施例中,即使開拓出新的個性化屬性,不需要為開拓出的新的個性化屬性分配字段,也就無需對存儲的個性化屬性進行鎖定,使得可以持續性不間斷地為用戶提供精準的服務,不會出現不能為用戶提供精準的服務的時間。其次,不需要與開拓出的新的個性化屬性分配字段,也就不存在出現空字段的情況,這樣就避免了浪費存儲空間的問題。關于上述實施例中的裝置,其中各個模塊執行操作的具體方式已經在有關該方法的實施例中進行了詳細描述,此處將不做詳細闡述說明。本領域技術人員在考慮說明書及實踐這里公開的發明后,將容易想到本發明的其它實施方案。本申請旨在涵蓋本發明的任何變型、用途或者適應性變化,這些變型、用途或者 適應性變化遵循本發明的一般性原理并包括本發明未公開的本
技術領域:
中的公知常識或慣用技術手段。說明書和實施例僅被視為示例性的,本發明的真正范圍和精神由所附的權利要求指出。應當理解的是,本發明并不局限于上面已經描述并在附圖中示出的精確結構,并且可以在不脫離其范圍進行各種修改和改變。本發明的范圍僅由所附的權利要求來限制。當前第1頁12