Previous | Table of Contents | Next |
A synonym is merely a way of assigning an alias with which users can reference a table or view. This makes it easier to access tables that you do not own. When you own a table, you use its name in your SQL queries. When you want to access a table owned by another user, you need to specify both the owner of the table and the table name (in the owner.table_name format). When you reference tables located in a different database using SQL*Net, the format can be rather complicated. Synonyms simplify this access because you can create a simple synonym that contains the details of a complex reference string (see Figure 12.4).
Figure 12.4. Synonyms.
There are two types of synonymsprivate and public. Private synonyms are those that you create for your own personal use. Public synonyms are those that you create that any user in the database can use. Obviously, from a DBA point of view, you usually want to restrict the number of users who can create public synonyms. You usually want to be even more restrictive with the number of users who can drop public synonyms. There are three primary system privilege sets with which the DBA is concerned related to synonyms:
Finally, it is interesting to consider what you get when you issue a query that goes against an object name that states the following: You own a table with that name, you have a private synonym with that name, and there is also a public synonym with that name. I had to try this out once to figure out what Oracle would do. After I got the results of this experiment, it made sense to me. So, here is the order in which Oracle accesses objects that have the same name in the database:
As mentioned earlier in this chapter, stored procedures are a way of storing software within the Oracle database. Basically, anything that you can develop in a PL/SQL script can be saved as an Oracle stored procedure. A collection of stored procedures can be saved as a package in the database. Stored procedures can present several interesting advantages for Oracle developers:
There are two problems with stored procedures. First, all stored procedures are stored in the system tablespace, usually thought of as sacred ground for use only by the DBA. However, the Oracle developers do not agree. Therefore, you have to let non-DBA software be placed in your most special tablespace. The other problem is that the software has to be written in PL/SQL. PL/SQL gets the job done; however, it is difficult to debug and does not support normal input/output operations. Stored procedures are very useful if you are willing to live with these two annoyances.
Stored procedures require special system privileges for creation (as you would expect with something that can be this powerful and that has to be placed in the system tablespace). Without getting into the details that are of concern to software developers, you need to grant CREATE PACKAGE, CREATE PROCEDURE, DROP PACKAGE, and/or DROP PROCEDURE to users who will be developing stored procedures in your system. Chapter 17 will cover stored software in greater detail.
Recall that a cluster is a group of tables that you want to store together because they contain a number of common columns and are often joined together in queries. I have never used clusters. They were common in Oracle6, but the basic data storage algorithm for Oracle8 is a lot smarter that in Oracle6, and it will arrange tables in an efficient manner without creating clusters. One nice feature about clusters is that users have no idea whether the tables that they are accessing are in a cluster. Only the developers and DBAs know which tables are in clusters.
The basic Oracle references provide a good description of the details of setting up clusters. They also go into more detail about when you might use them. However, for purposes of this book, it is enough for you to know what they are. If you have performance problems with queries that always join together a few tables that have common columns, you may consider experimenting with clusters. Otherwise, you may never see a cluster. (Although many of the Oracle internal tables are supposed to use clusters, you may never deal with these tables directly because that is what you purchased the RDBMS software to do for you.)
Previous | Table of Contents | Next |