So far in this series about the IBM Data Studio Developer integrated development environment (IDE) thats available with DB2 Version 9.5 (DB2 9.5), Ive shown you how to set up database connection objects and the actions that you can perform on them. In addition, I introduced you (in Part 2) to some of the features available in the Database Explorer view, and Part 3 and Part 4 gave you a full tour of overview diagrams. In Part 5, you learned how to point-and-click your way to OLE DB functions that can integrate data from external data sources that have an OLE DB provider. In Part 6, I showed you how easy it is to create an SQL statement using the IBM Data Studio SQL Builder. In this installment, Im going to show you my four favorite features in the SQL Builder that make this tool even more helpful than just point and clicking your way to an SQL statement like I showed you in the last article.
Things you have to do to follow the examples in this article...
I recommend that you start with Part 1 because I tend to build on the concepts and objects created in these series sequentially. For this article, I assume that youve at least created the SAMPLE database (use the db2sampl xml sql command) and that the FEMALEPERSONNEL SQL statement built in Part 6 resides in the SQL Scripts folder in a database development project. Your Data Project Explorer and Database Explorer views should look similar to these:
IBM Data Studio Query Builder productivity boosters
In this section, Ill talk about my favorite features that really help boost productivity when youre designing SQL statements using the Query Builder. I may have mentioned some of the features in past articles in this series, but this section will serve as a place where they can all come together.
Perhaps one of the most rapid application development features that I know of in IBM Data Studio is SQL Assist. If youve ever worked with Microsoft Visual Studio and are familiar with IntelliSense, then you already have a good idea what Im talking about. However, when you use the SQL Builder in IBM Data Studio, the assistance is hooked into the underlying databases schema not just the respective programming language semantics. In fact, since IBM Data Studio can maintain a cache of the data servers you are working with, you can even work in a disconnected mode (offline) and still leverage this feature. SQL Assist is a key part of the pureQuery initiative: it places the same assistance feature that Java programmers expect from their tools into an integrated editor that understands both Java and SQL.
For example, create a new query (call it FEMALEPERSONNEL2) and drag the DEPARTMENT and EMPLOYEE tables to your SQL Builder design canvas in the same manner you did in Part 6. IBM Data Studio should now look like this:
In the last article, you added columns to the query by simply selecting them from the middle pane of the SQL Builder. While you can use the graphical controls at the bottom of the SQL Builder to add clauses to your SQL statement, most developers are likely to use a combination of manual entry and assisted entry (like the Add Join and projection options I covered in Part 6). While the check box column definition method is more useful for those not as adept in writing SQL, even SQL maestros will want to use contextual assistance while they are writing the SQL statement; the SQL Builder offers this with SQL Assist.
In the area of the SQL Builder that displays the actual text of your SQL statement, try to manually append the following condition (shown in bold text below) to the SQL statement that was automatically generated for you:
SELECT * FROM DEPARTMENT, EMPLOYEE WHERE PAULZ.EMPLOYEE.WORKDEPT=A00 AND SEX=F ORDERBY PAULZ.EMLOYEE.LASTNAME
Note: Dont forget to substitute the schema qualifier PAULZ used in this article for the schema you used to create the SAMPLE database. (On a Windows platform, its whatever user account you were logged in with when you ran the DB2 CREATE DATABASE command or db2sampl.)
Now I want you to erase the newly typed text and retype it pausing ever so slightly after you specify PAULZ - of course, replace PAULZ with your schema name. (Stop at the period.) In IBM Data Studio, when a period (.) follows a schema name that DB2 recognizes, the SQL Assist feature is automatically engaged and all the applicable objects in context (in this case, the schema objects) are automatically presented in a pop-up list for you, as shown below:
Simply select the object you are looking for from the pop-up list and press Enter. In this example, select the EMPLOYEE table and briefly pause after typing the qualifying period after the EMPLOYEE table name. You can see that SQL Assist is smart enough to recognize the context of the SQL statement: notice below that the pop-up list only shows the columns that are part of the EMPLOYEE table:
If youre following along in this example, youll want to select the WORKDEPT column. Sometimes you may notice that the column you want isnt on the pop up list. Obviously, you can use the scroll bar or your cursor movement keys to scroll down the list of returned columns - but theres a better way! SQL Assist has filter and stemming options that quickly move focus in the pop-up list to the location based on the first key you press. In this example, if you pressed W, then the SQL Assist pop-up list would only display those columns that begin with this letter:
Note: You can also invoke SQL Assist by right-clicking in your SQL statement window and selecting SQL Assist from the pop-up menu, or by pressing Ctrl+Space after specifying an object name in your SQL statement.
Continue building this SQL statement, but now I want you to manually enter the AND SEX=F restriction. (Notice that it changed color - well talk about that in a bit.) You can see that sometimes its better just to type something quickly than to leverage SQL Assist. As you get more accustomed to this great feature, youll decide for yourself when to use it and when to use your old fashioned fast-typing fingers. In this case, I know I dont actually have to specify the schema here, and I know there is a column called SEX, and I know the value and its corresponding data type, so it was just faster to enter it myself.
Enter a space after SEX=F. SQL Assist can help further, but its only going to show up if you ask for it using one of the methods detailed in the previous note (because there is no period triggering the action). For example, to add the ORDER BY clause, invoke SQL Assist and manually scroll the entire list of options to find this operator. (Of course, pressing a letter key will automatically move focus in the list to the first occurrence for that group):
You can see this list is very long. The point is that there is always some help available for you, and depending on the context of the SQL statement, it changes dynamically. Finish building this SQL statement and save your work.
Of course, since views and nicknames are presented like tables to applications, IBM Data Studio will link the SQL Assist features to enumerate all the qualifying views and nicknames, along with tables, in the list returned to the developer.
Another reason why this feature is so important is that if you were to create an SQL statement using the SQL Editor, you wouldnt have the option to drag (or add) tables to the middle pane of the editor. You would just have the SQL text.
You can also customize the way SQL Assist behaves in IBM Data Studio. For example, you could choose whether to display SQL proposals (keywords, templates, and names of database objects) when you use content assistance while writing or editing an SQL statement. As previously mentioned, Ctrl+Space is the default key combination for this content assistance. If you want to change this combination, select Window>Preferences>General>Keys and change the configuration for Content Assist.
SQL Assist really enhances productivity because it moves the requirement away from knowledge of the database schema for productivity and places automated discovery of the schema in the hands of the application developers for a rapid application development experience: this is true extreme application development.