data:image/s3,"s3://crabby-images/7c3c7/7c3c747733e66ff9ce9534972e7b112dd083fe32" alt="Oracle SQL Developer 2.1"
Browsing objects
Whether you are about to embark on new development, modify existing objects, or just want to see what's in your database, you are likely going to start by browsing the schema or schemas you have access to. Technically, you are querying the Oracle database, and so many of the actions in this chapter, such as using a menu to drop a table, or a dialog to create a new table with columns and constraints, can be done by writing the SQL in the SQL Worksheet or SQL*Plus. By using the functionality the tool provides, you can quickly complete a multitude of tasks. In SQL Developer, you use the Connections navigator to browse (or query) the database objects. To follow the examples in this section, you need to create database connections for the sample schemas HR and OE. You will also need access to SYSTEM, or a user capable of granting privile ges to other users.
Working with the Connections navigator
Objects are grouped into nodes in the Connections navigator to reflect their types. They are ordered by most commonly used with Tables, Views, and Indexes, at the top of the list. You can refer to the following screenshot to see the grouping, order, and some of the currently available types displayed in the Connections navigator. The selection of browsable object types available increases with each release as the SQL Developer team adds support for more features. For example, Queues and Queues Tables were introduced in Oracle SQL Developer 1.5, and Jobs were added in SQL Developer 2.1.
data:image/s3,"s3://crabby-images/857bb/857bb55138ee223ecad3c2231992b8e6fd3de584" alt="Working with the Connections navigator"
To open a connection in the navigator:
- Double-click the connection.
- Expand the node.
- Select Connect from the context menu.
The first time you connect to a database schema, whether you open an existing connection or click on Connect in the New Database Connections dialog, SQL Developer automatically expands the connection in the Connections navigator and opens a SQL Worksheet. This automatic opening of the SQL Worksheet is controlled by a preference: Open a Worksheet on connect. Select Tools | Preferences, expand the Database node and select Worksheet.
Tip
Reconnecting users
When doing administrative work with users, it can help to disconnect the user you are working with before making the changes, and reconnect them afterwards. Some actions, such as dropping users or renaming connections, will not be possible without first disconnecting the connection.
Tip
Database schema or user?
The Oracle Concepts Guide states,
"A schema is a collection of database objects. A schema is owned by a database user and has the same name as that user."
Throughout the text, we use schema and user interchangeably. For the most part, we refer to the OE and HR schemas, meaning the collection of database objects. When closely or directly related to an activity we use "user", as the code does this. For example, DROP user HR cascade
; a piece of code that drops all of the objects in the schema and the user itself.
Working with objects
To work with any object, select and expand the node. The most common node you'll work with is the Tables node. This displays all of the tables the user owns (all of the tables in the schema). Each of the object nodes is identified by an icon, and the Tables node highlights some of the main table types using these icons. Not all are singled out, but the more commonly used ones are. If you expand the HR Tables node, the COUNTRIES table, which in the sample is an index-organized table, is identified by the slightly different table icon used. Partitioned tables are also distinguished from regular, simple tables using icons. The following screenshot displays the index organized, regular, external, partitioned, and temporary icons:
data:image/s3,"s3://crabby-images/d3a60/d3a60ff690c3ea8c9c6216ed2ca48436567d9f40" alt="Working with objects"
Using the HR and OE schemas is useful for illustrating various features within SQL Developer. They do not reflect reality, where you'd typically be working with many more objects or sets of objects, within a schema or across schemas, and the mere act of expanding a node exposes a long and possibly unworkable list of objects. SQL Developer provides filtering for each object type, which allows you to control the display of objects.
To use the filter, select an object node, such as Tables, and select Apply Filter... from the context menu.
Depending on the object node selected, the choice of filter criteria varies. An important feature to note is the Include Synonyms checkbox, available for tables and views. All object nodes will only display those objects that belong to the schema. If one schema has access to the objects in another schema, you can create synonyms for those objects and, using the filter, have them display in the object node. Without the filter, you need to use the Other Users node to see the objects in another schema.
data:image/s3,"s3://crabby-images/56525/56525da52787772aef700a464b24181be6328d73" alt="Filtering objects"
In the previous screenshot, the Filter dialog is for tables. For all object filters, you can add multiple selections as shown and select the options:
- Match Any
- Match All
The filter criteria provides lists of choices. In the first for the column, values such as CREATED
and LAST_DDL_TIME
, and for the operator, values such as LIKE
or<>
. Prior to SQL Developer 2.1, the column drop-down list displayed only four choices. These four choices have since been expanded to provide greater control of the objects displayed.
Note
In SQL Developer 2.1, the underlying query no longer includes the restrictions defined in earlier releases. For example, there is no longer the restriction ALL_OBJECTS.GENERATED = 'N'
, which means that your list of tables also includes generated tables. If you tend not to work with these objects, then applying only that filter is worthwhile.
To avoid needing to apply a schema at the level of each object type in the browser, you can set a schema filter. This is particularly useful if you enforce a naming standard that requires all objects to have a prefix or suffix to designate the application or schema with which they are associated. Select Apply Filter... from the database connection for the schema to invoke the dialog:
data:image/s3,"s3://crabby-images/0c30c/0c30c43d51519985dbbd74c52fada08ee067ca9b" alt="Schema level filtering"
You can override the schema level filter using a filter at the object type level. The object filter dialog includes an Override Schema Filter option.
Display editors
Once you have expanded an object type node in the Connections navigator, selecting any object in that node opens a window of tabs, called display editors, which define the object. Each editor displays a data grid of details describing the selected object. These are based on queries against the data dictionary and you can get the same results by writing the SQL yourself.
The number and types of editors displayed will vary depending on the object or database that you are connected to. If you are connected to Oracle Database 11g, then an additional Flashback editor displays with the other table display editors.
Instead of itemizing each of the object types and the different collections of display editors, we'll use the Tables node to review some of the display editor details.
Using the HR connection, select EMPLOYEES in the Tables node to see the general display editors:
data:image/s3,"s3://crabby-images/35c4c/35c4c8740ed4bf3383208c05361739ce27563d4c" alt="General display editors"
The Columns editor displays all of the column detail, including column comments. To get a feel for queries that run behind the editors, run the following query in the SQL Worksheet:
SELECT COLUMN_NAME,DATA_TYPE FROM ALL_TAB_COLUMNS WHERE TABLE_NAME ='EMPLOYEES' AND OWNER = 'HR';
The output from the query matches the first two columns of the Columns display editor (this is a simplified example). If you need to find out more information about any object in the database, without a GUI tool, you need to start by querying the data dictionary to determine which tables hold the metadata about your objects. From there, you must decide what detail you need from these tables, in our example it was the single ALL_TAB_COLUMNS
table, and then write the join clause to query all of the selected tables.
There is a set of editors for each of the object types. For tables, these include Constraints, Grants, Statistics, Triggers, and Partitions. The data in each data grid is a result of a query joining a number of data dictionary tables. SQL Developer provides a framework for you to create and add your own display editors. You can do this with user extensions, which are discussed in the chapter on Extending SQL Developer.
Some of the editors display master-detail output. To see the detail result set you need to select an individual record in the master result set. The following screenshot shows the EMP_NAME_IX for the EMPLOYEES table. By selecting the index, you can quickly see that this index is made up of two columns:
data:image/s3,"s3://crabby-images/80ae0/80ae00496389598e99d86bea6968052d67003c13" alt="General display editors"
To create the index using SQL, use the following query:
CREATE INDEX "EMP_NAME_IX" ON "EMPLOYEES" ("LAST_NAME", "FIRST_NAME");
Each new object selected in the navigator replaces the last, regardless of object type or connection, unless you click on the Freeze View pin button on the object display. This locks the window and a new window opens with a new set of editors.
To see this feature in action, expand the HR Tables node. Select the EMPLOYEES table and note the set of display editors. Now select the DEPARTMENTS table, and note that it replaces the details of the EMPLOYEES table. Expand the Sequences node and click through each of the sequences available. These now replace the tables which were previously displayed. This replacing feature is very useful as it saves screen real estate, and keeps the screen and work area uncluttered. However, it is also very useful to be able to compare two sets of data, side by side. Therefore, by selecting the Freeze View pin, each new object selected opens in a new window and you can then tile the windows.
Note
SQL Developer automatically opens the display editors as you click on the object, or if you navigate down through the objects using the keyboard. You can control this by changing the default Open Object on Single Click behavior. Select Tools | Preferences, in the tree displayed, expand Database, select ObjectViewer and deselect Open Object on Single Click.
The SQL editor is displayed at the end of the set of shipped display editors and is available for most object types (any editors you create are added after the SQL editor). The SQL editor displays the query required to recreate the object selected. When you select the SQL editor, SQL Developer uses the package DBMS_METADATA
to query the database and return the SQL required for recreating the object selected. So, clicking on the editor with a table selected displays the SQL (DDL) for that table.
Select the COUNTRIES table in the Connections navigator. The default display provides the full CREATE TABLE
SQL in a single statement as shown in the following screenshot:
data:image/s3,"s3://crabby-images/6a07d/6a07dcf0703f6617090af5d67469f9ab20c5f37e" alt="Using the SQL display editor"
You can control the SQL output for tables by adjusting the parameters passed to the DBMS_METADATA
package. This is done by using the SQL Developer preferences in the Tools | Preferences dialog, and by setting Database | ObjectViewer options. To illustrate this, deselect Show Schema, Show Storage, and select Show Constraints as Alter and then click on OK:
data:image/s3,"s3://crabby-images/41786/41786f9891ba35cd605448453793f604759698fd" alt="Using the SQL display editor"
Refresh the SQL editor to display the updated output. Notice how the schema prefix "HR" is no longer displayed and the storage specifics are now excluded. This makes it a very useful script to reuse on other databases, or for other schemas. You may also like to create the tables with no constraints, add data, and then apply the constraints subsequently:
data:image/s3,"s3://crabby-images/d6b40/d6b4012b28035454c3924404b5a7724230e795c1" alt="Using the SQL display editor"
Working with the data grids
The contents of each display editor are displayed in data grids, which typically have three or more columns of data within the grid. A few are two column name-value pair data grids, such as the Details editor. The data in these grids is not editable and merely reflects the details about the object or structure selected. There are two exceptions. The first exception is the Data editor included with the set of display editors for certain objects, such as tables and views. The Data editor displays the instance data for a table and, depending on the object, this data can be edited and the changes can be committed to the database. The second exception is new to SQL Developer 2.1. This is the Code editor for PL/SQL objects, where you are placed into a PL/SQL editor when you select the object.
Data grids throughout SQL Developer have context menus on the column's headings and the data grid itself. You can control the layout and what data is displayed by using these two context menus. For the remaining portion of this section we'll review the various options on these context menus.
The easiest way to control the column order displayed in the data grid is to use drag-and-drop. Select the column header and drag it to a new position. Alternatively, you can select Columns... from the context menu on the column heading as shown in the following screenshot:
data:image/s3,"s3://crabby-images/b6045/b60459c9fd2fedd40c5c42dbbd4eca33f0c21a92" alt="Controlling the column display"
This invokes the Manage Columns dialog, which supports reordering of columns. The same dialog also supports the ability to selectively hide and show columns. Regardless of how you reorder or change the display of columns, the new column order remains in place when you close and reopen the display editor, as well as if you close SQL Developer. Along with the other display settings, this value is persisted until you actively change the setting or clear the settings by selecting Delete Persisted Settings... from the same context menu displayed in the earlier screenshot.
The column headings also provide a context menu to Auto-Fit selections. This allows you to resize the column based on the header or the contents of the column. There is also a Best Fit option, which uses a combination of these. Using Ctrl or Shift+select, you can select multiple columns and apply these conditions to all of the columns. An additional Fit Screen option is available to ensure all of the columns fit within the extent of the display area.
With the exception of the two column name-value pair displays, you can sort the records displayed by double-clicking on most of the column headings. This is true for all of the data grids throughout SQL Developer. Columns that allow for sorting display this icon to the left of the column header. You can also perform multiple column sorts by selecting Sort... from the column header context menu. The following screenshot displays the detail of placing two sort settings on the data grid:
data:image/s3,"s3://crabby-images/51c34/51c34b67aaeed071e921383912f6f4a8f3004e4f" alt="Sorting the data"
SQL Developer 2.1 introduced column filters, which are like a WHERE
clause for the display editors. Click on the column header, or select Filter Column from the context menu on the column header. Either action opens a floating menu of choices to restrict the column:
data:image/s3,"s3://crabby-images/71d19/71d195b7e94a0d7efbb5398f2b23ac9f0a3600ef" alt="Filtering columns"
Filtered columns display a filtered symbol. To clear these column filters, invoke the filter menu again and select All..., or select Remove All Filters from the columns context menu.
Tip
Navigating the grid
Navigating the data grid is done using the mouse to click through records, or dragging the scroll bar down through sets of records. You can even use the Page Up and Page Down keys on the keyboard to skip through larger sets of records.
Two additional key combinations, useful for large sets of data, are Ctrl+Page Down to get you to the last record and Ctrl+Page Up to get you back to the start of the records.
Let's move down to the context menu available on the data grids. These are available throughout SQL Developer, wherever a data grid is displayed, and tend to vary slightly. For example, the reports data grids have an additional navigation menu and the updateable data grids have an additional option for duplicating rows. In the next section, we'll consider a few of the options available.
The Filter/Highlight option is available for most data grids. In the following screenshot, we have used one of the data dictionary reports, which has a larger set of data available. The report here is the All Objects report under Data Dictionary Reports | All Objects.
data:image/s3,"s3://crabby-images/d78ff/d78ff4ac978e4d44b471929251903cc2d4015114" alt="Highlighting data"
The Find/Highlight dialog allows you to search for a string in any cell in the grid or in a particular column in the grid. Use the drop-down list to the left-hand side of the search field to select the column for the search. The default is all columns.
The Highlight option is illustrated in the previous screenshot. Here, we applied two searches and highlighted each independently. The persisted searches are tracked in the dialog. If these are not visible, expand the floating window. These highlights persist when you close the dialog, or indeed if you close the report or data grid. Remove the persistent highlights using the same window.
The context menu on any data grid includes:
- Single Record View
- Count Rows
While these are useful on any data grid, they are more useful for data grids where the number of columns displayed is unwieldy, or the number of records displayed is extensive.
data:image/s3,"s3://crabby-images/456a9/456a984c61f3daff69f310851e67a2a4b9a7b827" alt="Count Rows and the Single Record View"
The Single Record View... switches the display of a single record to a form layout. This allows you to see the contents of the cells more clearly as you are now able to scroll down through the column heading, and not across the page.
The Save Grid as Report option is a useful addition to SQL Developer 2.1. This data grid context menu option writes the SQL query, which produced the grid, to the Create Report dialog. This allows you to see and review all of the SQL queries that make up any data grids within the product and create a new user defined report, based on the query. For more information on working with reports, refer to the chapter on The Power of SQL Reports.
The Data and Flashback editors are slightly different to the read-only display editors in that they are related to instance data. The Data editor displays the table data in a grid. You can update, delete, or insert new data using the grid. The Flashback editor also displays the data in the table, and focuses on the changes made to the data.
In the next section, we'll look at the Data editor and focus on the different features available when working with this updatable data grid. To invoke an updatable data grid, select any table in the Connections navigator, and click on the Data editor.
Like the previously discussed data grids, the Data editor data grid has two sort options. The first option is on the column heading, where only one sort applies at a time and each sort replaces the last. The second option allows you to sort on multiple columns. To sort columns on multiple criteria, select the Sort... option just above the data grid. This allows you to sort on a selection of columns, which can be sorted in ascending or descending order.
Filters are restrictions on the displayed data. When you add a filter to the data grid, you are in effect adding a WHERE
clause to the select statement. An example of adding a filter to the COUNTRIES data grid is COUNTRY_NAME LIKE 'A%' OR COUNTRY_NAME LIKE 'C%'
. Each time you invoke the Data editor for a table, the full set of data is returned, that is, without any filters applied. However, any previous filters on the table are stored and you can invoke them from the Filter drop-down list.
The following screenshot displays the EMPLOYEES table with a multiple column sort applied, as indicated by the bold Sort... option. The Filter drop-down list indicates a selection of previous filters for the table:
data:image/s3,"s3://crabby-images/2e8b7/2e8b71cc02dca152565733dbe2ff879f48913a06" alt="Sorting and filtering data"
To invoke the drop-down list, place the cursor in the filter field and start typing or use the down arrow.
To update any data item in the grid, select the item and start typing. As soon as you are in edit-mode, the Edit Value dialog button displays. Clicking on this button invokes an edit dialog, which is useful for larger text fields such as comments:
data:image/s3,"s3://crabby-images/5ea57/5ea57a844b7585978c8d50e82ae9ab721cfd4317" alt="Updating data"
For LOB columns, the value stored is not displayed in the data grid. Instead, the word (BLOB) displays. To see the value, such as the image stored, you can edit the value by selecting the Edit Value dialog button. In the following example, the image is stored in the database. To view the image select the Image checkbox. To use the data grid to add an image, or file to the database, click on Load and select the file. This is not saved to the database until you have committed the changes. Click on OK to close the dialog and then click on the Commit Changes button. You can now view the image or file by once again clicking on the (BLOB) field:
data:image/s3,"s3://crabby-images/7829e/7829e09d5ba967cf9c6fda310c13429e02a18348" alt="Working with LOBS in the data grid"
The Flashback display editor is displayed when you are connected to an Oracle Database 11g. To see the Flashback feature in action, select the Data editor for one of the HR tables, such as DEPARTMENTS. Modify a record and Commit the changes. Now, select the Flashback display editor. You should see Update in the Operation column. If it is not immediately apparent, double-click on the Operation column to sort the data. Select the updated record. The updated record is displayed in the Data editor below the records. Select the Undo SQL tab to view the query required to reinstate the original's re cord. The Undo SQL tab shows the SQL needed to restore the state for the whole transaction.
data:image/s3,"s3://crabby-images/973fa/973fa8371437335ab71508128fa1948935ad2c25" alt="Using flashback"
Reviewing other database object nodes
As you select each of the other database objects, you'll notice that the set of display editors varies considerably.
It would be tedious to single out each of the object nodes and describe them here. The display editors and data grids behave the same for each of them. In this next section, we review the nodes where the behavior or interaction is slightly different and worth noting.
Triggers, functions, procedures, and packages all have their own separate nodes in the Connections navigator. Prior to SQL Developer 2.1, a single-click on any object in these PL/SQL nodes behaved as for all other database objects, that is, a set of defining display editors opens. In order to edit a PL/SQL object, you needed to select the Edit... menu item, or click on the Edit button. Historically, conforming to that standard served only to confuse users wanting to open and edit PL/SQL code.
SQL Developer 2.1 changed this behavior by opening a single set of editors, with the first being the editable PL/SQL code:
data:image/s3,"s3://crabby-images/bab20/bab205c7dfa0f4c3a725557291dcc93421fb70b6" alt="Working with PL/SQL objects"
In the screenshot just displayed, the initial Code editor is the editable PL/SQL code editor. This Code editor is included in the set of display editors for the selected procedure. This differs from earlier product releases, where the code editor was a separate window.
Very often, you may have the connection details for one schema that has access to objects in another schema. One of the most frequently asked questions on the SQL Developer forum is about viewing objects that the schema does not own.
As discussed, the objects under your connection are objects created or owned by the schema defined in the connection. To view any other objects that your connection (schema) has access to, use the Other Users node. When you expand Other Users, for your current connection, you are executing the equivalent SQL query SELECT * FROM ALL_USERS
;. This query returns all of the users in the current database. However, it does not mean that you have access to the objects in each of those schemas.
To review the objects the HR schema has access to, expand the Other Users node for the HR connection. Select and expand the user OE, and then expand the Tables node. You should see the selection of OE tables displayed. Not only does HR have access to these objects, the HR schema can query the data. You can select each table and display the set of editors available. HR is not a privileged user, but is granted the SELECT ANY TABLE
system privilege.
The user SCOTT/TIGER is another of the Oracle database shipped schemas. SCOTT was the original sample user and is not a privileged user. If you have access to SCOTT, create a new database connection for SCOTT and repeat the exercise. If you expand the OE or HR tables nodes under SCOTT's Other Users node, the nodes are empty. SCOTT does not have access to these objects.
You can expand and work with objects you have access to in the Other Users node. You can also create synonyms for these objects and then, using Filters, display the objects within each respective object type node in your connection.
Consider the following example. The HR schema has access to query the OE's CUSTOMERS table. HR can query the table, using SELECT * from OE.CUSTOMERS
;. Now, create a synonym using, CREATE SYNONYM CUSTOMERS FOR OE.CUSTOMERS
;. This means the HR schema can write the queries without having to refer to the OE schema.
In SQL Developer, the synonym definition appears in the Synonyms node. The CUSTOMERS object will appear in the Tables node by setting the Include Synonyms option in the Filter dialog.
In the following screenshot, the tooltip shows that the CUSTOMERS table belongs to OE. The Tables node is also marked as Filtered:
data:image/s3,"s3://crabby-images/b37a1/b37a1636d4d1f2221b93636671bf6ad52cf28c93" alt="Synonyms and filters"
The Recycle Bin was introduced to Oracle databases in Oracle Database 10g. SQL Developer displays the contents of the Recycle Bin in the Recycle Bin node. For supported databases, the Recycle Bin provides a listing of all objects deleted from the schema. The information displayed about dropped objects, includes the date the object was created and dropped, and whether the object can be undropped (reinstated) or purged. SQL Developer displays the original name of the object in the Connections navigator for ease of use. However, once dropped, the object has a new name. This allows you to drop objects and create new ones without the dropped object name blocking the action. In SQL Developer, displaying the old name makes it easier to decide what object you are dealing with, unless of course you repeatedly recreate and dropped the object.