EP1490770A1 - Method and system for server-based operations in server synchronization with a computing device - Google Patents
Method and system for server-based operations in server synchronization with a computing deviceInfo
- Publication number
- EP1490770A1 EP1490770A1 EP03716180A EP03716180A EP1490770A1 EP 1490770 A1 EP1490770 A1 EP 1490770A1 EP 03716180 A EP03716180 A EP 03716180A EP 03716180 A EP03716180 A EP 03716180A EP 1490770 A1 EP1490770 A1 EP 1490770A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- database
- data
- information
- handheld device
- synchronization
- 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.)
- Ceased
Links
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/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
- G06F16/273—Asynchronous replication or reconciliation
-
- 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/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
Definitions
- This disclosure relates generally to computer systems, and in particular but not exclusively, relates to transferring data from one computer system into another.
- Portable computing devices such as personal digital assistants (PDAs) available from vendors such as Palm, Handspring, Hewlett Packard, Sony, Casio, Psion, have found increasing acceptance in the business world.
- PDAs personal digital assistants
- Some users have a need to use their handheld devices to interact with enterprise business applications such as those offered by Siebel Systems, Inc., Oracle Corporation and others.
- enterprise business applications can include large databases that a number of user may access and/or update at any time.
- Providing access to enterprise business applications through a handheld device can encounter significant problems due to the relatively limited amount of computing power, energy storage and memory available on typical handheld devices. For example, a user may wish to extract data that resides in a server used in supporting an enterprise business application. In view of the limited resources of the handheld device, it is generally desirable that the handheld device be designed and configured to efficiently receive the extracted data.
- a method and system for synchronizing a main database of a server and a local database of a handheld device.
- a user can use an application residing in the handheld device to make transactions in the local database.
- the handheld device is associated with a synchronization client configured to: (1) establish a connection between a server and the synchronization client; (2) receive an identifier for the main database's structure from the server; (3) receive an identifier for the version of the handheld application; (4) send transaction information to the server; (5) receive metadata to update the handheld application; and (6) receive data extracted from the main database from the server.
- This aspect advantageously allows the system to determine which database data and metadata are needed by the handheld device during synchronization, as well as to upload the transactions made by the user in the local database.
- the synchronization client is configured to determine whether to download to the handheld device a full extract of the main database or the download a delta extract (i.e., only the data that in the main database that has changed since the last synchronization operation).
- This aspect can advantageously allow the system to perform a delta extract download when appropriate to reduce the time needed to complete ⁇ synchronization operation.
- the synchronization client is configured to update filter information used by the server to filter the data from the main database to be downloaded to the handheld device.
- Figure 1 is a block diagram illustrating a system having a main database that is accessible to users through handheld devices, in accordance with one embodiment of the present invention.
- Figure 2 is a diagram illustrating dataflow between a handheld device and another computer system, according to one embodiment of the present invention.
- Figure 3 is a top-level block diagram illustrating components of a server and a client used in synchronizing a handheld device, according to one embodiment of the present invention.
- FIG. 4 is a more detailed block diagram illustrating components of a handheld device used in synchronizing the handheld device directly with the server, according to one embodiment of the present invention.
- Figure 5 is a diagram illustrating components of a companion device and a handheld device used in synchronizing the handheld device with the server through the companion device, according to one embodiment of the present invention.
- Figure 6 is a flow diagram illustrating a synchronization process of a client, according to one embodiment of the present invention.
- Figure 7 is a flow diagram illustrating a transaction processing operation, according to one embodiment of the present invention.
- Figure 8 is a flow diagram illustrating a send transaction operation, according to one embodiment of the present invention.
- Figure 9 is a flow diagram illustrating a metadata update operation, according to one embodiment of the present invention.
- Figure 10 is a flow diagram illustrating a data extraction operation, according to one embodiment of the present invention.
- Figure 10A is a diagram illustrating filters, according to one embodiment of the present invention.
- Figure 11 is a flow diagram illustrating a filter processing operation, according to one embodiment of the present invention.
- Figure 12 is a flow diagram illustrating in more detail a filter processing operation, according to one embodiment of the present invention.
- Figure 13 is a flow diagram illustrating a data extract operation, according to one embodiment of the present invention.
- Figure 14 is a flow diagram illustrating a compression operation, according to one embodiment of the present invention.
- Figure 15 is a flow diagram illustrating a synchronization process of a server, according to one embodiment of the present invention.
- Figure 16 is a flow diagram illustrating a send database data operation, according to one embodiment of the present invention.
- Embodiments of a system and method for detecting insufficient memory conditions during data extraction processes are described herein.
- numerous specific details are set forth to provide a thorough understanding of embodiments of the invention.
- One skilled in the relevant art will recognize, however, that the invention can be practiced without one or more of the specific details, or with other methods, components, materials, etc.
- well-known structures, materials, or operations are not shown or described in detail to avoid obscuring aspects of the invention.
- terms such as “processing”, “computing”, “calculating”, “determining”, “displaying” or the like refer to actions and processes of a computer system, or other similar electronic computing device.
- these actions and processes manipulate and transform data represented as physical quantities (as described above) within the computer system's registers and memories into other data similarly represented as physical quantities with within the computer system's memories or registers or other information storage, transmission or display devices.
- the present invention also relates to one or more apparatus for performing the operations described herein.
- An apparatus may be specially constructed for the required purposes, or include a general-purpose computer selectively activated or configured by a computer program stored in the computer.
- a computer program may be stored in a computer readable storage medium such as, but not limited to, any type of disk including floppy disks, optical disks, compact disks (CDs) and magnetic-optical disks.
- Other storage mediums include: read only memories (ROMs) including erasable and electrically erasable programmable ROMs (EPROMs and EEPROMs); random access memories (RAMs) including static and dynamic RAMs; and magnetic or optical cards.
- FIG. 1 illustrates a system 100 having a database that is accessible to users through handheld devices, in accordance with one embodiment of the present invention.
- System 100 includes a main computer system 110 having a main database 112 and a server connected to database 112.
- the server is implemented with a server 114.
- the server is implemented with a server 116 that includes a synchronization engine (sync engine) 118.
- main computer system 110 may include both server 114 and server 116. Servers 114 and 116 are both shown in Figure 1 for convenience; however, one of the servers may be omitted in the aforementioned first and second embodiments.
- System 100 also includes handheld devices that users may use to remotely access main database 112. Handheld devices 120-1 , 120-2, 120- 3, 120-4 and 120-5 are shown in Figure 1. When server 114 is present in system 100, a user may remotely access main database 112 using handheld device 120-1 via a connection 122 to server 114.
- connection 122 is implemented using a standard telephone modem and the serial interface defined by the handheld device manufacturer.
- a user may remotely access main database 112 via an intermediary computing device (also referred to herein as a companion device) 124, which is connected to server 114 via a connection 126.
- companion device 124 is a more powerful computing device (i.e., having more memory, a processor with better performance, a larger power supply, etc.) than typical handheld devices.
- a companion device may be a desktop or notebook computer.
- Handheld device 120-2 and companion device 124 transfer information over a connection 127.
- connection 127 is implemented using a serial interface typically provided with the handheld device.
- connection 127 may be implemented using a serial port, parallel port, or other bus protocol.
- Some handheld devices include a cradle assembly that provides the physical interconnection between the handheld device and a companion device.
- companion device 124 includes synchronization engine (sync engine) 128 and a synchronization manager (sync manager) 130.
- Sync engine 128 performs a similar function as sync engine 118 of server 116.
- sync manager 130 and sync engines 118 and 128 are implemented in software that is executed by one or more processors of companion device 124 or server 116.
- this embodiment of handheld device 120-1 includes a sync engine and sync manager serving essentially the same functions as sync engine 128 and sync manager 130.
- connection 132 can be a telephone modem connection as previously described for connection 122, or any other type of connection supported by both server 116 and handheld device 120-3.
- this embodiment of handheld device 120-3 includes a sync manager that provides essentially the same functions as sync manager 130.
- server 116 includes sync engine 118, allowing devices that access main database 112 via server 116 to dispense with having their own sync engines.
- a user may access main database 112 using handheld device 120-4 through a companion device 134, which is connected to handheld device via a connection 136.
- Connection 136 is typically the serial interface that is provided by the handheld device vendor.
- Companion device 134 is connected to server 116 via a connection 138.
- handheld device 120-4 includes a sync manager component (not shown) similar to that of handheld device 120-3.
- Companion device 134 includes an interface component (also referred to herein as a proxy) 140 that allows data transfers between server 116 and handheld device 120-4, which may be different.
- connection 138 i.e., the server-companion device connection
- connection 136 i.e., the companion device-handheld device connection
- interface component 140 serves, in effect, as a proxy between server 116 and handheld device 120-4.
- a user may access main database 112 using handheld device 120-5 through a companion device 144, which is connected to handheld device 120-5 via a connection 146.
- companion device 144 includes a sync manager 148, which communicates with server 116 via a connection 150.
- Sync manager 148 of companion device 144 allows handheld device 120-5 to dispense with having a sync manager component.
- main database 112 may access main database 112 using a handheld device via each of the five above paths (i.e., communication paths between main database 112 and handheld devices 120-1 through 120-5).
- a handheld device via each of the five above paths (i.e., communication paths between main database 112 and handheld devices 120-1 through 120-5).
- FIG. 1 although only one handheld device 120-3 is shown in Figure 1 as directly coupled to server 116, several users can access main database 112 in the essentially the same way using handheld devices that are configured in the substantially the same way as handheld device 120-3.
- system 100 may be implemented with various combinations or permutations of the five paths described above.
- system 100 may be implemented to support only the paths between main database 112 and handheld devices 120-3 (via server 116 and direct connection 132) and 120-4 (via server 116 and companion device 134).
- This exemplary embodiment allows a handheld device that is configured with a sync manager to perform either a direct synchronization or a companion synchronization (via proxy 140).
- any suitable connection can be used in other embodiments.
- other embodiments may use protocols other than HTTP.
- the signal propagation mediums used by the connections may be wired (e.g., using mediums such as twisted pair, cable, and optical fiber) or wireless (e.g., using technologies such as infrared, radio-frequency and optical technologies).
- One of the functions of system 100 is to synchronize selected information between main computer system 110 and a handheld device.
- the information may be database data stored in main database 112 and a local database (not shown) in a handheld device.
- the database data is updated frequently by users.
- the updated database data is distributed to users via synchronization processes.
- the information to be synchronized may include definitions (also referred to herein as metadata) used by an application executed in the handheld device.
- Figure 2 illustrates dataflow between a handheld device 202 and another computer system 204 in synchronizing data, according to one embodiment of the present invention.
- computer system 204 may be implemented by: (a) one of servers 114 or 116; or (b) companion device 124; or (c) companion device 134 combined with one of servers 114 or 116; or (d) companion device 144 combined with one of servers 114 or 116.
- handheld device 202 can initiate a connection with computer system 204 as indicated by arrow 210 in Figure 2.
- handheld device 202 initiates this connection with computer system 204 by logging in using a modem (e.g., via an Internet connection).
- this connection may be a standard HTTP connection.
- handheld device 202 may initiate this connection with a companion device using the synchronization interface application and hardware provided by the handheld device vendor. For example, this connection may be initiated when the user places handheld device 202 into a supplied cradle accessory and activates a synchronization button on the cradle.
- computer system 204 then provides initialization data to handheld device 202, and indicated by arrow 212 in Figure 2.
- the initialization information can include information related to the latest version of main database 112. For example, a new table may have added to main database 112.
- the initialization information may include information related to the most recent transaction (see description below) uploaded to computer system 204.
- handheld device 202 pulls this initialization information after the connection is established.
- computer system 204 may push the initialization information to handheld device 202 in response to the connection being established.
- this application definition information can include information related to definitions used in the application that the user uses to access the local database of handheld device 202 (also referred to herein as the handheld application).
- this application definition information can include the views and screens displayed by the handheld application in providing a user interface.
- handheld device 202 determines if its local application definition needs to be updated (using the initialization information) and if so, pulls this information from computer system 204.
- computer system 204 may receive information from handheld device 204 that indicates the version of its application definition. Computer system 204 can then determine whether handheld device 202 needs updated application definition information, and if so, push the updated application definition to handheld device 202.
- Handheld device 202 can transfer transaction information to computer system 204, as indicated by an arrow 214 in Figure 2. In one embodiment, all of the local database transactions entered into handheld device 202 by the user are recorded. This recorded transaction information is transferred to computer system 204, which then performs the transactions in main database 112 ( Figure 1). In some embodiments, handheld device 202 transfers the transaction information in one block to computer system 204. After the entire block has been received, computer system 204 would determine whether the block was properly received. In other embodiments, handheld device 202 transfers the transaction information in a number of relatively small blocks. After each small block is received, computer system 204 can determine whether that block was properly received and send a message or signal to handheld device 202 to either retransmit that block or send the next block. Thus, if there is a problem or interruption during the transfer, handheld device 202 need only transfer the blocks that have not been properly received, rather than retransmitting all of the transaction information.
- Computer system 204 can then transfer error information to handheld device 202, as indicated by an arrow 216 in Figure 2.
- this error information includes: (a) information on transactions that system 100 ( Figure 1) does not permit the user to make transactions on data that was also changed by other one or more other users; and (b) information on changes made to the transactions by the server. The user can then manually correct or dispose of these errors on handheld device 202.
- handheld device 202 and computer system 204 can update filter settings, as shown by arrow 218 in Figure 2.
- the filter settings are set so that unwanted or unneeded information is not transferred between handheld device 202 and computer system 204, thereby conserving limited resources on handheld device 202.
- a user can update filter settings for handheld device 202 and then upload them to computer system 204.
- computer system 204 can then avoid downloading information that the user does not want.
- computer system 204 processes the filter settings received from handheld device 202 to ensure that the filter settings are proper. For example, the user may have attempted to filter out information that is required by an application running on handheld device 202 to properly execute.
- Computer system 204 can then transfer database data to handheld device 202, as indicated by an arrow 220 in Figure 2. This operation is also referred to herein as "data extraction.” In one embodiment, computer system 204 forms an image of all of the database data that is visible to handheld device 202 and after being filtered. This image is also referred to herein as an extract. Computer system 204 then downloads this extract to handheld device 202. In one embodiment, computer system 204 downloads the extract in a series of relatively small blocks, with handheld device 202 acknowledging the reception of each small block.
- computer system 204 stores the extract after each download.
- computer system 204 can compare the current extract with the previous extract and download only the database data that has changed (also referred to herein as a delta extract). The previous extract can then be deleted.
- computer system 204 may ignore the previous extract and, instead, download the entire current extract. For example, if the structure of main database 112 ( Figure 1) changed since the previous extract, then computer system 204 would then perform a full extract rather than attempt to perform a delta extract. Handheld device 202 can then disconnect from computer system 204, as indicated by an arrow 222 in Figure 2.
- Figure 3 illustrates components of sync engine 116 ( Figure 1) and a handheld device 300 used in a synchronizing operation, according to one embodiment of the present invention.
- Handheld device 300 can be used to implement any of handheld devices 120-3 through 120-5 ( Figurel).
- sync engine 116 includes a metadata extractor 301 , a transaction processor 303 and a data extractor 305.
- Handheld device 300 includes a local database 308 and a synchronization client (sync client) 310 having a metadata importer 311 , a transaction recorder 313 and a data importer 315.
- sync client 310 and its components are implemented in software.
- Metadata generator/extractor 301 of sync engine 116 is operatively coupled to metadata importer 311 of sync client 310, as indicated by a dashed line 317.
- Transaction processor 303 of sync engine 116 is operatively coupled to transaction recorder 313 of sync client 310, as indicated by a dashed line 319.
- Data extractor 305 of sync engine 116 is operatively coupled to data importer 315 of sync client 310 as indicated by a dashed line 321.
- Sync client 310 can access local database 308 as indicated by a line 323.
- Metadata generator/extractor 301 extracts the metadata (stored in a particular format in server 116) and forms messages or datagrams containing the metadata for transmission to sync client 310.
- Metadata importer 311 of sync client 310 processes the metadata sent by metadata generator/extractor 301 to update the handheld application in handheld device 300. For example, in one embodiment, metadata importer 311 can determine whether handheld device has enough memory to store the metadata before requesting sync engine 116 to download the metadata. After handheld device 300 stores the metadata, metadata importer 311 can then update the handheld application (not shown) with the new application definitions included in the metadata.
- metadata importer 311 can determine whether handheld device has enough memory to store the metadata before requesting sync engine 116 to download the metadata. After handheld device 300 stores the metadata, metadata importer 311 can then update the handheld application (not shown) with the new application definitions included in the metadata.
- transaction recorder 313 in handheld device 300 records information related to transactions to local database 308 made by the user. For example, each time the user changes data in local database 308, transaction recorder 313 assigns a transaction identifier (transaction ID) and records the transaction ID and other pertinent information about the transaction. In another embodiment, the transaction ID can be assigned when a synchronization process is performed.
- the above-mentioned other pertinent information can include, for example, the field being changed, the previous and new data, record identifiers and names, and specifications of record relationships that can be used by server 116 to find the changed record or create the new record on main database 112 ( Figure l).
- Transaction recorder 313 can then upload the transactions to transaction processor 303 of sync engine 116.
- Transaction processor 303 receives the transactions from handheld device 300 and performs each transaction to update main database 112 ( Figure 1). A transaction may conflict with another transaction from another user, in which case transaction processor 303 reports an error without performing the transaction. One embodiment of this operation is described in more detail below in conjunction with Figure 7. In another embodiment, transaction processor 303 modifies one or more portions of the transaction so that the transaction will succeed. Transaction processor 303 can then send a message to handheld device 300 informing the user of the modification that was performed.
- data extractor 305 of sync engine 116 extracts database data that is visible to handheld device 300 from main database 112 ( Figure 1).
- the term visibility has a well-known meaning remote access of databases (see for example, U.S. Patents 6,216,135 and 6,233,617).
- data extractor 305 can avoid extracting data according to the filter settings (described previously in conjunction with arrow 218 of Figure 2).
- Data extractor 305 also forms the extracted database data into file to be downloaded to handheld device 300.
- sync engine 116 may send the file to handheld device 300 in a series of small messages or datagrams.
- Data importer 315 of handheld device 300 receives the file and temporarily stores the file for updating local database 308.
- the file may contain the updated database data in a format that is different from that of local database 308.
- a separate component may be used to process the data into the format of local database 308.
- FIG 4 illustrates handheld device 120-3 ( Figure 1), according to one embodiment of the present invention.
- handheld device 120-3 is configured to synchronize directly with server 116.
- handheld device 120-3 is configured with a sync client 401 , a synchronization log (sync log) 403, a transaction database 405, a data storing application (also referred to herein as a data storer) 407 and a datastore 409.
- sync client 401 performs the substantially similar functions as described for sync managers 130 and 148 ( Figure 1) that reside in companion devices.
- sync client 401 performs the functions of metadata importer 311 , transaction recorder 313 and data importer 315 of sync client 310 ( Figure 3).
- Sync log 403 is used to hold a list of all messages sent during synchronization operations (e.g., see the operations of Figure 2), which can then be used to restore information if a problem occurs during synchronization.
- Transaction database 405 is used to store information related to each transaction (e.g., the information generated by transaction recorder 313 of Figure 3).
- sync manager stores the transaction information in transaction database 405.
- the handheld application (not shown) stores the transaction information in transaction database 405.
- Data storer 407 is used in this embodiment to process the downloaded database data to be in the format of local database 308.
- Datastore 409 is used to store filter settings, the version of local database 308, the version of the handheld application (not shown), a file defining the schema of the local database, and the aforementioned application definitions from the metadata. Datastore 409 is also used to store transaction error messages. In this embodiment, the versions of the local database and the handheld application are referred to herein as the extraction ID and the repository ID, respectively. In some embodiments, datastore 409 can include the operating system's registry (e.g., as in a Windows or Linux operating system).
- Sync client 401 is operatively coupled to local database 308, sync log 403, transaction database 405, data storer 407 and datastore 409.
- Sync client 401 is also operatively coupled to server 116 ( Figure l) via connection 132.
- data storer 407 is operatively coupled to local database 308.
- Figure 5 illustrates components of handheld device 120-2 ( Figure 1) and companion device 124 ( Figure 1), according to one embodiment of the present invention.
- This embodiment of handheld device 120-2 and companion device 124 together contain components similar to the those described above in handheld device 120-3 ( Figure 4).
- handheld device 120-2 is configured with local database 308, transaction database 405, data storer 407 and datastore 409.
- Companion device 124 is configured with a sync client 501 and a sync log 503, both of which perform functions similar to that of sync client 401 ( Figure 3) and sync log 403 ( Figure 3) of handheld device 120-3.
- companion device 124 is configured with a client sync engine 505 and a companion local database 508.
- Client sync engine 505 provides functions similar to that of sync engine 118 ( Figure 1) in accessing main database 112 ( Figure 1).
- sync client 501 is operatively coupled to local database 308, transaction database 405, data storer 407, and datastore 409 of handheld device 120-2.
- the interconnection can be implemented through connection 127 ( Figure 1).
- sync client 501 is operatively coupled to sync log 503, client sync manager 505 and companion local database 508.
- companion local database 508 can store an image of local database 405 of handheld device 120-2.
- companion device 124 can be configured to synchronize companion local database 508 with main database 112 ( Figure 1). A subsequent synchronization of handheld device 120-2 will synchronize its local database 308 with the now synchronized companion local database 508.
- Figure 6 illustrates the operation of a sync client during a synchronization process, according to one embodiment of the present invention.
- the sync client is a handheld device with a direct connection to a server.
- the handheld device and server can be handheld device 120-3 ( Figure 4) and server 116 ( Figure 1).
- the sync client can be implemented by the combination of a companion device and handheld device (e.g., companion device 124 and handheld device 120-2 as in Figure 5).
- the operation of the sync client is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure l).
- those skilled in the art will appreciate that the following description can apply to other types of sync clients without undue experimentation.
- sync client 401 connects with the server (or companion device in other embodiments).
- sync client 401 connects to server 116 when the user performs a login process.
- sync client 401 executes an interface or driver that operates a modem to directly access server 116.
- this connection may be an Internet connection.
- the connection can be a wireless connection using RF or optical technology to implement a direct, web-based or other type of communication link.
- sync client 401 receives initialization data.
- sync client 401 receives initialization data from server 116 via connection 132.
- this initialization data can include information related to the latest version of the main database 112 (e.g., the extraction ID), the latest transaction uploaded to server 116 and the latest version of the handheld application (e.g., the repository ID).
- sync client 401 stores the initialization information in datastore 409.
- the sync client can receive the application definition version. Block 605 may be omitted if the handheld application definition is included as part of the initialization data received in block 603.
- server 116 sends the application definition version (which may have been updated) to sync client 401.
- Sync client 401 may compare the newly received application definition version with the application version already stored in datastore 409 (i.e., the current version of the handheld application).
- Sync client 401 then stores the new application definition version in datastore 409.
- the sync client can provide transaction information to the server or companion device.
- sync client 401 sends the transaction information stored in transaction database 405 to server 116.
- sync client 401 may send the transaction information for all of the recorded transactions in one block of data.
- sync client 401 may send the transaction information in several smaller blocks, waiting for an acknowledgement from server 116 before sending the next smaller block. Embodiments of this operation are described in more detail below in conjunction with Figures 7 and 8.
- the sync client can get metadata from the server.
- sync client 401 receives the metadata from server 116.
- this metadata includes application definitions for the handheld application.
- sync client 401 performs block 609 if the application definition version received in block 605 does not match the locally stored application definition version (e.g., this situation may occur when the application definitions have been updated).
- sync client 401 does not compare the application definition versions but rather always requests the metadata from server 116. Server 116 would then determine whether the application definitions need to be updated.
- the sync client updates its local database.
- sync client 401 requests that server 116 initiates a data extraction operation to provide updated database data to handheld device 120-3.
- the user may cause sync client 401 to update filters before getting the database data from server 116.
- server 116 will avoid downloading data undesired database data, which helps conserve battery power and reduce the time needed to complete the synchronization process.
- server 116 downloads the entire data extract (i.e., the data visible to the sync client and after filtering) in a single large block.
- server 116 may download a relatively small block of the data extract in response to a request by sync client 401. If handheld device 120-3 properly receives this block, sync client 401 can send a request for the next block, on so on until handheld device 120-3 receives the entire extract from server 116.
- sync client 401 can first determine whether to receive a full extract or a delta extract. For example, if the version of the database has changed (see block 603), sync client 401 can then request a full extract from server 116. However, if the version of the database has not changed, then sync client 401 can request a delta extract from server 116. For example, in a delta extract, server 116 would compare the full extract of the previous download to handheld device 120-3 to the current full extract. Server 116 would then only download records from the current full extract that are different from the corresponding records in the previous extract.
- the sync client disconnects from the server (or companion device).
- sync client 401 in response to input from the user, performs a log out process to disconnect from server 116.
- FIG. 7 illustrates one embodiment of block 607 ( Figure 6) in more detail, in accordance with the present invention.
- a sync client performs the operations of Figure 7.
- the sync client resides in handheld device 120-3 that has a direct connection with server 116.
- the transaction processing operation of block 607 is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure 1).
- block 607 is performed as follows in this exemplary embodiment.
- the sync client receives information related to the last transaction uploaded to the server or (companion device).
- sync client 401 gets a transaction identifier (transaction ID) from server 116. This transaction ID is the identifier of the last transaction received by server 116.
- handheld device 120-3 generates a transaction ID using a pseudo-unique ID generator when initialized. In another embodiment, ID generation is guaranteed to be unique.
- Sync client 401 increments this pseudo-unique ID each time handheld device 120-3 uploads information recorded for a transaction (also referred to herein as "uploading a transaction") to server 116.
- sync client 401 can then compare the received transaction ID with the transaction information in transaction database 405 to send the unprocessed transaction information (i.e., transactions having a transaction ID greater than the transaction ID received from server 116).
- the sync client may compress the unprocessed transactions to be uploaded.
- sync client 401 compresses the transaction information using any suitable compression algorithm.
- Sync client 401 may then also convert the compressed information into the format supported by the connection between handheld device 120-3 and server 116 (e.g., text for use in a HTTP connection).
- block 703 may be omitted (i.e., the information need not be compressed).
- sync client 401 then uploads the information of unprocessed transactions.
- sync client 401 sends the transaction information to server 116 in a single large block.
- sync client 401 can send the transaction information in a series of smaller blocks.:
- server 116 provides an acknowledgement after properly receiving each smaller block from handheld device 120-3.
- the sync client gets information regarding errors (if any) that occurred during block 705.
- server 116 keeps a record of all of the errors that occurred in processing the transactions. For example, an error may be that a transaction has attempted to update a field that was more recently updated by another user who synchronized before the user of handheld device 120-3. Other examples include errors that occur when the transaction violates other data validation rules that may be imposed by the server that are not imposed by the handheld application.
- FIG. 709 illustrates block 705 ( Figure 7) in more detail, according to one embodiment of the present invention.
- a sync client performs the operations of Figure 8.
- the sync client resides in handheld device 120-3 having a direct connection with server 116.
- the transaction processing operation of block 705 is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure 1).
- block 705 is performed as follows in this exemplary embodiment.
- sync client 401 determines whether the transaction ID received in block 701 ( Figure 7) is stored in transaction database 405 ( Figure 4). If the received transaction ID is in transaction database 405, then all of the transaction records in transaction database 405 created before the transaction corresponding to the received transaction ID have already been received by server 116 and thus are no longer needed. In one embodiment, sync client 401 performs a block 803 in which it deletes all of the transaction records in transaction database 405 having a transaction ID that is smaller than (i.e., created before) the received transaction ID.
- sync client 401 determines that the received transaction ID is not in transaction database 405, then none of the transaction records remaining in transaction database 405 have been properly received by server 116. In a block 805, sync client 401 determines the number of unprocessed transaction records stored in transaction database 405. In one embodiment, this number is stored in a variable (referred to herein as TXNCOUNT for convenience). Block 805 is also performed following the completion of block 803.
- sync client 401 determines whether the number of processed transaction records is less than the value of TXNCOUNT. That is, following block 805, the number of processed transaction records in the current performance of block 705 is set to zero. As each transaction record in transaction database 405 is processed (e.g., uploaded to server 116), the number of processed transaction records is incremented. When the number of processed transaction records reaches the value of TXNCOUNT, then all of the transaction records in transaction database 405 have been processed. In this case, the process proceeds to a block 809 in which all of the transaction records stored in transaction database 405 are deleted and block 705 ends.
- sync client 401 adds the transaction record to a transaction string or message that is to be uploaded to server 116.
- sync client 401 packs the transaction record in a transaction string that is to be uploaded to server 116.
- a transaction record may be stored in transaction database 405 as a series of small mini-transaction records (especially if the transaction is a complex or large transaction).
- sync client 401 would concatenate a mini- transaction record with the existing transaction string.
- sync client 401 determines if the transaction record is a mini-transaction record. For example, in one embodiment, each mini-transaction record of a transaction would have the same transaction ID. Sync client 401 can determine whether a transaction record is a mini- transaction record by comparing the transaction ID of the current transaction record with the transaction ID of the previous transaction record. If the transaction record is a mini-transaction record, then the operational flow loops back to block 811. However, if the transaction record is not a mini-transaction, then a block 817 is performed.
- the transaction string (from block 813) is URL (Uniform Resource Locator) encoded so that the string can be sent to server 116 via an HTTP connection.
- URL Uniform Resource Locator
- sync client 401 URL encodes the transaction string.
- the URL encoded transaction string is uploaded.
- sync client 401 places the encoded transaction string in the header of an HTTP request and sent to server 116. If the transaction string is too large (e.g., greater than two kilobytes), the string is uploaded using more than one HTTP request. After the transaction string is uploaded, the process returns to block 807. The process repeats until all of the transaction records in transaction database 405 have been processed.
- Figure 9 illustrates block 609 ( Figure 6) for updating metadata, according to one embodiment of the present invention.
- a sync client performs the operations of Figure 9.
- the sync client resides in handheld device 120-3 ( Figure 4) having a direct connection with server 116 ( Figure l ).
- server 116 Figure l
- the transaction processing operation of block 609 is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure l).
- block 609 is performed as follows in this exemplary embodiment.
- sync client 401 compares the locally stored repository ID (i.e., stored in datastore 409) with the repository ID from server 116 (see block 605 of Figure 6).
- the locally-stored repository ID indicates the version of the handheld application residing in handheld device 120-3, whereas the repository ID from server 116 indicates the version of the handheld application that handheld device 120-3 should have (e.g., the handheld application may have been updated since the last time handheld device 120-3 was synchronized).
- sync client 401 determines whether the repository IDs match. If they match, then handheld device 120-3 has the correct version of the handheld application and block 609 terminates. However, if they do not match, handheld device 120-3 must be updated with the correct version of the handheld application. Thus, if in block 903 the repository IDs do not match, the process proceeds to a block 905.
- sync client 401 gets the size of the metadata.
- sync client 401 gets the size of the metadata from server 116. However, this size does not represent the size the metadata will occupy in handheld device 120-3 when downloaded and stored in the datastore.
- sync client 401 applies a scaling factor to the size received in block 905 to determine a maximum expected size of the executed metadata.
- this scaling factor is determined experimentally. In other embodiments, the scaling factor may be configurable or dynamically determined. The scaling factor ensures that the actual size of the executed metadata is less than or equal to the maximum expected size.
- sync client 401 determines whether the memory available in handheld device 120-3 is sufficient to store the metadata. In one embodiment, sync client 401 compares the maximum expected size determined in block 907 with the available memory.
- sync client 401 gets the metadata from server 116 in a block 911. In one embodiment, sync client 401 pulls the metadata from server 116 in a single transfer. In another embodiment, sync client 401 pulls the metadata from server 116 in a series of smaller transfers.
- sync client 401 performs an error routine to gracefully exit block 609.
- sync client 401 can cause handheld device 120-3 to display a message to the user that there is insufficient memory available to complete the synchronize process and suggesting that the user delete unneeded files and retry the synchronization process.
- the error routine of block 913 can prompt the user to free memory space and once the user does so, return to block 909 instead of exiting.
- FIG 10 illustrates block 611 ( Figure 6) for extracting database data, according to one embodiment of the present invention.
- a sync client performs the operations of Figure 10.
- the sync client resides in handheld device 120-3 ( Figure 4) having a direct connection with server 116 ( Figure l).
- server 116 Figure l
- the transaction processing operation of block 611 is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure l).
- block 611 is performed as follows in this exemplary embodiment.
- sync client 401 gets the extraction ID from server 116. In one embodiment, sync client 401 gets this information in block 603 ( Figure 6) as part of the initialization information. This extraction ID indicates the version of the database that handheld device 120-3 should have. In addition, handheld device 120-3 also locally stores the extraction ID (e.g., in datastore 409) that indicates the version of the database currently residing in handheld device 120-3. These extraction IDs can be different if the database architecture was updated since the last time handheld device 120-3 was synchronized. For example, main database 112 ( Figure l) may have been updated to add and/or delete fields or tables.
- sync client 401 processes the filters.
- the user may have modified the filter settings on handheld device 120-3.
- the filter settings are used by the server to download only the database data desired by the user.
- One advantage of this filtering is that it reduces the amount of downloaded data to a size that can fit in the memory of handheld device 120-3.
- Sync client 401 can download the filter settings stored in server 116 and use them to update the locally updated filter settings.
- Sync client 401 can also upload the user modified filter settings to server 116. The server will ensure that the user modified filter settings are valid settings. The valid new filter settings are used by the server in downloading database data to handheld device 120-3.
- the filter settings are described below in more detail in conjunction with Figure 10A.
- sync client 401 determines whether handheld device 120-3 has sufficient memory available to store the database data to be downloaded by server 116.
- sync manager 116 gets the size of the data extract from server 116.
- server 116 accesses main database 112 ( Figure 1) to create an extract of database data that is visible to handheld device 120-3 and has been filtered according to the valid filter settings uploaded from the handheld device.
- Server 116 provides the size of the data extract (either a full extract or a delta extract) to sync client 401 , which can then determine whether there is sufficient memory available in handheld device 120-3.
- sync client 401 in a block 1007, pulls the data extract (either full or delta) from server 116.
- Sync manager 410 can pull the data extract in a single transfer or in a series of smaller transfers.
- sync client 401 stores the extract in local database 308.
- block 611 terminates.
- sync client 401 can execute an. error routine similar to block 913 ( Figure 9) to gracefully exit from block 611.
- sync client 401 gets a new extraction ID from server 116.
- Sync client 401 may omit block 1011 if the locally stored extraction ID is the same as the extraction ID received from server 116 in block 1001.
- FIG 10A illustrates the filters described in block 1003 ( Figure 10), according to one embodiment of the present invention.
- filters are associated with screens defined by the metadata (described above in conjunction with Figures 3 and 9).
- the screens are displayed by the handheld application executed in the handheld device to provide a user interface to the handheld device's local database.
- the screens can display selected groups of database data in formats/arrangements that allow users to more easily use and understand the data.
- the filters have multiple screens, indicated as SCREEN_1 to SCREEN_M.
- SCREEN_1 When the handheld application is running, the user can navigate through the various screens to cause the handheld device to display desired database data.
- Each screen has at least one business object.
- screen SCREEN_1 has several business objects indicated as BUSOBJ to BUSOBJ_N.
- the business objects are predetermined to define groups of related data to be displayed by the handheld device.
- the screens are defined to have only one business object per screen to simplify the processing in block 1003 ( Figure 10).
- FIG 11 illustrates block 1003 ( Figure 10) for processing filters, according to one embodiment of the present invention.
- a sync client performs the operations of block 1003.
- the sync client resides in handheld device 120-3 ( Figure 4) having a direct connection with server 116 ( Figure 1).
- server 116 Figure 1
- the operation of block 1003 is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure l).
- block 1003 is performed as follows in this exemplary embodiment.
- sync client 401 downloads filter information from server 116 ( Figure l).
- This filter information includes the filter settings that server 116 used in previous synchronization operation for sync client 401.
- this filter information can includes updates to the filters provided by a system administrator or by the vendor of sync client 401 or sync engine 118 ( Figure l).
- This filter information can include: (a) screen identifiers; (b) the identifiers of the business object(s) associated with each screen; and (c) each business object's associated filter(s). Because the screens each have only one associated business object, the filter information can downloaded as a file containing only the screens and their associated filters. In this embodiment, the downloaded file is temporarily stored in handheld device 120-3 ( Figure 1) for access by sync client 401.
- sync client 401 gets a file of locally stored filter settings (also referred to herein as the filter settings file).
- This filter settings file can contain filter settings revised by the user after the previous synchronization operation.
- Sync client 401 can then access the filter settings file during block 1103.
- sync client 401 updates the filter information to include information from both the filter settings file and the filter information downloaded in block 1101.
- sync client 401 can also update the filter information with a default filter setting(s) for a business object(s).
- sync client 401 includes a component (e.g., a dialog) that allows the user to select filter settings. For example, this component can display a screen along with a menu that allows the user to make filter setting selections. The next screen is then displayed so that the user can change the settings as desired. This is repeated until all of the screens have been displayed.
- the filter settings file is updated to reflect the filter setting selections.
- sync client 401 updates the filter settings file to include the updated filter information.
- This updated filter settings file is saved locally in handheld device 120-3
- sync client 401 provides the updated filter information to server 116.
- sync client 401 uploads the updated filter information to server 116 in the form of an XML string, which is then URL encoded before sync client 401 sends the filter setting information to server 116.
- the filter information is in the form of a packed string with preselected characters used to link a business object with a filter setting(s) and to indicate a next business object.
- FIG 12 illustrates in more detail blocks 1103, 1105, and 1107 (Figure 11), according to one embodiment of the present invention.
- a sync client performs the operations.
- the sync client resides in handheld device 120-3 ( Figure 4) having a direct connection with server 116 ( Figure 1).
- the operations of blocks 1103, 1105 and 1107 are described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure 1).
- blocks 1103, 1105 and 1107 are performed as follows in this exemplary embodiment.
- sync client 401 parses the downloaded filter information (see block 1101 of Figure 11).
- the downloaded filter information is in the form of an XML encoded stream.
- Sync client 401 sets up a data structure for storing filter information parsed from the downloaded information.
- the data structure is a linked list.
- the data structure can be a mark-up language file such as, for example, XML, SGML or HTML.
- sync client 401 searches for a next screen in the parsed downloaded filter information. If sync client 401 finds a screen, then, in a block 1205, sync client 401 places the screen in the data structure. For example, in the linked list embodiment, sync client 401 can create a link for the found screen. In an XML embodiment, sync client 401 can create tags or attributes for the screen.
- sync client 401 searches for a next business object associated with the screen of block 1203. If sync client 401 finds a business object, then, in a block 1209, sync client 401 places the business object in the data structure, with a mechanism to indicate the relationship between the business object and the screen. Continuing the linked list example above, sync client 401 can create a link from the screen found in block 1203 to the business object found in block 1207. In an XML embodiment, sync client 401 can create tags or attributes for the business object.
- sync client 401 searches for a next filter associated with the business object of block 1207. If sync client 401 finds a filter, then in a block 1213, sync client 401 places the filter in the data structure. Continuing the linked list example above, sync client 401 can create a link from the business object found in block 1207 to the filter found in block 1211. In an XML embodiment, sync client 401 can create tags or attributes for the filter. As previously described in conjunction with Figure 10A, a business object may have more than one filter. However, in this embodiment, only one filter can be active at a time.
- sync client 401 determines whether the active filter for the business object found in block 1207 has been selected.
- the data structure includes a separate "active filter" pointer to point at the active filter corresponding to the business object found in block 1207.
- Sync client 401 can check whether this pointer is filled (i.e., points to an address). If the pointer is empty, the active filter for the business object has not been selected.
- sync client 401 determines whether the filter found in block 1207 is a default filter. If so, then in a block 1219, sync client 401 sets the filter as the default filter. For example, sync client 401 loads the "active filter" pointer with the address of the default filter and the operational flow returns to block 1211. If in block 1217 the filter is not a default filter, the operational flow returns to block 1211 to find the next filter.
- sync client 401 determines whether an active filter has been selected for current business object. If sync client 401 determines that an active filter has been selected (e.g., when all of the filters for the current business object have been found and one is a default filter), the operational flow returns to block 1203 to find a next screen. However, if sync client 401 determines that no active filter has been selected (e.g., when no filter has been found for the current business object, or none of the found filters is a default filter), the operational flow proceeds to a block 1223.
- sync client 401 searches the found filter(s) for the current business object (i.e., through one or more iterations of blocks 1211-1219) for a filter that is not a "No Filter” filter. More particularly, as previously described, a business object need not have an active filter. For this case, this embodiment uses a "No Filter” filter to indicate that the business object does not have an active filter. If in block 1223 sync client 401 finds a filter in the found filter(s) that is not a "No Filter” filter, then in a block 1225 sync client 401 selects this filter as the active filter. However, if in block 1223 no such filter is found, the operational flow proceeds to a block 1227.
- sync client 401 searches the found filter(s) for a "No Filter” filter. If sync client 401 finds a "No filter” filter, then in a block 1229, sync client 401 selects this filter as the active filter. However, if in block 1227 sync client 401 does not find a "No Filter” filter, then no active filter is selected as indicated by a block 1231. Following either of blocks 1229 and 1231 , the operational flow returns to block 1 03 to find a next screen.
- sync client 401 gets the filter settings file (see block 1103 described above).
- the filter settings file can contain filter settings revised by the user after the previous synchronization operation.
- the filter settings include each business object and its associated activated filter (i.e., a business object/filter pair).
- sync client 401 parses out the next business object/filter pair from the filter settings file. Sync client 401 loops back to block 1242 (as described below) until all of the business object/filter pairs have been parsed out of the filter settings file.
- sync client 401 determines whether the business object/filter pair is empty (i.e., no active filter was selected in the previous synchronization operation). If the business object/filter pair is empty, the operation flow returns to block 1242 to parse out the next business object/filter pair.
- sync client 401 determines that the business object/filter pair is not empty, the operational flow proceeds to a block 1246.
- sync client 401 searches the data structure (see blocks 1205-1213) for the business object indicated by the business object/filter pair. Block 1246 is useful because the business object may no longer exist, for example, in an update of the handheld application. If in block 1246 sync client 401 does not find the business object in the data structure, the operational flow returns to block 1242 to parse out the next business object/filter pair.
- sync client 401 if sync client 401 does find the business object in block 1246, the operational flow proceeds to a block 1248.
- sync client 401 searches the aforementioned data structure for the filter. As described above for the business object, the filter may no longer exist due to an update in the handheld application. If in block 1248 sync client 401 does not find the filter in the data structure, the operational flow returns to block 1242 to parse out the next business object/filter pair. However, if sync client 401 does find the filter in data structure, sync client 401 then sets this found filter as the active filter in a block 1250. The operational flow then returns to block 1242 to parse out the next business object/filter pair.
- the operational flow of the embodiment of Figure 12 in effect, retrieves the latest filter settings stored in the server for the sync client and then resets the filter settings to the default active filters. Then the locally stored user settings from the previous synchronization operation are used to update the default active filters for those business object and filters.
- This embodiment helps ensure that filter settings are correct when the handheld application is updated.
- FIG 13 illustrates block 1007 (Figure 10) for extracting data, according to one embodiment of the present invention.
- a sync client performs the operations of block 1007.
- the operation of block 1007 is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure 1).
- Figures 4 and 13 block 1007 is performed as follows in this exemplary embodiment.
- sync client 401 gets the locally stored extraction ID with the extraction ID downloaded from server 116 for comparison.
- the extraction ID identifies the version of the database extract. For example, if the database structure on server 116 has changed, the extraction IDs will be different.
- sync client 401 determines whether the locally stored and downloaded extraction IDs match. If the extraction IDs match, the operational flow proceeds to a block 1305. In block 1305, sync client 401 requests a delta extract from server 116.
- a delta extract includes only the database data that has changed since the previous synchronization operation.
- the sync engine e.g., sync engine 118 or 128 in Figure 1
- the sync engine retrieves a full extract for the sync client from main database 112 ( Figure 1 ).
- sync client 401 would compare the stored extract with the full extract retrieved from main database 112 and transmit only the changed database data to the sync engine (118 or 128). This delta extract is then received by sync client 401.
- sync client 401 determines in block 1303 that extraction IDs do not match, the operation flow proceeds to a block 1307.
- sync client 401 requests a full extract from server 116.
- Server 116 then provides the full extract, which is then received by sync client 401.
- FIG 14 illustrates a compression operation, according to one embodiment of the present invention.
- This compression operation can be performed by a sync client (e.g., sync client 401 of Figure 4) or a server (e.g., server 114 or 116 of Figure 1).
- this compression operation can be performed by server 116 before sending database data (e.g., a delta extract) to sync client 401.
- This compression algorithm can also be used by sync client 401 to send information back to server 116.
- this compression operation can be used to implement block 703 ( Figure 7). This compression operation advantageously reduces the time needed to transfer information between a server and a sync client.
- information to be transmitted is compressed.
- the information is binary data such as database data, transaction data or metadata. Any suitable compression algorithm can be used.
- the binary information is compressed using the Zip 2.3 compression utility available from www.info-zip.org. In other embodiments, other compression algorithms can be used.
- the compressed binary data is converted to text.
- the compressed binary data is converted to text using standard Base-64 encoding.
- the conversion to text helps reduce corruption of the. data during the transmission process.
- the text data can include mark-up using a mark-up language such as XML (extensible markup language) or HTML (hypertext mark-up language).
- the text data generated in block 1403 is encoded using a protocol for the connection between the server and sync client.
- a protocol for the connection between the server and sync client In one embodiment, standard hypertext transfer protocol (HTTP) is used to encode the text data for transmission over the Internet. In other embodiments, different protocols can be used, depending on the nature of the connection between the server and the sync client.
- the text data may be file transfer protocol (FTP) encoded. This compressed and encoded information can then be sent to the intended recipient.
- block 1403 can be omitted with block 1405 encoding the compressed binar data from block 1401 instead of text.
- the information to be sent can be broken into smaller units that are then separately compressed and encoded according to blocks 1401 , 1403, and 1405. These smaller units are sent separately to the recipient so that, before receiving the next unit of information, the recipient can: (a) store the compressed unit of information; (b) decompress the stored compressed unit of information; (c) store the decompressed unit of information; and (d) delete the compressed unit of information.
- This refinement reduces the amount of available memory needed by the recipient to properly receive and decompress the transmitted information.
- FIG 15 illustrates a synchronization process of a server, according to one embodiment of the present invention.
- the server is connected to a sync client.
- the sync client can reside in a handheld device that has a direct connection to the server.
- the handheld device and server can be handheld device 120-3 ( Figure 4) and server 116 ( Figure l).
- the sync client can be implemented by the combination of a companion device and handheld device (e.g., companion device 124 and handheld device 120-2 as in Figure 5).
- the operation of the server is described in conjunction with server 116 ( Figure l) and handheld device 120-3 ( Figure 4).
- server 116 Figure l
- handheld device 120-3 Figure 4
- a server operates in conjunction with a sync client as follows.
- the server connects with the sync client.
- the sync client may reside in a companion device in some embodiments.
- server 116 connects to sync client 401 in response to the user logging in.
- server 116 executes an interface or driver that operates a modem to directly access sync client 401.
- this connection may be an Internet connection.
- the connection can be a wireless connection using RF or optical technology to implement a direct, web- based or other type of communication link.
- the server downloads initialization data to the sync client.
- server 116 downloads initialization data to sync client 401 via connection 132.
- this initialization data can include information related to the latest version of the main database 112 (e.g., the extraction ID), the identifier for latest transaction uploaded to server 116 by sync client 401 , and the latest version of the handheld application (e.g., the repository ID).
- the server can receive transaction information from the sync client.
- server 116 receives the transaction information from sync client 401 and can store this transaction information in a memory (not shown) of computer system 110 ( Figure l).
- server 116 may receive the transaction information for all of the recorded transactions from sync client 401 in one relatively large block of data.
- server 116 may receive the transaction information in several smaller blocks from sync client 401.
- server 116 would provide an acknowledgement to sync client 401 after receiving each smaller block, which then signals sync client 401 to send the next smaller block.
- the server can send metadata from the sync client.
- server 116 sends the metadata to sync client 401.
- this metadata includes application definitions for the handheld application.
- server 116 performs block 1507 in response to a request from sync client 401.
- sync client 401 can request the metadata if the application stored in server 116 (from the most recent synchronization operation) does not match the locally stored application definition version. This situation may occur when the application definitions have been updated after the previous synchronization operation.
- sync client 401 is configured to always request the metadata during a synchronization operation without comparing versions.
- server 116 would determine whether the application definitions have been updated since the last synchronization operation and if so, send the metadata to sync client 401. In a further refinement of this alternative embodiment, server 116 can automatically perform these operations without waiting for a request from sync client 401 , pushing the metadata to sync client 401 if the applications definitions have been updated.
- the server updates the sync client's local database.
- server 116 receives a request from sync client 401 to initiate a data extraction operation.
- server 116 may receive updated filter settings (see the descriptions of Figures 11 and 12 above) before performing the data extraction operation.
- server 116 will avoid downloading data undesired database data, which helps conserve battery power and reduce the time needed to complete the synchronization process.
- server 116 downloads the entire data extract (i.e., the data visible to the sync client and after filtering) in a single large block.
- server 116 may download a relatively small block of the data extract in response to a request by sync client 401.
- sync client 401 can send a request for the next relatively small block, on so on until sync client 401 receives the entire data extract from server 116.
- This data extract can be a full or delta extract (described in more detail below in conjunction with Figure 16).
- server 116 disconnects from sync client 401 in response to a log out process initiated by the user (or performed automatically by sync client 401 upon completion of the synchronization operation). In an alternative embodiment, server 116 can automatically disconnect from sync client 401 after performing the operations of block 1509.
- Figure 16 illustrates block 1509 (Figure 15), according to one embodiment of the present invention.
- a server performs the operations of block 1509.
- the operation of block 1509 is described in conjunction with handheld device 120-3 ( Figure 4) and server 116 ( Figure 1).
- Figures 4 and 16 block 1509 is performed as follows in this exemplary embodiment.
- server 116 extracts data from main database 112 that is visible to sync client 401.
- server 116 may filter this data according to the filter settings provided to server 116 by sync client 401 (described in conjunction with Figures 11 and 12).
- server 116 then saves in memory (not shown) a file of the extracted data for later use in a subsequent synchronization operation.
- server 116 compares this extract with a file containing extracted data from the previous synchronization operation. Where the data from corresponding database records differ, in a block 1607, server 116 saves the data from newer extract (i.e., the "delta") in another file referred to herein as the delta extract file.
- server 116 stores each delta as a record/data pair that sync client 401 can parse from the delta extract when received by sync client 401.
- a reserved delimiter separates fields within each record and a different reserved delimiter separates records.
- an escape mechanism can be used to allow these reserved delimiters to appear with a record field value.
- the delta extract file may include an indicator for each record/data pair to indicate whether the record was deleted, new, or changed.
- the delta extract is performed on the field level rather than the record level (which may contain several fields) to further reduce the size the delta extract file.
- server 116 determines whether to download a full or delta extract to sync client 401.
- server 116 would receive a request from sync client 401 for either a full extract or delta extract.
- sync client 401 bases this request on whether an extraction ID downloaded from server 116 matches an extraction ID locally stored by sync client 401.
- the extraction IDs would be different and sync client would request a full extract.
- server 116 sends either a full extract or delta extract to sync client 401 in a block 1611 or a block 1613, respectively.
- server 116 can receive the locally stored extraction ID from sync client 401 and compare this received extraction ID with the most recent extraction ID stored in server 116. For example, server 116 can request this data from sync client 401 , or this may be part of the data extraction process (e.g., similar to block 1101 of Figure 10 except that instead of getting the extraction ID, the sync client provides its local extraction ID). Server 116 can then determine whether to download the delta or full extract, as appropriate. For example, server 116 can perform blocks 1301 and 1303 ( Figure 13) instead of sync client 401.
- server 116 can receive the repository ID in determining whether to provide metadata to sync client 401 (e.g. see block 609 of Figure 6). For example, server 116 can request this data from sync client 401 , or this may be part of the data extraction process (e.g., similar to block 605 of Figure 6 except that instead of getting the repository ID, the sync client provides its locally stored repository ID). Server 116 can then determine whether to download the metadata. For example, server 116 be configured to perform blocks 901 and 903 ( Figure 9) instead of sync client 401.
Abstract
Description
Claims
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US8462802A | 2002-02-25 | 2002-02-25 | |
US84628 | 2002-02-25 | ||
PCT/US2003/005773 WO2003073292A1 (en) | 2002-02-25 | 2003-02-25 | Method and system for server-based operations in server synchronization with a computing device |
Publications (2)
Publication Number | Publication Date |
---|---|
EP1490770A1 true EP1490770A1 (en) | 2004-12-29 |
EP1490770A4 EP1490770A4 (en) | 2007-02-28 |
Family
ID=27765324
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP03716180A Ceased EP1490770A4 (en) | 2002-02-25 | 2003-02-25 | Method and system for server-based operations in server synchronization with a computing device |
Country Status (4)
Country | Link |
---|---|
EP (1) | EP1490770A4 (en) |
JP (1) | JP4343704B2 (en) |
AU (1) | AU2003219896A1 (en) |
WO (1) | WO2003073292A1 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107066594A (en) * | 2017-04-19 | 2017-08-18 | 济南浪潮高新科技投资发展有限公司 | A kind of synchronous method of metadata |
Families Citing this family (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7395446B2 (en) * | 2004-05-03 | 2008-07-01 | Microsoft Corporation | Systems and methods for the implementation of a peer-to-peer rule-based pull autonomous synchronization system |
US20050262166A1 (en) * | 2004-05-05 | 2005-11-24 | Microsoft Corporation | Method and system for synchronizing data between electronic devices |
CA2622404A1 (en) * | 2004-09-15 | 2006-03-23 | Adesso Systems, Inc. | System and method for managing data in a distributed computer system |
US20100325153A1 (en) * | 2009-06-17 | 2010-12-23 | Microsoft Corporation | Synchronized distributed media assets |
US7953696B2 (en) * | 2005-09-09 | 2011-05-31 | Microsoft Corporation | Real-time synchronization of XML data between applications |
US9514163B2 (en) * | 2005-11-17 | 2016-12-06 | International Business Machines Corporation | Database consolidation tool |
US8239504B2 (en) | 2007-01-07 | 2012-08-07 | Apple Inc. | Synchronization methods and systems |
US7778971B2 (en) | 2007-01-07 | 2010-08-17 | Apple Inc. | Synchronization methods and systems |
US7805403B2 (en) | 2007-01-07 | 2010-09-28 | Apple Inc. | Synchronization methods and systems |
US7660831B2 (en) | 2007-01-07 | 2010-02-09 | Apple Inc. | Synchronization methods and systems |
US7739410B2 (en) | 2007-01-07 | 2010-06-15 | Apple Inc. | Synchronization methods and systems |
US7761414B2 (en) | 2007-01-07 | 2010-07-20 | Apple Inc. | Asynchronous data synchronization amongst devices |
US9240015B2 (en) | 2009-05-08 | 2016-01-19 | A2Zlogix, Inc. | Method and system for synchronizing delivery of promotional material to computing devices |
US9836770B2 (en) | 2012-02-24 | 2017-12-05 | Ad Persistence, Llc | Data capture for user interaction with promotional materials |
US9973891B2 (en) | 2015-10-23 | 2018-05-15 | Kodiak Networks Inc. | System and method for geofencing |
WO2017070551A1 (en) * | 2015-10-23 | 2017-04-27 | Kodiak Networks Inc. | System and method for content messaging |
JP6720792B2 (en) * | 2016-09-15 | 2020-07-08 | セイコーエプソン株式会社 | Device management device and device management program |
CN108076081B (en) * | 2016-11-09 | 2021-02-26 | 菜鸟智能物流控股有限公司 | Method, device and system for synchronizing service data |
CN110442588A (en) * | 2019-07-05 | 2019-11-12 | 深圳壹账通智能科技有限公司 | Information synchronous updating method, device, computer equipment and storage medium |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5857201A (en) * | 1996-06-18 | 1999-01-05 | Wright Strategies, Inc. | Enterprise connectivity to handheld devices |
US6304882B1 (en) * | 1998-05-05 | 2001-10-16 | Informix Software, Inc. | Data replication system and method |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5884323A (en) * | 1995-10-13 | 1999-03-16 | 3Com Corporation | Extendible method and apparatus for synchronizing files on two different computer systems |
AU6336798A (en) * | 1997-02-27 | 1998-09-29 | Siebel Systems, Inc. | Method of synchronizing independently distributed software and database schema |
US6295541B1 (en) * | 1997-12-16 | 2001-09-25 | Starfish Software, Inc. | System and methods for synchronizing two or more datasets |
US6205448B1 (en) * | 1998-01-30 | 2001-03-20 | 3Com Corporation | Method and apparatus of synchronizing two computer systems supporting multiple synchronization techniques |
AU1838200A (en) * | 1998-11-30 | 2000-06-19 | Siebel Systems, Inc. | Client server system with thin client architecture |
-
2003
- 2003-02-25 EP EP03716180A patent/EP1490770A4/en not_active Ceased
- 2003-02-25 WO PCT/US2003/005773 patent/WO2003073292A1/en active Application Filing
- 2003-02-25 JP JP2003571918A patent/JP4343704B2/en not_active Expired - Lifetime
- 2003-02-25 AU AU2003219896A patent/AU2003219896A1/en not_active Abandoned
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5857201A (en) * | 1996-06-18 | 1999-01-05 | Wright Strategies, Inc. | Enterprise connectivity to handheld devices |
US6304882B1 (en) * | 1998-05-05 | 2001-10-16 | Informix Software, Inc. | Data replication system and method |
Non-Patent Citations (2)
Title |
---|
See also references of WO03073292A1 * |
SESHADRI P ET AL: "SQLServer for Windows CE-a database engine for mobile and embedded platforms" DATA ENGINEERING, 2000. PROCEEDINGS. 16TH INTERNATIONAL CONFERENCE ON SAN DIEGO, CA, USA 29 FEB.-3 MARCH 2000, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 29 February 2000 (2000-02-29), pages 642-644, XP010378761 ISBN: 0-7695-0506-6 * |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107066594A (en) * | 2017-04-19 | 2017-08-18 | 济南浪潮高新科技投资发展有限公司 | A kind of synchronous method of metadata |
CN107066594B (en) * | 2017-04-19 | 2021-02-26 | 浪潮集团有限公司 | Metadata synchronization method |
Also Published As
Publication number | Publication date |
---|---|
JP4343704B2 (en) | 2009-10-14 |
EP1490770A4 (en) | 2007-02-28 |
AU2003219896A1 (en) | 2003-09-09 |
JP2005518605A (en) | 2005-06-23 |
WO2003073292A1 (en) | 2003-09-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7761535B2 (en) | Method and system for server synchronization with a computing device | |
US7526575B2 (en) | Method and system for client-based operations in server synchronization with a computing device | |
US7415539B2 (en) | Method and apparatus for detecting insufficient memory for data extraction processes | |
US7257649B2 (en) | Method and system for transferring information during server synchronization with a computing device | |
WO2003073292A1 (en) | Method and system for server-based operations in server synchronization with a computing device | |
US8463944B2 (en) | Optimal compression process selection methods | |
US10552382B2 (en) | System and method for the synchronization of a file in a cache | |
US20020073076A1 (en) | System and method for enabling off-line database functionality | |
US9298747B2 (en) | Deployable, consistent, and extensible computing environment platform | |
CN100371929C (en) | Synchronization of database data | |
KR100999267B1 (en) | On-device application catalog updated by management servers | |
RU2453911C2 (en) | Offline execution of web based applications | |
EP2047382B1 (en) | Two-way and multi-master synchronization over web syndications | |
KR101384387B1 (en) | System and method for provisioning a user device | |
CN101719073B (en) | Intelligent client-based on-demand downloading realization method | |
US20050278392A1 (en) | System and method for synchronizing multiple database files | |
Peek et al. | EnsemBlue: Integrating distributed storage and consumer electronics | |
US20090144258A1 (en) | Systems and methods for query processing | |
US11900083B2 (en) | Systems and methods for indexing source code in a search engine | |
WO2014089230A2 (en) | Method and system of storing data files and retrieving data in a data file and requesting information from a computer | |
JP2007080167A (en) | Software resource distribution system and method, and program | |
EP2615563A1 (en) | Device for synchronously sharing files and method for synchronously sharing files | |
US7987420B1 (en) | System, method, and computer program product for a scalable, configurable, client/server, cross-platform browser for mobile devices | |
WO2003062998A1 (en) | System and method for url response caching and filtering in servlets and application servers | |
JP2000200233A (en) | Device and method for data acquisition notification and recording medium |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
17P | Request for examination filed |
Effective date: 20040924 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LI LU MC NL PT SE SI SK TR |
|
AX | Request for extension of the european patent |
Extension state: AL LT LV MK RO |
|
RIN1 | Information on inventor provided before grant (corrected) |
Inventor name: SCOTT, BRIAN Inventor name: GEORGE, DAVID Inventor name: CHUNG, PI-YU Inventor name: RABBERS, DAVID, L. Inventor name: VEJLSTRUP, MAGNUS Inventor name: HUANG, XIAO, FREI |
|
REG | Reference to a national code |
Ref country code: HK Ref legal event code: DE Ref document number: 1072491 Country of ref document: HK |
|
A4 | Supplementary search report drawn up and despatched |
Effective date: 20070125 |
|
RIC1 | Information provided on ipc code assigned before grant |
Ipc: G06F 17/30 20060101ALI20070119BHEP Ipc: G06F 12/00 20060101AFI20030910BHEP |
|
17Q | First examination report despatched |
Effective date: 20070921 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R003 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE APPLICATION HAS BEEN REFUSED |
|
18R | Application refused |
Effective date: 20170531 |
|
REG | Reference to a national code |
Ref country code: HK Ref legal event code: WD Ref document number: 1072491 Country of ref document: HK |