Step-by-step Guide
When using InfoWorks WS Pro, SQL is a flexible tool for importing and exporting data. In this example is a CSV containing a list of customers who have reported low water pressure. This example creates a selection list of these customers.
- In a file browser window, navigate to the folder containing the exercise data.
- In Notepad or a spreadsheet program like Microsoft Excel, open the Customers.csv file to check the structure.
The first value must be the name of the variable to be used; in this case, it is $customers. All values, or for this example, customer IDs, are separated by commas.
data:image/s3,"s3://crabby-images/690d2/690d2b490ca27ca2e025e80711d0473066d97449" alt="A Microsoft Excel spreadsheet with the Customers.csv file open and the first value highlighted in red."
- Close the file.
To locate the full file path, which is necessary to load it in an SQL query:
- In the file browser window, right-click Customers.csv and select Properties.
- On the Security tab, in the Object name field, select all the text.
- On your keyboard, press CTRL+C
data:image/s3,"s3://crabby-images/1363d/1363d0d9f931a61a189f7646f4335745301f6432" alt="The Properties dialog box for Customers.csv, Security tab, with the complete file path selected and highlighted in red."
- Click OK.
- From the Model Group window, drag-and-drop the BridgeNet network into the workspace to open the GeoPlan.
- In the Selection menu, pick SQL Select.
data:image/s3,"s3://crabby-images/11cbb/11cbbd72dbb4daf9eef6b444e5b0ff839490fb5f" alt="The InfoWorks WS Pro interface with the Selection menu displayed and SQL Select selected; and in the workspace, the BridgeNet GeoPlan open."
Your SQL query needs to load the list of customers, and then select any customers in that list.
- In the SQL dialog box, expand the Object Type drop-down and select Customer Point.
- In the text box, type: LIST $customers;
This defines the list variable you will load your CSV into. Remember that this must match the first value in your CSV.
- On your keyboard, press ENTER.
- Type: LOAD $customers FROM FILE ‘
- On your keyboard, press CTRL+V to paste the complete file path.
- Type another apostrophe (‘).
- Type a semicolon (;).
This loads your CSV into the list variable.
- Type: SELECT WHERE MEMBER(reference, $customers)
This will select any customer whose reference field is in your $customers list. Your syntax should match the image below:
data:image/s3,"s3://crabby-images/4fbbf/4fbbf95218f6f9d195627378bd46695c0464ac78" alt="The SQL dialog box with the SQL query entered."
- Click Test to ensure the query syntax is correct.
- In the notification, click OK.
data:image/s3,"s3://crabby-images/ffdc7/ffdc7a06db36c488f1436c65421014adca10c18e" alt="The SQL dialog box with Test highlighted in red and the notification with OK selected."
- Click Apply.
There should now be customers selected in the network. If the customers are not visible:
- Move the SQL dialog box to one side.
- Right click in the GeoPlan and select Find selection.
data:image/s3,"s3://crabby-images/a3a2b/a3a2bf971af40bcc8c7db14b9d6abeac62270f69" alt="The GeoPlan shortcut menu with Find selection selected and called out."
- Close the SQL dialog box.
- In the Model Group window, open the existing Selection Lists group.
OR, to create a new one:
- Right-click the Selection Lists group.
- Select New > Selection List.
data:image/s3,"s3://crabby-images/eb854/eb8548bda4989f6518fb33ff94964c9f972f96f9" alt="In the Model Group window, the Selection Lists shortcut menu with New selected, and in the flyout, Selection List selected and called out."
- Name the selection list “Customers”.
- Click OK.
To clear the current selection:
- On the Operations toolbar, click Clear Selection.
- From the Model Group window, drag-and-drop the Customers selection list into the GeoPlan to re-select the customers.
data:image/s3,"s3://crabby-images/c1892/c1892eaaae8b729898c83bebda44cfd9cd7b3f1a" alt="In the Operations toolbar, Clear selection highlighted in red, and below, the mouse pointer dragging the Customers selection list from the Model Group window into the GeoPlan."
Now, repeat the process in reverse, and then export the affected customers:
- With the Customers still selected, in the Selection menu, pick SQL Select.
- In the SQL dialog box, expand the Object Type dropdown and select Customer Point.
- Enable Apply Filter to Current Selection.
- Type the following query: SELECT reference INTO FILE ‘
- On your keyboard, press CTRL+V to paste the file path to the CSV again.
Note: If needed, repeat Steps 4-7 to copy the full file path.
- Change the filename to CustomersExport.csv.
- At the end of the filename, type an apostrophe (‘).
data:image/s3,"s3://crabby-images/60aa1/60aa1869342a928dddecc891685b940384150cc8" alt="The SQL dialog box with the export SQL query entered and Apply selected."
- Click Test to make sure that the query syntax is correct.
- Click OK.
- Click Apply.
- Navigate to the data folder, where you will find a list of exported customer IDs.
data:image/s3,"s3://crabby-images/c682d/c682d50639ccc0b08817fd18bcb7ebfeb8681dc1" alt="A Microsoft Excel spreadsheet with a list of exported customer IDs."