Share via


Step by Step: Developing a SQL Mobile Application with Visual Studio 2005 and SQL Server 2005

4/7/2010

Microsoft Corporation

February 2007

Summary

Learn how to use Microsoft® SQL Server™ 2005 Mobile Edition (SQL Mobile) to synchronize data between a Microsoft Windows Mobile®–based device and a SQL Server 2005 back-end database. This HOL will take 1 hour and 30 minutes to complete. (80 printed pages)

Download code sample from the Microsoft Download Center.

Applies To

Microsoft Visual Studio® 2005Microsoft SQL Server 2005Microsoft SQL Server 2005 Mobile EditionMicrosoft .NET Compact Framework version 2.0Windows Mobile version 5.0 software for Pocket PCsWindows Mobile version 5.0 software for Smartphones

The following applications are required to run this HOL:

Credentials Used

In this HOL, you will need the following information:

  • Computer's name

Introduction

Lab 1: Developing a SQL Mobile Application with Visual Studio 2005 and SQL Server 2005

Conclusion

Additional Information

Introduction

You will use SQL Server Management Studio to create a SQL Mobile database, set up, and configure SQL Server 2005 and Internet Information Services (IIS) for merge replication. You will use Visual Studio 2005 to create a Microsoft .NET Compact Framework application to maintain SQL Mobile data and synchronize it with SQL Server data. You will also learn how to synchronize SQL Mobile data with any back-end data store using a Web service. When you have completed this hands-on lab (HOL), you will know how to easily build a mobile application that must keep mission-critical data in synchronization with a back-end database.

Lab 1: Developing a SQL Mobile Application with Visual Studio 2005 and SQL Server 2005

Learn how to use SQL Server 2005 Mobile Edition (SQL Mobile) to synchronize data between a Windows Mobile–based device and a SQL Server 2005 back-end database. You will use SQL Server Management Studio to create a SQL Mobile database and to set up and configure SQL Server 2005 and IIS for merge replication. You will use Visual Studio 2005 to create a .NET Compact Framework application to maintain the SQL Mobile data and synchronize it with SQL Server data. You will also learn how to synchronize SQL Mobile data with any back-end data store using a Web service. When you have completed this lab, you will know how to easily build a mobile application that keeps mission-critical data in synchronization with a back-end database.

Because completing all exercises in the lab may take more time than you have available, you may select only those exercises that are most useful for you. Each exercise provides you with files that offer a starting point as if you had completed the previous exercise. While there is no explicit order in which you have to perform the exercises, each exercise builds on the activities performed in the previous one.

In this lab, you will perform the following exercises:

  • Creating and using a SQL Mobile database in a Windows Mobile 5.0 application
  • Synchronizing data between a SQL Server 2005 and SQL Mobile database
  • Synchronizing data between any back-end database and SQL Mobile database using a Web service

Exercise 1: Creating and Using a SQL Mobile Database in a Windows Mobile 5.0 Application

In this exercise, you will use SQL Server Management Studio to create a stand-alone SQL Mobile vendor database. You will then create a Windows Mobile 5.0 application to view and maintain the vendor data within the SQL Mobile database. The vendor database will be based on the AdventureWorks sample database that ships with SQL Server 2005.

To create a SQL Mobile database

  1. Start SQL Server Management Studio by clicking Start | All Programs | Microsoft SQL Server 2005 | SQL Server Management Studio.

  2. In the Connect to Server dialog box, select SQL Server Mobile in the Server type box, as shown in Figure 1.

    Ff621674.2b0dfecc-fead-4996-b83f-fd51849bb197(en-us,MSDN.10).gif

    Figure 1. Selecting SQL Server Mobile as the server type

  3. In the Database file box, select <New Database…>.

    The Create New SQL Server 2005 Mobile Edition Database dialog box appears, as shown in Figure 2.

    Ff621674.b10d662a-caf3-4448-a282-7e8efda88c8b(en-us,MSDN.10).gif

    Figure 2. Creating a new SQL Server 2005 Mobile Edition database

  4. Under Enter the new SQL Server 2005 Mobile Edition database filename, type C:\Program Files\Windows Mobile Developer Samples\HOLs\HOL302_SQL_Mobile\Exercises\Exercise1\Vendors.sdf.

  5. Leave the other values as their defaults, and then click OK.

  6. If you are prompted with a message that says, Password is either not provided or blank, click Yes to continue with the blank password.

    Note

    Step 6 is not a recommended security practice, but for the purpose of simplicity in this lab, you will use this setting.

  7. Click Connect to connect to the new SQL Mobile database, as shown in Figure 3.

    Ff621674.c3e497a0-e550-4229-a5df-30efd3df6f25(en-us,MSDN.10).gif

    Figure 3. Connecting to the new SQL Server 2005 Mobile Edition database

Conclusion

Although you can create tables and other database objects interactively, just as you can when connected to a SQL Server 2005 database, a script is provided for convenience to create the Vendor table in your new SQL Mobile database in the next procedure.

To create a table for the new SQL Mobile database

  1. In SQL Server Management Studio, click File | Open | File.

  2. Browse to C:\Program Files\Windows Mobile Developer Samples\HOLs\HOL302_SQL_Mobile\Setup, and then select CreateVendor.sqlce. Click Open.

  3. Verify that the full path of your new Vendors.sdf database file is selected in the Database file box, and then click Connect.

  4. Click Query | Execute to create the Vendor table. The Message pane appears with the message (1 row(s) affected) repeated four times.

  5. In the Object Explorer pane, right-click the Tables folder, and then click Refresh.

  6. Expand the Tables folder, and then verify that there is now a Vendor table.

  7. Expand the Vendor table and its Columns folder to familiarize yourself with the table’s structure, which happens to conform to the schema of the Vendors table in the AdventureWorks sample database.

    In the next exercise, you will see why having the table's structure conform to the schema is desirable. The table contains four records that you can browse by right-clicking the SQL Server Mobile database node, and then by clicking New Query. In the query editor, type SELECT * FROM Vendor, and then click Query | Execute. When you are finished browsing, close the Query Editor window. There is no need to save your changes when prompted.

  8. Close SQL Server Management Studio.

Conclusion

To create a new Windows Mobile 5.0 application for Pocket PC

  1. Start Visual Studio 2005 by clicking Start | All Programs | Microsoft Visual Studio 2005 | Microsoft Visual Studio 2005.

  2. Click File | New | Project to create a new Windows Mobile application.

  3. In the New Project dialog box under Project types, browse to Visual C# | Smart Device | Windows Mobile 5.0 Pocket PC.

    Note

    Depending on your Visual Studio configuration, Visual C# may appear under Other Languages.

  4. In the Templates box, select Device Application.

  5. Change the Name to AdvWorksMobile.

  6. Change the Location to C:\Program Files\Windows Mobile Developer Samples\HOLs\HOL302_SQL_Mobile\Exercises\Exercise1.

  7. Be sure Create directory for solution is selected, and then click OK, as shown in Figure 4.

    Ff621674.fde0536e-97c7-42d7-97cd-a1d36f207d3b(en-us,MSDN.10).gif

    Figure 4. The New Project dialog box

    Visual Studio creates a new project and opens Form1 in the form designer.

To create the Vendor List form

  1. In Solution Explorer in Visual Studio, right-click Form1.cs, and then click Rename.

  2. Type VendorList.cs as the new file name, and then press ENTER.

  3. Click Yes in response to the prompt to rename all references of the Form1 code element in the project.

  4. If the VendorList form is not already open in the form designer, double-click VendorList.cs in the Solution Explorer pane to open it in the form designer.

  5. In the form designer, right-click the blank area of the form, and then click Properties.

  6. In the Properties pane, change the Text property value to Vendor List.

  7. Change the MinimizeBox property value to False.

    This step causes an OK button to appear at the top right corner of the form when it is displayed on the device instead of the default smart minimize button (which looks like an x). Normally, when the x is clicked, Windows Mobile applications are minimized to the background where they are still running. Changing this property value to False causes the form to actually be closed when clicking OK, making debugging easier because the application needs to be deployed multiple times, which would not be possible if the application were still running in the background.

To add the SQL Mobile Vendors database as a project data source

  1. In Visual Studio, click Data | Add New Data Source.

    The Data Source Configuration Wizard appears.

  2. Select Database as the data source type, and then click Next, as shown in Figure 5.

    Ff621674.13f2afc2-a560-426d-9130-9416bbc65cae(en-us,MSDN.10).gif

    Figure 5. Choosing a data source type in the Data Source Configuration Wizard

  3. On the Choose Your Data Connection page, click New Connection.

  4. In the Add Connection dialog box, click Change.

  5. Select Microsoft SQL Server Mobile Edition, and then click OK, as shown in Figure 6.

    Ff621674.3a6fe696-fbac-4266-ae84-da052e765556(en-us,MSDN.10).gif

    Figure 6. Changing the data source

  6. In the Add Connection dialog box, be sure the My Computer option is selected as the Data Source.

  7. Under Connection Properties, click Browse to select the database.

  8. Browse to C:\Program Files\Windows Mobile Developer Samples\HOLs\HOL302_SQL_Mobile\Exercises\Exercise1, click Vendors.sdf, and then click Open.

  9. Click OK to add the connection, as shown in Figure 7.

    Ff621674.1783d84f-3577-4d40-aacb-021bc080ad44(en-us,MSDN.10).gif

    Figure 7. The Add Connection dialog box

  10. On the Choose Your Data Connection page, after the new connection appears in the Which data connection should your application use to connect to the database box, click Next, as shown in Figure 8.

    Ff621674.a6bad1a4-4bd3-45e5-8632-4724612c428a(en-us,MSDN.10).gif

    Figure 8. Choosing Your Data Connection page with the new connection selected

  11. When Visual Studio prompts you to copy the local data file to your current project and modify the connection, click Yes, as shown in Figure 9.

    Ff621674.fe0efcf8-d0ef-43be-b2b8-01a69e75ac2c(en-us,MSDN.10).gif

    Figure 9. Message to copy the local data file to your current project

    Visual Studio copies the Vendors.sdf file into your project folder and sets its properties such that the file will also be copied to your device when the application is deployed.

  12. On the Choose Your Database Objects page, expand Tables, and then select Vendor.

  13. Change the DataSet name to AdvWorksDataSet, and then click Finish, as shown in Figure 10.

    Ff621674.935e86b7-cb68-4f2b-a14f-cafccfc09c02(en-us,MSDN.10).gif

    Figure 10. Choose Your Database Objects page

    Visual Studio adds the AdvWorksDataSet.xsd schema and other related files to your project.

To add content to the Vendor List screen

  1. The VendorList.cs Form Designer should still be visible in Visual Studio, but if it is not, double-click VendorList.cs in Solution Explorer to open it in the form designer.

  2. Click Data | Show Data Sources to show the Data Sources pane if it is not already visible, as shown in Figure 11.

    Ff621674.bf97830b-d136-4a1f-8bd9-ed49dfce8205(en-us,MSDN.10).gif

    Figure 11. The Data Sources pane

    You can drag and drop tables and individual columns to the form designer to create controls that are bound to the data source. By default, a DataGrid control is created when dragging an entire table to a form designer.

  3. In the Data Sources pane, expand AdvWorksDataSet.

  4. Click and drag the Vendor table, and then drop it anywhere in the blank area on the VendorList.cs form designer.

    Visual Studio creates a DataGrid control for the Vendor table, as shown in Figure 12.

    Ff621674.29f79834-491a-4599-9170-73e13b0799df(en-us,MSDN.10).gif

    Figure 12. The DataGrid control for the Vendor table in the form designer

    Notice that in the component tray (located at the bottom of the form designer) Visual Studio has also created the advWorksDataSet DataSet, the vendorBindingSource BindingSource, and the vendorTableAdapter TableAdapter, as shown in Figure 13. Visual Studio uses these controls that are invisible at run time to bind the vendor data to the DataGrid.

    Ff621674.524fa149-af28-406e-b13c-14bc6b7645b4(en-us,MSDN.10).gif

    Figure13. The component tray in Visual Studio

  5. Right-click the DataGrid control, and then click Properties.

  6. In the Properties pane, set the Location property to 0, 0, and then set the Size property to 240, 268, effectively filling the whole screen.

You are now ready to test the application’s functionality.

To test the application

  1. In Visual Studio, click Debug | Start Debugging.

  2. In the Deploy AdvWorksMobile dialog box that appears, be sure Windows Mobile 5.0 Pocket PC Emulator is selected, and then click Deploy, as shown in Figure 14.

    Ff621674.5ef72563-805a-4c4f-9d3f-82911cf2570b(en-us,MSDN.10).gif

    Figure 14. The Deploy AdvWorksMobile dialog box

    Note

    If you receive an error message that there was an error deploying the application any time that you deploy the application during this lab, be sure the application is not already running by following the steps in Appendix A at the end of this HOL.

    Visual Studio launches the Pocket PC - Windows Mobile 5.0 device emulator and begins to deploy the application to the device. Deploying the first Windows Mobile 5.0 application may take some time because the .NET Compact Framework version 2.0 and your application’s files—including the SQL Mobile database in this case—need to be copied to the device.

    When the application appears in the device emulator, as shown in Figure 15, you should see the list of four vendors that were inserted into the table when you created the database. You can scroll right and left and resize the columns with the column dividers on the header row to see all of the fields in the table.

    Ff621674.17dbe66a-68e6-4e38-8c6f-50288ca2ed05(en-us,MSDN.10).gif

    Figure 15. The emulator running the application with the Vendor table

  3. Click OK to dismiss the form, and then close the application.

Besides simply viewing a list of vendors, your application needs to allow the user to edit the vendor data. You will use the DataGrid’s smart tag tasks to generate additional data forms, but before you do that, you need to set the default values for some data columns that do not allow null values.

To generate add and edit functionality

  1. In Visual Studio, open the VendorList.cs form in the form designer if it is not open already.

  2. In the component tray, click the advWorksDataSet component, and then click the smart tags button at the top-right corner of the control. The smart tag menu appears, as shown in Figure 16.

    Ff621674.2064b9cd-009c-45b3-afd2-c3b484e02691(en-us,MSDN.10).gif

    Figure 16. The smart tag menu for the advWorksDataSet component

  3. In the smart tag menu for AdvWorksDataSetTasks, click Edit in DataSet Designer.

    The AdvWorksDataSet DataSet designer opens, displaying the Vendor table, as shown in Figure 17.

    Ff621674.7881f348-b882-443a-95be-35a327db4a50(en-us,MSDN.10).gif

    Figure 17. The AdvWorksDataSet DataSet designer

  4. Click the row in the Vendor table that contains the PreferredVendorStatus column name. In the Properties pane, locate the DefaultValue property, and then change its value to True.

  5. In the same way as Step 4, click the ActiveFlag column name in the Vendor table, and then change its DefaultValue property to True.

    Now you need to add the ability to write data changes from the DataSet to the SQL Mobile database.

  6. In the DataSet Designer, click VendorTableAdapter.

  7. In the Properties pane, locate the UpdateCommand property.

  8. In the Update Command property box, select (New).

  9. Expand the UpdateCommand property, click the CommandText property, and then click its ellipsis button.

    The Query Builder dialog box appears with the Add Table dialog box, as shown in Figure 18.

    Ff621674.6ced4d61-745b-41eb-bf04-0a0e0fc9184b(en-us,MSDN.10).gif

    Figure 18. The Query Builder and Add Table dialog boxes

  10. On the Add Table dialog box, click Close.

  11. In the Query Builder dialog box, type or paste the following SQL statement, as shown in Figure 19, which follows the code.

    UPDATE 
        Vendor 
    SET 
        AccountNumber = @AccountNumber, 
        Name = @Name, 
        CreditRating = @CreditRating, 
        PreferredVendorStatus = @PreferredVendorStatus, 
        ActiveFlag = @ActiveFlag, 
        PurchasingWebServiceURL = @PurchasingWebServiceURL, 
        ModifiedDate = @ModifiedDate 
    WHERE 
        VendorID = @VendorID
    

    Ff621674.5492b901-8388-4afc-bbf4-e6ea6af70e53(en-us,MSDN.10).gif

    Figure 19. The Query Builder dialog box with a SQL statement

  12. Click OK.

  13. Close the AdvWorksDataSet.xsd DataSet designer. When you are prompted to save your changes, click Yes.

  14. In the VendorList.cs form designer, click the DataGrid control, and then click the smart tags button at the top-right corner of the control. The smart tag menu appears, as shown in Figure 20.

    Ff621674.bdf0fcba-5ace-4fcd-990a-a618753fcfc6(en-us,MSDN.10).gif

    Figure 20. The smart tag menu for the DataGrid control

  15. In the smart tag menu for DataGrid Tasks, click Generate Data Forms.

    Visual Studio generates two new forms in Solution Explorer: VendorEditViewDialog.cs and VendorSummaryViewDialog.cs, as shown in Figure 21.

    Ff621674.b4a2b62a-a8f0-4806-bdf4-d4ff3c37ef40(en-us,MSDN.10).gif

    Figure 21. Two new forms in Solution Explorer

    Visual Studio has also added a New menu to the VendorList main menu, as shown in Figure 22.

    Ff621674.fd2a893e-4a79-4f3b-afd8-7e716677bc9a(en-us,MSDN.10).gif

    Figure 22. The New menu in the VendorList main menu

    In addition to these readily-visible changes Visual Studio has made to your project, Visual Studio has also added code behind the VendorList form and the new forms it has generated.

  16. In Solution Explorer, right-click VendorList.cs, and then click View Code.

  17. In Code view, locate the newMenuItemMenuItem_Click method. This new method that has been added to the form’s code responds to the user clicking the New menu. The method begins by adding a new record to the vendorBindingSource data binding source; next, it creates an instance of the VendorEditViewDialog form, passing it the vendorBindingSource variable; finally, it displays the form instance that it just created.

  18. Locate the vendorDataGrid_Click method. This method has been added to the form’s code, and it responds to the user clicking the DataGrid control. The method creates an instance of the VendorSummaryViewDialog form, passing it the vendorBindingSource variable, and then it shows the form.

  19. In Solution Explorer, double-click VendorEditViewDialog.cs to open the form designer.

  20. Notice that the form has an individual data-bound control for each column in the Vendor table.

  21. Scroll to and right-click the text box under Modified Date, and then click Properties.

  22. Double-click the Locked property to change its value to True, and then change the BorderStyle property to None. In a moment, you will add code to modify this control’s value before the record is saved, so the control’s text should not be edited by the user.

  23. Click View | Code to view the form's code.

  24. Notice that in the VendorEditViewDialog_Closing method, it calls the EndEdit method of the vendorBindingSource data binding source that it received when it was instantiated, thus saving any data that has been added or edited since the form was opened.

  25. Create a new line before the call to EndEdit and assign the current date and time to the ModifiedDate column. You can easily access the data binding source as shown in the following code example.

        DataRowView dataRowView = 
            (DataRowView)this.vendorBindingSource.Current;
        AdvWorksDataSet.VendorRow vendorRow = 
            (AdvWorksDataSet.VendorRow)dataRowView.Row;
        vendorRow.ModifiedDate = DateTime.Now;
    

    Note

    A more full-featured implementation of this form would be to provide functionality that would allow the user to cancel their changes, but to save time, that functionality is left as an optional exercise.

  26. In Solution Explorer, double-click VendorSummaryViewDialog.cs to open the form designer.

  27. Notice that this form also has an individual data-bound control for each column in the Vendor table, but the controls are read-only. Also notice that the form has an Edit command.

  28. View the form’s code and locate the editMenuItemMenuItem_Click method, which responds to the Edit command being clicked. It behaves much like the newMenuItemMenuItem_Click method on the VendorList form; it simply relies on the fact that the vendorBindingSource variable’s current record will be edited when the VendorEditViewDialog form is opened. This command works because the controls on this form are databound to the same vendorBindingSource instance as the DataGrid on the VendorList form.

You need to add the ability to add any data changes made in your application to the SQL Mobile database file when the user closes the application.

To add functionality to add modified data to the SQL Mobile database

  1. In Solution Explorer, double-click VendorList.cs to return to the VendorList form designer.

  2. Click the form’s title bar. In the Properties pane, click the Events button (with a lightning bolt symbol on it).

  3. Locate and double-click the Closing event to generate an event handler and open the event in Code view.

  4. Add the following code to the VendorList_Closing event handler.

        this.vendorTableAdapter.Update(advWorksDataSet);
    

    This code uses the vendorTableAdapter table adapter to update the SQL Mobile database file with the data changes that have been made to the advWorksDataSet DataSet.

Conclusion

Note

While the generated forms and code provide add and edit functionalities with the single click of a command, a more full-featured implementation would be to provide functionality that would allow the user to delete a record, but to save time, that functionality is left as an optional exercise.

To test application features

  1. In Visual Studio, click Debug | Start Debugging.

  2. In the Deploy AdvWorksMobile dialog box, be sure Windows Mobile 5.0 Pocket PC Emulator is selected, and then click Deploy.

  3. When the application appears in the device emulator, click a row in the DataGrid.

    Note

    You may need to click the device emulator’s button on the Windows taskbar to bring the emulator to the foreground.

  4. Notice that the VendorSummaryViewDialog form appears with the details of the row that you clicked, as shown in Figure 23.

    Ff621674.623d80a8-0741-4243-9645-9cbb65660eb3(en-us,MSDN.10).gif

    Figure 23. Details about a row that was clicked in the Vendor table

  5. Click Edit to open the data form that you can edit, as shown in Figure 24.

    Ff621674.5f23ca99-454d-44f3-9cb8-990676589b1a(en-us,MSDN.10).gif

    Figure 24. Editing a data form in the emulator

  6. After the VendorEditViewDialog form appears, modify some of the data, and then click OK to save it. Notice that the Vendor List form’s DataGrid is updated to reflect the data changes you made, as shown in Figure 25.

    Ff621674.aec9e04c-c01b-415c-b2f7-4c933a1186a5(en-us,MSDN.10).gif

    Figure 25. The updated Vendor List

  7. Click New.

  8. After the VendorEditViewDialog form appears, enter data for a new record, as shown in Figure 26.

    Ff621674.4e16665c-409b-4e86-b54f-888948e4c4ff(en-us,MSDN.10).gif

    Figure 26. Entering a new record

  9. Click OK to save the data. Notice that the Vendor List form’s DataGrid is updated to reflect the new record that you entered, as shown in Figure 27.

    Ff621674.dfee268c-542a-42b1-b9b8-bb9a07319348(en-us,MSDN.10).gif

    Figure 27. The updated Vendor List with the new record

  10. Click OK to dismiss the form, and then close the application.

In this exercise, you have learned how to create a stand-alone SQL Mobile database and how to create a Windows Mobile application that can be used to maintain this stand-alone data. In the next exercise, you will learn how to synchronize data between your mobile database and a back-end SQL Server database.

Exercise 2: Synchronizing Data Between SQL Server 2005 and SQL Mobile

In this exercise, you will enhance the Windows Mobile 5.0 application that you created in Exercise 1 to synchronize data between the SQL Server 2005 AdventureWorks sample database and the SQL Mobile database that your application uses. You will use merge replication to accomplish the synchronization so your device does not always need to be connected to a network or back-end database to be fully functional.

To create a merge replication publication

  1. If SQL Server Management Studio is not already running, click Start | All Programs | Microsoft SQL Server 2005 | SQL Server Management Studio to open it.

  2. In the Connect to Server dialog box, click the Server type box, and then click Database Engine if it is not already selected.

  3. In the Server name box, select your computer name if it is not already selected.

    Note

    Be sure that you select the entry with just your computer name, and not the entry with your computer's name followed by \SQLEXPRESS.

  4. In the Authentication box, be sure Windows Authentication is selected.

  5. Click Connect.

  6. In the Object Explorer pane, expand Replication, right-click Local Publications, and then click New Publication.

    The New Publication Wizard appears, as shown in Figure 28.

    Ff621674.c5150824-77d3-43da-9b2c-a4ec8a123901(en-us,MSDN.10).gif

    Figure 28. The New Publication Wizard

  7. Click Next.

  8. On the Distributor page, be sure computer name will act as its own Distributor; SQL Server will create a distribution database and log is selected, where your computer's name replaces the italicized text, as shown in Figure 29.

    Ff621674.7a5ef316-c13e-4fe5-811c-9e4b041a9f27(en-us,MSDN.10).gif

    Figure 29. The Distributor page

  9. Click Next.

    Note

    If the Snapshot Folder page does not appear, your computer has already been configured for merge distribution. If you are sure that your Windows user account has permissions to read the network snapshot share, you may skip to Step 19; however, it is highly recommended for the purposes of this lab to configure merge distribution as described in the following steps.

  10. On the Snapshot Folder page, make a note of the Snapshot folder value or copy it to Clipboard (by pressing CTRL+C), as shown in Figure 30.

    Ff621674.41543fdd-92ba-4ca6-89c1-4ab9d7fa0793(en-us,MSDN.10).gif

    Figure 30. The Snapshot Folder page

  11. On the desktop computer, click Start | Run.

  12. On the Snapshot folder page of the wizard, copy the path from Snapshot folder box.

  13. In the Run dialog box, paste the path into the Open box, and then click OK, as shown in Figure 31.

    Ff621674.d5ed4c72-8bfc-4268-8094-f797203e46c5(en-us,MSDN.10).gif

    Figure 31. The Run dialog box

  14. In the Windows Explorer window, click Tools | Folder Options.

  15. In the Folder Options dialog box, click the View tab, and then scroll to the bottom of the Advanced settings list.

  16. Be sure to clear the Use simple file sharing (Recommended) option, and then click OK, as shown in Figure 32.

    Ff621674.57cd14bf-ddf4-4d4e-b25e-408fbe499f1a(en-us,MSDN.10).gif

    Figure 32. The Folder Options dialog box

  17. Right-click anywhere in the blank area of the Windows Explorer file and folder area (it is probably empty), and then click Properties.

  18. In the Properties dialog box, click the Sharing tab, and then select Share this folder, as shown in Figure 33.

    Ff621674.301ea114-9a2c-430f-95c1-8d95b5b8f545(en-us,MSDN.10).gif

    Figure 33. Sharing a folder

  19. Click OK, and then close the Windows Explorer window.

  20. In the New Publication Wizard, click Next on the Snapshot Folder page.

  21. On the Publication Database page, be sure AdventureWorks is selected as the publication database, as shown in Figure 34, and then click Next.

    Ff621674.01e1c03d-cd44-408a-8a0c-c992cf6373e7(en-us,MSDN.10).gif

    Figure 34. The Publication Database page

  22. On the Publication Type page, select Merge publication as the Publication type, and then click Next, as shown in Figure 35.

    Ff621674.9feb2140-8d56-4885-a0bb-1d80eb72be99(en-us,MSDN.10).gif

    Figure 35. Selecting a publication type

  23. On the Subscriber Types page, clear the SQL Server 2005 option, and then select SQL Server 2005 Mobile Edition, as shown in Figure 36. Click Next.

    Ff621674.ac5a7d1a-e154-4933-a1c7-7212003a6902(en-us,MSDN.10).gif

    Figure 36. The Subscriber Types page

  24. On the Articles page under Objects to publish, expand Tables, select Vendor, and then click Next, as shown in Figure 37.

    Ff621674.5ae32edd-b5c6-432d-aa7a-ee43ca4a4b4b(en-us,MSDN.10).gif

    Figure 37. The Articles page

    Note

    Additional tables may appear in the Objects to publish list than those in Figure 37.

  25. On the Article Issues page, click Next when the Uniqueidentifier columns will be added to tables issue appears in the list, as shown in Figure 38.

    Ff621674.961bae89-6352-4608-bcb2-df1bcbe14387(en-us,MSDN.10).gif

    Figure 38. The Article Issues page

  26. On the Filter Table Rows page, click Next to indicate that no row filtering is necessary, as shown in Figure 39.

    Ff621674.41caff37-62ff-4842-9944-95f58b0bcf7c(en-us,MSDN.10).gif

    Figure 39. The Filter Table Rows page

  27. On the Snapshot Agent page, clear the Schedule the Snapshot Agent to run at the following times option, and be sure that Create a snapshot immediately is selected, as shown in Figure 40. Click Next.

    Ff621674.2697a892-83f2-421d-8d30-f2f68dc16da8(en-us,MSDN.10).gif

    Figure 40. The Snapshot Agent page

  28. Click the Security Settings button to display the Snapshot Agent Security dialog box.

  29. Select the Run under the SQL Server Agent service account option, and then click OK, as shown in Figure 41.

    Note

    Step 29 is not a recommended security practice, but for the purpose of simplicity in this lab, use this setting.

    Ff621674.fec7ae81-02d0-4b8b-80fa-5f6f10e226b3(en-us,MSDN.10).gif

    Figure 41. The Snapshot Agent Security dialog box

  30. On the Agent Security page, click Next, as shown in Figure 42.

    Ff621674.4ede70c1-59d1-4404-80bd-86bd032e7a70(en-us,MSDN.10).gif

    Figure 42. The Agent Security page

  31. On the Wizard Actions page, be sure that Create the publication is selected, and be sure that the Generate a script file with steps to create the publication option is clear, and then click Next, as shown in Figure 43.

    Ff621674.71b3c884-4c23-4df5-b877-bcee05d1bbe4(en-us,MSDN.10).gif

    Figure 43. The Wizard Actions page

  32. On the Complete the Wizard page, type AdvWorksMobile as the Publication name, and then click Finish, as shown in Figure 44.

    Ff621674.bb185725-0292-40a5-8399-a9f1909d2214(en-us,MSDN.10).gif

    Figure 44. The Complete the Wizard page

  33. Wait for the publication wizard to finish successfully, and then click Close, as shown in Figure 45.

    Ff621674.8ac1d096-cd0b-4287-8ab0-794f600ae22c(en-us,MSDN.10).gif

    Figure 45. The New Publication Wizard successfully finishes

To configure merge replication Web synchronization for the publication

  1. In the SQL Server Management Studio Object Explorer pane, expand Local Publications to reveal the newly created publication.

  2. Right-click the new [AdventureWorks]: AdvWorksMobile publication, and then click Configure Web Synchronization.

    The Configure Web Synchronization Wizard appears, as shown in Figure 46.

    Ff621674.78462de1-44c4-4161-95ca-30e728f7d7fe(en-us,MSDN.10).gif

    Figure 46. The Welcome page for the Configure Web Synchronization Wizard

  3. Click Next.

  4. On the Subscriber Type page, select SQL Server Mobile Edition, and then click Next, as shown in Figure 47.

    Ff621674.ce30ddbd-db50-41cd-a225-cd281093fd26(en-us,MSDN.10).gif

    Figure 47. The Subscriber Type page

  5. On the Web Server page, be sure your computer name appears in the Enter the name of the computer running IIS box.

  6. Select Create a new virtual directory.

  7. Under Select the Web site in which to create the new virtual directory, expand the local computer, expand Web Sites, and then select Default Web Site, as shown in Figure 48. Click Next.

    Ff621674.d7c44c51-6568-485f-9f3f-4a23b4119076(en-us,MSDN.10).gif

    Figure 48. The Web Server page

  8. On the Virtual Directory Information page in the Alias box, type AdvWorksMobile for the virtual directory that will be created, and then click Next, as shown in Figure 49.

    Ff621674.0016eb43-bb04-4664-974f-909519aedd7a(en-us,MSDN.10).gif

    Figure 49. The Virtual Directory Information page

  9. If you are prompted with a message that says The folder does not exist, click Yes to create the folder.

  10. If you are prompted with a message that says This folder does not contain a copy of the SQL Mobile Server Agent, click Yes to copy and register the agent.

  11. On the Secure Communications page, leave the Do not require secure channel (SSL) option selected, and then click Next, as shown in Figure 50.

    Ff621674.aecde07a-d400-48fa-b40c-9a7a96c593c8(en-us,MSDN.10).gif

    Figure 50. The Secure Communications page

  12. On the Client Authentication page, select the Clients will connect anonymously option, and then click Next, as shown in Figure 51.

    Ff621674.0857af17-7fbb-456d-b268-b27eda6fc36d(en-us,MSDN.10).gif

    Figure 51. The Client Authentication page

  13. On the Anonymous Access page, leave the default values, and then click Next, as shown in Figure 52.

    Ff621674.d221ca55-2320-47fe-8e45-9ce677dc2267(en-us,MSDN.10).gif

    Figure 52. The Anonymous Access page

  14. On the Snapshot Share Access page in the Share box, type *\\your_computer's_name\*repldata, where your computer's name replaces the italicized text, as shown in Figure 53. The share name, repldata, corresponds to the merge distribution share that you created in the previous procedure. Click Next.

    Ff621674.1ff17f2c-0c07-4dc3-ab70-629340c77916(en-us,MSDN.10).gif

    Figure 53. The Snapshot Share Access page

  15. On the Complete the Wizard page, click Finish to complete the configuration.

  16. After the Configure Web Synchronization Wizard completes successfully, click Close, as shown in Figure 54.

    Ff621674.b641257f-80d5-426d-94af-1534d3298900(en-us,MSDN.10).gif

    Figure 54. The Configure Web Synchronization Wizard successfully finishes

Because the publication's virtual directory will be accessed anonymously, you need to allow your computer’s anonymous Internet user account to access the SQL Server publication database.

Note

The following procedure is not necessarily a recommended security practice, but it meets the demonstration purposes of this lab. In a production system, you would use some form of authentication to identify the users who access the publication database based on the security requirements of your system.

To permit anonymous Internet user to access the SQL Server publication

  1. In the SQL Server Management Studio Object Explorer pane, right-click the Security folder, and then click New | Login.

  2. In the Login - New window, click the Search button.

  3. In the Select User or Group dialog box, click the Advanced button.

  4. Click the Find Now button.

  5. Scroll through the list of names, and then select the name that starts with IUSR_ and contains your computer's name, as shown in Figure 55.

    Ff621674.6128e91c-e984-4a50-af34-40d56024a42b(en-us,MSDN.10).gif

    Figure 55. The Select User or Group dialog box

  6. Click OK.

  7. Click OK. The name of the user that you selected in Step 5 is displayed in the Login name box, as shown in Figure 56.

    Ff621674.3b93102b-b64c-41f3-97f6-aa04bf9371cb(en-us,MSDN.10).gif

    Figure 56. The Login name box is populated with your selection

  8. Under Select a page, select User Mapping.

  9. Under Users mapped to this login, select the Map column to the left of AdventureWorks.

  10. In the Database role membership box, be sure MSmerge_PAL_role and public are selected, as shown in Figure 57.

    Ff621674.e54911c8-59f4-4619-986d-2a6de6b3d219(en-us,MSDN.10).gif

    Figure 57. The user mapping settings in the Login window

  11. Click OK.

  12. In the Object Explorer pane, expand Replication | Local Publications if it is not already expanded.

  13. Right-click the [AdventureWorks]: AdvWorksMobile publication, and then click Properties.

  14. Select the Publication Access List page, and then click the Add button.

  15. In the Add Publication Access dialog box, select the anonymous Internet user (IUSR_*), and then click OK, as shown in Figure 58.

    Ff621674.79665114-44c2-46f2-9cd1-11a6de1932a0(en-us,MSDN.10).gif

    Figure 58. The Add Publication Access dialog box

  16. Confirm that the user has been added to the Publication access list, and then click OK, as shown in Figure 59.

    Ff621674.9a78e2d8-5754-4ae5-a3c1-0f32955b9244(en-us,MSDN.10).gif

    Figure 59. Verifying that a user has been added to the publication access list

Now that you have created a publication and configured the Web server and database for replication, you can programmatically subscribe to the publication and synchronize data in your application. Instead of connecting your application’s data source to the SQL Mobile database file that you created manually in Exercise 1, you will now connect to a SQL Mobile database that will be created and populated from the AdvWorksMobile publication. Because the schema of the Vendor table that you created in the previous exercise is compatible with that of the Vendor table in the AdventureWorks database, you can simply swap the new database for the old one.

To add synchronization features to your application

  1. If it is not already running, start Visual Studio by clicking Start | All Programs | Microsoft Visual Studio 2005 | Microsoft Visual Studio 2005.

  2. Click File | Open | Project/Solution.

  3. Browse to C:\Program Files\Windows Mobile Developer Samples\HOLs\HOL302_SQL_Mobile\Exercises\Exercise2\AdvWorksMobile, and then select AdvWorksMobile.sln. Click Open. This is a copy of the solution that you created in Exercise 1.

  4. In Solution Explorer, double-click VendorList.cs to open the form designer.

  5. Click the light blue area above the right soft key. The area changes to gray and contains the text Type Here.

  6. Click the same area again to turn it dark blue, so you can replace the Type Here text, as shown in Figure 60.

    Ff621674.b897eb2a-31fb-474a-8c44-fb936e6b2229(en-us,MSDN.10).gif

    Figure 60. Preparing to change the soft key's text

  7. Type the word Menu, and then press ENTER. This menu will provide multiple synchronization functions.

  8. Type Init Sync, and then press ENTER. This command will be used to create a synchronized copy of the vendor data and display it to the user.

  9. Type Sync, and then press ENTER. This command will be used to synchronize the database that has already been created via the Init Sync command.

  10. Verify that the menu editor now looks like Figure 61.

    Ff621674.0c6bb338-02f2-46d1-96e2-e36350a03778(en-us,MSDN.10).gif

    Figure 61. The commands for the right soft key

  11. Right-click the Init Sync command, and then click Properties.

  12. Change the (Name) property to menuInitSync.

  13. In the same way, change the Sync command's (Name) property to menuSync.

  14. Double-click the Init Sync command to create a click event handler for the command. The Code view opens.

  15. Return to the form designer, and then double-click the Sync command to create a click event handler for it. You will add code to the event handlers that you have just created in a few steps.

  16. Locate the using statements at the beginning of the file, and then add the following three using statements.

    using System.Data.SqlServerCe;
    using System.IO;
    using System.Reflection;
    
  17. Declare a class-level variable of type SqlCeReplication that is named _repl. A good place to put the following line of code is near the beginning of the VendorList class.

    SqlCeReplication _repl = new SqlCeReplication();
    
  18. Create a private read-only string property named DataFileName, as shown in the following code example.

    private string DataFileName
    {
        get { return Path.ChangeExtension(
                Assembly.GetExecutingAssembly().GetName().CodeBase, ".sdf"); }
    }
    

    This property generates and returns the name of the SQL Mobile database file that will be created and updated with subscription data. It uses the System.IO.Path.ChangeExtension() method and System.Reflection.Assembly.GetExecuting.Assembly().GetName().CodeBase property to generate the path and name for the database file. The database file is stored in the same folder and has the same base file name as the application’s assembly with an .sdf extension added.

  19. Create another private read-only string property named DataSourceConnectionString to generate and return the data source connection string for the SQL Mobile database, as shown in the following code example.

    private string DataSourceConnectionString
    {
        get { return string.Format("Data Source = {0};", this.DataFileName); }
    }
    

    This code uses the DataFileName property that you just created and returns a string in the format expected for a connection string to a SQL Mobile database.

  20. Create a private bool method named Connect that conditionally connects to the SQL Mobile database, as shown in the following code example.

    private bool Connect()
    {
        if (File.Exists(this.DataFileName))
        {
            this.vendorTableAdapter.Connection =
                new SqlCeConnection(this.DataSourceConnectionString);
            return true;
        }
        else
            return false;
    }
    

    This code uses the DataFileName property that you just created and the System.IO.File class’s Exists method to check if the SQL Mobile database file is available for connection. If it is available, the connection is made between the SQL Mobile database and the vendorTableAdapter table adapter and a value of true is returned; otherwise, false is returned.

  21. Create a private method named GetData that uses the vendorTableAdapter table adapter to fill the advWorksDataSet data set from the SQL Mobile database, as shown in the following code example.

    private void GetData()
    {
        this.vendorTableAdapter.Fill(this.advWorksDataSet.Vendor);
    }
    
  22. Likewise, create a private method named SaveData that uses the vendorTableAdapter table adapter to save the advWorksDataSet data set contents to the SQL Mobile database, as shown in the following code example.

    private void SaveData()
    {
        this.vendorTableAdapter.Update(advWorksDataSet);
    }
    
  23. Create a private method named InitReplication that sets up the _repl SqlCeReplication object, as shown in the following code example.

    private void InitReplication()
    {
        _repl.InternetUrl = @"https://vstowb-4051400/AdvWorksMobile/sqlcesa30.dll";
        _repl.Publisher = @"VSTOWB-4051400";
        _repl.PublisherDatabase = @"AdventureWorks";
        _repl.PublisherSecurityMode = SecurityType.NTAuthentication;
        _repl.Publication = @"AdvWorksMobile";
        _repl.Subscriber = @"AdvWorksMobile";
        _repl.SubscriberConnectionString = this.DataSourceConnectionString;
    }
    

    This code applies several property values to the _repl object to set it up for proper merge replication.

    The InternetUrl property should contain the name of the computer that has been set up as the merge publication Web share, and it needs to end with sqlcesa30.dll. Be sure to replace the italicized your_computer_name with your computer’s actual name or IP address. Be aware that because this code will run on a device or emulator—and not your computer—you cannot use localhost here.

    Set the Publisher property to be the name of the database server that has been set up as the publisher, again replacing the italicized your_computer's_name with your computer's name or IP address.

    The name of the PublisherDatabase is the AdventureWorks database that was set up for replication.

    The PublisherSecurityMode is set to SecurityType.NTAuthentication, so the IUSR_* user is automatically logged in to the publishing database server.

    The Publication property is set to the name of the publication that you previously created: AdvWorksMobile.

    The Subscriber is named the same as the publication for simplicity.

    The SubscriberConnectionString uses the DataSourceConnectionString property that you previously created to connect to the device’s SQL Mobile database.

    It is no longer desirable to load the locally stored data that you created manually in Exercise 1 when the application starts.

  24. Locate the VendorList_Load method, and then comment out or remove the line of code that fills the vendorTableAdapter table adapter, as shown in the following code example.

        //this.vendorTableAdapter.Fill(this.advWorksDataSet.Vendor);
    
  25. In its place, add the following code that calls the InitReplication, Connect, and GetData methods that you previously created to retrieve any data that may exist.

        this.InitReplication();
        if (this.Connect())
            this.GetData();
    
  26. Create a private method named SyncVendors that commits any pending data changes in the advWorksDataSet DataSet to the SQL Mobile database, synchronizes the data via merge replication, and rebinds the synchronized data to the advWorksDataSet DataSet, as shown in the following code example. This should all be conditional upon the existence of the SQL Mobile database file.

    private void SyncVendors()
    {
        if (File.Exists(this.DataFileName))
        {
            this.SaveData();
            _repl.Synchronize();
            this.GetData();
        }
        else
            MessageBox.Show("The subscription database has not yet been created. You must first select the Init Sync menu item.");
    }
    

    This code uses the DataFileName property that you previously created and the System.IO.File class’s Exists method to determine if synchronization is valid at this point based on the existence of the SQL Mobile database file. Assuming the file exists, the code saves the data to the SQL Mobile database file by using the SaveData method that you created. Next, it calls the _repl object’s Synchronize method to make changes in both the publishing SQL Server database and the subscribing SQL Mobile database. All modifications made in the local SQL Mobile database are applied to the SQL Server database, and any modifications that have been made to the SQL Server data are applied to the SQL Mobile database. Finally, it retrieves the updated data by using the GetData method that you created.

    If the database file does not yet exist, the code gives the user feedback and instructions to first initialize the synchronization.

  27. Locate the empty menuInitSync_Click method. Add the following code to create a subscription to the merge publication and synchronize the data for the first time.

        bool okToContinue = !File.Exists(this.DataFileName);
    
        if (!okToContinue)
            okToContinue = MessageBox.Show("The SQL Mobile database already exists on this device and will be overwritten. Continue?", 
                "Warning", MessageBoxButtons.YesNo, MessageBoxIcon.Exclamation, 
                MessageBoxDefaultButton.Button1) == DialogResult.Yes;
    
        if (okToContinue)
        {
            File.Delete(this.DataFileName);
            _repl.AddSubscription(AddOption.CreateDatabase);
            this.Connect();
            this.SyncVendors();
        }
    

    Before the subscription is synchronized, this code checks for and deletes any existing SQL Mobile database file using the System.IO.File class’s FileExists and Delete methods, first giving the user a chance to cancel the initialization if the user doesn’t want to delete the existing subscription data.

    Next, the _repl AddSubscription method is called with the CreateDatabase AddOption enumeration value to create the SQL Mobile database file and set it up for synchronization.

    Now that the SQL Mobile database file exists, the Connect method that you previously created is used to connect to it.

    Finally, the code calls the SyncVendors method that you created to perform the first actual synchronization. During this first synchronization, the table is created in the SQL Mobile database with the same schema it has on the server. The data from the SQL Server table is downloaded into the table that is contained in the SQL Mobile database. At the end of the synchronization, the table in the SQL Server database and the table in the SQL Mobile database have the same data.

  28. Locate the VendorList_Closing event handler, and then replace the call to the vendorTableAdapter.Update method with the following code.

        this.SaveData();
        _repl.Dispose();
    

    This code uses the SaveData method that you created, which now has the code to update the SQL Mobile database. The code also properly disposes of the _repl object’s resources after they are no longer needed.

  29. Locate the menuSync_Click method, and then add a line of code that calls the SyncVendors method. This option allows the user to initiate synchronization.

        this.SyncVendors();
    

To enable the emulator to connect to the merge publication Web site that is running on your local computer, you need to provide the emulator with network connectivity. The easiest way to provide network connectivity is to use ActiveSync 4.0 or later to connect to the emulator. This is a newly provided feature of Visual Studio 2005 and ActiveSync 4.0.

To establish connectivity between the emulator and the desktop computer

  1. On the desktop computer, click Start | All Programs | Microsoft ActiveSync.

  2. In ActiveSync, click File | Connection Settings.

  3. In the Connection Settings dialog box, select Allow connections to one of the following, if it is not already checked, and then select DMA in the corresponding list.

  4. Click OK.

    ActiveSync is now able to connect to the emulators and physical devices. The next step is to connect and cradle the emulator by using the new Visual Studio 2005 Device Emulator Manager.

  5. In Visual Studio, click Tools | Device Emulator Manager.

  6. In Device Emulator Manager, scroll to and select Windows Mobile 5.0 Pocket PC Emulator. You may have to expand the Windows Mobile 5.0 Pocket PC SDK node to locate Windows Mobile 5.0 Pocket PC Emulator.

  7. If there is not already a green arrow next to Windows Mobile 5.0 Pocket PC Emulator, click Actions | Connect in Device Emulator Manager. A green arrow should appear next to Windows Mobile 5.0 Pocket PC Emulator.

  8. With Windows Mobile 5.0 Pocket PC Emulator still selected, click Actions | Cradle in Device Emulator Manager.

    ActiveSync should begin the connection process, which may take a minute or two.

  9. If the Microsoft Office Outlook dialog box appears, click OK.

  10. If the Microsoft ActiveSync dialog box appears, click OK.

  11. On the Synchronizing Setup Wizard page, click Cancel.

    Clicking Cancel establishes connectivity between the emulator and the desktop computer without requiring that ActiveSync be configured to keep files and Microsoft Office Outlook® information on the emulator and desktop computer synchronized.

You are now ready to test the application.

To test application features

  1. In Visual Studio, click Debug | Start Debugging.

  2. In the Deploy AdvWorksMobile dialog box that appears, be sure Windows Mobile 5.0 Pocket PC Emulator is selected, and then click Deploy.

  3. When the application appears in the emulator, click Menu.

  4. Click the Init Sync command. After going through the synchronization setup and actual synchronization, the emulator displays the updated vendor list, as shown in Figure 62.

    Ff621674.e13307d1-196b-42e6-b776-c9d109d3e76d(en-us,MSDN.10).gif

    Figure 62. The updated vendor list in the emulator

  5. Click the first vendor row (with a Vendor ID of 1) to display the summary screen.

  6. Click the Edit command, and then wait for the Edit screen to appear.

  7. Change some of the data values, and then click OK to save your data changes.

  8. Verify that your changes are reflected in the DataGrid.

  9. Click New.

  10. When the Edit screen appears, fill in the fields with new data, and then click OK.

  11. Verify that your new record appears in the DataGrid.

  12. Return to SQL Server Management Studio, and then connect to your computer’s SQL Server database engine if it is not already connected.

  13. In the Object Explorer pane, expand Databases | AdventureWorks | Tables.

  14. Right-click the Vendor table (it may have a prefix), and then click Open Table.

  15. Browse to the second vendor (with a VendorID of 2), and then change the AccountNumber and Name to new values, like those in Figure 63.

    Ff621674.16b8934b-f084-43b1-9c22-db5a7ee353a7(en-us,MSDN.10).gif

    Figure 63. Changing the second vendor's account number and name

  16. Use the mouse or arrow keys to browse to another row in the table to save your changes. The editing pencil icon disappears from the left column.

  17. Browse to the new row (with an asterisk in the left column), and then add a new record. You don’t need to add values for the VendorID column or any columns beyond and including the ModifiedDate column. The merge replication procedure created the additional rowguid column to identify records for replication. The column’s value is generated automatically.

  18. Browse to another row to save your new record.

  19. In the application on the emulator, click Menu | Sync to synchronize the data in the SQL Server and SQL Mobile Vendor tables. Be sure you click Sync this time, and not Init Sync. Selecting Init Sync would delete and recreate the SQL Mobile database rather than synchronizing it with the SQL Server database.

  20. After the synchronization is complete, view the list of records in the device application’s DataGrid. Verify that the changes you made on the device and on the server by using SQL Server Management Studio are reflected on the device.

  21. On the vendor table in SQL Server Management Studio, click Query Designer | Execute SQL to refresh the data, and then verify that the changes you made in both places are reflected on the server as well.

  22. On the emulator, click OK to close the application.

In this exercise, you have learned how to use merge replication to synchronize data between a SQL Mobile database and a back-end SQL Server database, retaining a fully functional mobile application that only needs to connect to a network for synchronization.

Exercise 3: Synchronizing Data Between Any Back-end Database and SQL Mobile Database Using a Web Service

In this exercise, you will modify your application to synchronize its SQL Mobile data with any back-end data store using a Web service.

Note

For the purposes of this exercise, the Web service synchronization will only be one way—from the SQL Mobile database to the SQL Server database. A more full-featured implementation would synchronize data both ways, but the purpose of this exercise is to demonstrate how simple it is to use a Web service as the mechanism for transmitting data from a mobile device to a back-end data store.

To add Web service synchronization features to your application

  1. If it is not already running, start Visual Studio by clicking Start | All Programs | Microsoft Visual Studio 2005 | Microsoft Visual Studio 2005.

  2. Click File | Open | Project/Solution.

  3. Browse to C:\Program Files\Windows Mobile Developer Samples\HOLs\HOL302_SQL_Mobile\Exercises\Exercise3\AdvWorksMobile, and then select AdvWorksMobile.sln. Click Open. This is a copy of the solution that you created in Exercise 2.

  4. In Solution Explorer, right-click References, and then click Add Web Reference.

    The Add Web Reference dialog box appears, as shown in Figure 64.

    Ff621674.d188f2af-587b-426b-9674-d4b84fb61902(en-us,MSDN.10).gif

    Figure 64. The Add Web Reference dialog box

  5. In the URL box, type http*://your_machine_name/*AdvWorksServices/DataService.asmx, replacing the italicized text with your computer's name, and then click Go.

    The Web service that appears is a simple service that was installed with the files for this HOL. As you will see, the Web service provides Create and Update methods that accept an AdvWorksDataSet.VendorDataTable DataTable whose schema is compatible with the AdvWorksDataSet.VendorDataTable in your mobile application. The Create method expects to receive any new records that the caller has added since the last synchronization, and the Update method expects to receive any records the caller has updated since the last synchronization.

  6. In the Web reference name box, type AdvWorksServices, and then click Add Reference, as shown in Figure 65.

    Ff621674.14a7d90a-25b6-4f44-8469-46a9ba5603e1(en-us,MSDN.10).gif

    Figure 65. Providing a Web reference name

  7. Verify that the AdvWorksServices Web service appears in Solution Explorer under Web References, as shown in Figure 66.

    Ff621674.92773d01-b163-4544-a69a-3bfc5acbfc28(en-us,MSDN.10).gif

    Figure 66. Verifying the new Web reference is in Solution Explorer

  8. In Solution Explorer, double-click VendorList.cs to open the form designer.

  9. Click Menu above the right soft key to reveal the commands.

  10. Click the gray Type Here text below the Sync command to turn it dark blue, so you can replace the default text, as shown in Figure 67.

    Ff621674.ab54f83d-fbc7-4503-848a-f3b6a9b212be(en-us,MSDN.10).gif

    Figure 67. Replacing the default text

  11. Type Sync with WS, and then press ENTER. This command will be used to synchronize your data with a Web service.

  12. Verify that the menu editor now looks like Figure 68.

    Ff621674.e05f5a1e-ac35-4d2a-9777-bb7dc3ebeae1(en-us,MSDN.10).gif

    Figure 68. The Sync with WS command is added to the menu

  13. Right-click the Sync with WS command, and then click Properties.

  14. Change the (Name) property to menuSyncWS.

  15. Double-click the Sync with WS command to create a click event handler. The Code view opens.

  16. In the menuSyncWS_Click event handler, add the following code.

        AdvWorksServices.DataService advWorksDataService =
            new AdvWorksMobile.AdvWorksServices.DataService();
    
        DataTable addedRows = 
            advWorksDataSet.Vendor.GetChanges(DataRowState.Added);
        if (addedRows.Rows.Count > 0)
        {
            AdvWorksServices.AdvWorksDataSet.VendorDataTable 
                addedRowsForService =
                new AdvWorksServices.AdvWorksDataSet.VendorDataTable();
            addedRowsForService.Merge(addedRows);
            advWorksDataService.Create(addedRowsForService);
        }
    
        DataTable modifiedRows =
            advWorksDataSet.Vendor.GetChanges(DataRowState.Modified);
        if (modifiedRows.Rows.Count > 0)
        {
            AdvWorksServices.AdvWorksDataSet.VendorDataTable 
                modifiedRowsForService =
                new AdvWorksServices.AdvWorksDataSet.VendorDataTable();
            modifiedRowsForService.Merge(modifiedRows);
            advWorksDataService.Update(modifiedRowsForService);
        }
    
        this.SaveData();
    

    This code begins by creating an instance of the AdvWorksMobile.AdvWorksServices.DataService Web service proxy class that was generated when you referenced the Web service.

    Next, the code creates a DataTable that contains any newly added rows from the advWorksDataSet Vendor DataTable by calling the GetChanges method with the DataRowState.Added enumeration value. If any new rows exist, they’re merged into an AdvWorksServices.AdvWorksDataSet.VendorDataTable DataTable and passed to the Web service’s Create method.

    The code then similarly retrieves any modified records using the DataRowState.Modified enumeration value, and then passes them to the Web service’s Update method.

    Finally, the code saves the additions and modifications to the SQL Mobile database file by using the SaveData method that you created.

Before you can test the application, you need to be sure the emulator can connect to the network in such a way that it can call the Web service.

To allow network connectivity to call the Web service

  1. If the emulator is not already running, follow the steps in the "To establish connectivity between the emulator and the desktop computer" procedure in Exercise 2.

  2. On the emulator, click the Connectivity icon at the top of the screen. The Connectivity balloon appears. Figure 69 shows the Connectivity balloon pointing to the Connectivity icon.

    Ff621674.5a2cff3e-8d8d-45a9-9206-68c46f73d572(en-us,MSDN.10).gif

    Figure 69. The Connectivity balloon points to the Connectivity icon

  3. Click Settings, and then click the Connections icon.

  4. Click the Advanced tab, and then click the Select Networks button.

  5. Be sure that My ISP is selected in both drop-down lists, and then click OK.

  6. Click OK, and then click the close button at the top right of the Settings screen.

You are now ready to test the new application feature.

To test application features

  1. In Visual Studio, click Debug | Start Debugging.

  2. In the Deploy AdvWorksMobile dialog box that appears, be sure Windows Mobile 5.0 Pocket PC Emulator is selected, and then click Deploy.

    Note

    If you skipped Exercise 2, you will need to be sure the emulator is connected and cradled as described in the "To establish connectivity between the emulator and the desktop computer" procedure.

  3. Use the application’s user interface to edit and create new data in the SQL Mobile database as you did in the "To test application features" procedure in Exercise 2.

    Note

    If you skipped Exercise 2, you will need to use ActiveSync’s Explore button to locate \Program Files\AdvWorksMobile\Vendors.sdf on the emulator, and then rename it to AdvWorksMobile.sdf. After doing so, click OK to close the application on the emulator, and then restart this procedure at Step 1.

  4. Click Menu | Sync with WS to synchronize your local changes with the back-end data store via the Web service.

  5. Because the back-end database in this exercise is the same SQL Server AdventureWorks database that you have been using, use the same SQL Server Management Studio techniques that you used in the "To test application features" procedure in Exercise 2 to verify that the data changes you made on the device are now present on the server.

Conclusion

In this exercise, you modified your application to synchronize its SQL Mobile data with any back-end data store using a Web service.

Conclusion

In this lab, you performed the following exercises:

  • Creating and using a SQL Mobile database in a Windows Mobile 5.0 application
  • Synchronizing data between a SQL Server 2005 and SQL Mobile database
  • Synchronizing data between any back-end database and SQL Mobile database using a Web service

In this lab, you learned how to use SQL Mobile to synchronize data between a Windows Mobile–based device and a SQL Server 2005 back-end database using merge replication. You set up and configured SQL Server 2005, IIS, and a .NET Compact Framework application. You also learned how to synchronize SQL Mobile data with any back-end data store using a Web service. These techniques have prepared you to easily build a mobile application that keeps mission-critical data in synchronization with a back-end database.

Terminating an Application That Is Running on a Device or Emulator

This appendix describes how to terminate an application that is running on a device or emulator. This is useful for cases where an application has been started without having the debugger attached and the application needs to be terminated so a new copy of the application can be deployed. You will terminate the application by using the Remote Process Viewer remote tool in Visual Studio.

Before you can terminate a process, you need to know the name of the executable file. In most cases, this is the same name as the Visual Studio project. If you are uncertain about the name of the executable file, you can find it in the project's properties.

To terminate an application that is running on a device or emulator by using the Remote Process Viewer remote tool

  1. In Visual Studio, select Project | xxx Properties, where xxx represents the name of the current project.

  2. In the Project Properties dialog box, note the value in the Assembly Name field. This is the name that the executable file will be running on the device or emulator.

  3. Close the Properties dialog box.

    Now, you can terminate the process.

  4. On the desktop computer, click Start | Microsoft Visual Studio 2005 | Visual Studio Remote Tools | Remote Process Viewer.

  5. When prompted by the Select a Windows CE Device dialog box, select the emulator or device where the application is running, as shown in Figure 70, and then click OK.

    Ff621674.780f8b4f-ff63-46ef-93c8-c47d173b41cd(en-us,MSDN.10).gif

    Figure 70. Select a Windows CE Device dialog box

  6. After the connection to the emulator or device completes, select the application that you want to terminate in the top pane of the Remote Process Viewer, as shown in Figure 71.

    Ff621674.48d79172-30cb-4b42-801f-80aab3ada339(en-us,MSDN.10).gif

    Figure 71. Selecting the application to terminate

    You may need to widen the Process column (the leftmost column) to fully view the process names.

  7. In Windows CE Remote Process Viewer, click File | Terminate Process to terminate the process.

    Note

    Be certain that the correct process is selected before you click Terminate Process. Terminating the incorrect process may render the device or emulator unusable, requiring it to be reset before you can use it again.

  8. Verify that the process is terminated by selecting Target | Refresh. Scroll to the top pane of Windows CE Remote Process Viewer again. If the application name still appears, the process was not terminated, and you need to repeat these steps.

Conclusion

Note

Most processes terminate in one try; however, depending on the state of the application, terminating a process occasionally takes two attempts.

Setting Up Your Computer

Before you begin this HOL, you need to be sure the following procedures are completed.

To install Internet Information Services

  1. On the desktop computer, click Start | Control Panel | Add or Remove Programs.

  2. In the Add or Remove Programs dialog box, click Add/Remove Windows Components.

  3. In the Windows Components list, select Internet Information Services (IIS) if it is not already selected, and then continue clicking Next until the Windows Components wizard is complete.

  4. Close the Add or Remove Programs dialog box.

To use an emulator

  • Be sure that to perform a hard reset on the emulator if you have used the emulator for a previous HOL.

Conclusion

Note

If you used an emulator in a previous HOL, you should do a hard reset on the emulator before starting this HOL. (On the emulator, click File | Reset | Hard.)

Note

If you receive an error during deployment that indicates that the process or file is in use, this means that the program is still running on the emulator and must be closed before a new copy can be deployed and run. This error may appear anytime in the HOL that you deploy the emulator. See Appendix A in this HOL for instructions for exiting a running application.