I have a few questions about data synchronization. The architecture does not seem to be clear about this:
Does Google Gears provide from automatic synchronization of data (from client to server and server to client)?
If it does provide for automatic data synchronization, then can i write functions to hook into the sync mechanism (on the server and on the client) to control what data is synced?
Is there anyway to partition the data on the server? for example a client should be able to download only those rows in a table which are related to it (for example there is 'hostname' column in the table, and only those rows which contain the hostname of the client trying to download the data should be downloaded to it)
Basically what I am looking for is: does Google Gears Synchronization support the data synchronization features like SQL Server Merge replication? [ http://technet.microsoft.com/en-us/library/ms152746.aspx ]
Gears does not provide any synchronization capabilities. I think I remember listening to a podcast interview with one of the gears developers when it first came out, and he said that they wanted to provide a framework to help with synchronization, but realized that everyone's synchronization needs were sufficiently different that it would be too difficult to find a one-size-fits-all solution.
In addition, it's important to note that because the database portion of Gears is really just a client-side database accessible from javascript, there's nothing in Gears that specifies a specific server-side implementation, or even a specific server api. Thus, doing things like the data partitioning you describe are up to the developer, as is interfacing with the server in general.