The present invention relates to a Personal Information Manager (PIM) service, namely data synchronization service, of terminals in the field of communication, and particularly, to a method for searching, updating and synchronizing a change log item and a data synchronizing device.
Managements on personal information of terminals such as cellphones and Personal Digital Assistants (PDA), schedule information and mail information and so on have become an important component of terminal information management. How to backup data into a network server safely and effectively and restore the backup data to a terminal conveniently when the terminal is replaced or data of the terminal are changed has become a theme of data synchronization. A SyncML protocol can implement the data synchronization between the terminal and network server, which makes data on the terminal and on the network server stay consistent ultimately.
In order to implement fast and efficient synchronization between the terminal and server, a mode of increment synchronization is normally used. The increment synchronization refers to synchronizing the data updating between the last synchronization and the current synchronization. The fast synchronization in the SyncML protocol is precisely a mode of increment synchronization.
In order to implement the increment synchronization, the terminal or server need to record the data updating of an entity (e.g. a phonebook record) between the last synchronization and the current synchronization in a database (e.g. a phonebook), namely a change log. The change log exists as a file generally and consists of individual change log items. Each change log item indicates change information of one updated entity, which includes information such as a unique identifier (assigned by the database to every entity), a type of the operation on the entity, and optionally, data of the updated entity and so on. In addition, change log items in the change log normally grow backward in the order of the modified time of the updated entity.
In the related art, generally, when entities (no matter an identical entity or different entities) are operated (modified) at a time, one change log item will be added into the change log. By this mode, with the increase of the number of times of data updating, the change log will become increasingly larger and grow limitlessly.
In order to limit the unlimited increase of the change log, a normally used scheme is that: with regard to each entity, only at most one change log item of the entity exists in the change log, that is, when one entity is modified, and before a corresponding change log item is added into the change log, firstly it is to query whether the change log item of the entity has existed in the change log; if yes, it is to modify the change log item corresponding to the entity according to a certain kind of superposition policy; if not, it is to add one change log item corresponding to the entity into the change log.
With the above scheme, although a size of the change log can be limited, a mode of ergodic search needs to be used to search out whether the change log item corresponding to the entity exists in the change log. Furthermore, with regard to the modification at any one time, no matter whether the change log item corresponding to the entity exists in the change log or not, a flow of the above ergodic search is required to be executed once, which will affect the search speed and efficiency seriously.
The object of the present invention is to provide a method for searching, updating and synchronizing a change log item in a change log and a data synchronizing device, to overcome the problem that the efficiency of searching change log items is low in the related art.
In order to solve the above problem, the present invention provides a method for searching a change log item, which comprises:
Wherein, the search algorithm of elements in the ordered sequence comprises: a binary search algorithm.
The present invention further provides a method for updating a change log item, which comprises:
Wherein, the step of adding a change log item corresponding to the current updating into the change log comprises: after adding the change log item corresponding to the current updating to any position in the change log, ordering the change log items in the change log according to the numerical values of the entity identifiers.
Wherein, the step of adding a change log item corresponding to the current updating into the change log comprises: according to an interpolation algorithm for the elements in the ordered sequence, processing the entity identifier in the change log item, and adding the change log item corresponding to the current updating to a relevant position in the change log.
Wherein, the interpolation algorithm for the elements in the ordered sequence comprises: binary interpolation algorithm.
Wherein, the search algorithm of elements in the ordered sequence comprises: a binary search algorithm.
The present invention further provides a method for synchronizing a change log item, which comprises:
The above method further comprises:
The present invention further provides a data synchronizing device, which comprises: a storage unit and a search unit;
The above device further comprises an update unit;
Wherein, the update unit is configured to:
The above device further comprises a synchronization unit;
Wherein, the search algorithm of elements in the ordered sequence comprises: a binary search algorithm.
The present invention further provides a data synchronizing device, which comprises a synchronization unit, wherein, the synchronization unit is configured to: when data synchronization is performed with an opposite end device, synchronize data corresponding to change log items saved in a change log to the opposite end device; and after the synchronization is completed, save all change log items which are synchronized unsuccessfully, and order all the change log items which are synchronized unsuccessfully according to numerical values of entity identifiers contained in the items.
With the present invention, not only a size of the change log can be limited to make the file maintenance simple, but also the search speed for change log items can be improved greatly since the speed for searching the ordered sequence is much faster than the speed of the ergodic search.
a) is a schematic diagram of adding a new change log item with an entity identifier being 6 to the end of the change log directly according to the example of the present invention.
b) is a schematic diagram of a reordered change log according to the example of the present invention.
The technical scheme of the present invention will be described in detail in combination with the accompany drawings and examples below.
The basic conception of the searching method of the present invention is: in a change log of a data synchronizing device (e.g. a terminal such as a cellphone or a Personal Digital Assistant (PDA), a server or any other device which can implement data synchronization), ordering change log items according to numerical values of entity identifiers contained in the items; in the data synchronizing device, when data updating occurs in an entity in a database of the data synchronizing device, using a search algorithm of elements in an ordered sequence to search out whether a change log item containing an entity identifier exists in the above change log.
Correspondingly, as shown in
To implement the step of still ordering the change log items in the change log for which the addition is completed according to the numerical values of the entity identifiers contained in the items, any one of the following two modes can be used:
In mode 1, when the change log items are added into the change log, the change log item corresponding to the current updating can be added to any position in the above change log (preferably, it can be added to the end of the change log); after the addition is completed, the change log items are reordered according to the numerical values of the entity identifiers contained in the change log items in the change log.
In mode 2, when the change log items are added into the change log, the entity identifier in the change log item can be processed according to an interpolation algorithm for the elements in the ordered sequence, and the change log item corresponding to the current updating is added to a relevant position in the change log.
After the above updating method is used, a brand new ordered change log can be obtained, and the change log is operated circularly as such, which not only makes the file maintenance simpler, but also improves the search speed for change log items greatly. In a word, in the present invention, ordering and interpolating for the change log are integrated into the synchronization, thus implementing a fast search for the change log items in the change log.
When the above data synchronizing device needs to perform data synchronization with other devices, and as shown in
After the synchronization is finished, if an update operation is performed on a certain entity or certain entities in the database, the above refreshed change log is updated in accordance with the update operation according to the above updating method.
One application example of the present invention is used to perform a further description below.
SyncML protocol synchronizing phonebook database is taken as an example.
The entity identifier: LUID, which is a unique ID number assigned by the phonebook database to every entity in the phonebook.
The operation type with FLAG: its value can be from 0 to 3. Wherein, 0 represents invalidity, 1 to 3 all represent validity, 1 represents ADD, 2 represents DELETE and 3 represents UPDATE.
After the synchronization is finished, a ordering operation is executed on each change log item which is synchronized unsuccessfully in the change log, including:
After the synchronization is finished, all the change log items which are synchronized unsuccessfully are precisely the valid change log items indicated by the value of the FLAG in the change log.
When a certain datum (and a certain entity) in the phonebook are updated, following steps are included:
If another operation is performed on an entity with an identifier being 5 in
If an addition operation is performed on an entity with an entity identifier being 6, a change log item corresponding to this modification is required to be added into the change log. After the above interpolation algorithm is used, the change log item will be added between the change log items with entity identifiers being 5 and 7, as shown in
If the addition operation is performed on an entity with an entity identifier being 6, a change log item corresponding to this modification is required to be added into the change log.
As shown in
With the above two schemes, a brand new ordered change log can be obtained. It is assumed that, in a general scheme, the change log items in the change log are in a disordered arrangement: (the numbers represent the entity identifiers contained in the change log items in the change log)
1 4 3 9 7 12 17 15 20
However, if an ordered arrangement is used for the change log items in the change log, the order is:
1 3 4 7 9 12 15 17 20
If a common searching method of element in the ordered sequence—a binary searching method—is used to find the change log item with the identifier being 15, only 2 times are required. The worst condition is to search for 20, and only 4 times are required. It is because that the complexity of the binary searching method is O (log2 N).
When N is equal to 1000, with regard to the ergodic search, it needs to search 1000 times in the worst condition; but with regard to the binary search, it only needs to search 10 times at worst. Therefore, the search speed is improved greatly.
In the general scheme, the same as the above first sequence, it is assumed that a change log record with an identifier being 13 is required to be added into the change log, thus 13 will be arranged behind 20 in the general scheme, that is:
1 4 3 9 7 12 17 15 20 13
In the description, when the Contact Manager is modified, and assuming that change log records are newly added, in order to add the newly modified change log records into the change log, two methods can be used:
In method 1, a binary interpolation method can be used, that is, the binary searching method is used, a position in which the records should be interposed is found, and the new change log items are directly interposed into the change log orderly, to keep the change log in order all the time in the process of updating the database. Similarly, the complexity of the binary interpolation method is O (log2 N). When N is 1000, even in the worst condition, it only needs 10 times of search to achieve an ordered change log.
In method 2, the new change log items can be added to the end of the change log directly, and then one reordering operation is performed on all change log items in the change log, and the purpose of ordering also can be achieved.
Although an interpolation is used in method 1, only the binary search is executed in fact, and even if N is equal to 1000, it only needs to search 10 times at worst. That is to say, with regard to N=1000, the times for interposing and searching in order are 20 in total at most, but with regard to the disordered ergodic, it needs to search 1000 times in the worst condition. Therefore, the complexity is reduced greatly with the present invention.
In conclusion, with the present invention, the search speed for the change log items is improved greatly. In the present invention, not only the unlimited increase of the file can be limited to make the file maintenance simpler, but also the search speed for the change log items can be improved greatly.
In addition, the present invention further provides a data synchronizing device, which comprises: a storage unit and a search unit;
The above device can further comprise an update unit;
Furthermore, that the update unit is used to add a change log item corresponding to the current updating into the change log refers to that, the update unit is used to add the change log item corresponding to the current updating to any position in the change log, and then order the change log items in the change log according to the numerical values of the entity identifiers; or, the update unit is used to process the entity identifier in the change log item according to an interpolation algorithm of elements in an ordered sequence, and add the change log item corresponding to the current updating to a relevant position in the change log.
The above device can further comprise a synchronization unit; when data synchronization is performed with an opposite end device, the synchronization unit is used to synchronize data corresponding to change log items saved in the change log to the opposite end device; and after the synchronization is completed, the synchronization unit is also used to save all change log items which are synchronized unsuccessfully, and order all the change log items which are synchronized unsuccessfully according to the numerical values of the entity identifiers contained in the items.
The present invention further provides a data synchronizing device, which comprises a synchronization unit, wherein,
Certainly, the present invention can still have other various examples, any person skilled in the art can make various corresponding changes and transformations according to the present invention without departing from the spirit and essence of the present invention, and these corresponding changes and transformations shall all fall into the protection scope of the appended claims of the present invention.
With the present invention, not only a size of the change log can be limited to make the file maintenance simple, but also the search speed for change log items can be improved greatly since the speed for searching the ordered sequence is much faster than the speed of the ergodic search.
Number | Date | Country | Kind |
---|---|---|---|
200910262788.2 | Dec 2009 | CN | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CN2010/072158 | 4/23/2010 | WO | 00 | 6/26/2012 |