Page 513
Today's lesson covers two topics that can't be ignored during the development of Oracle database applicationssecurity and tuning. Many of the tasks discussed in this lesson are typically performed by a dedicated database administrator. Even if you're never responsible for the security and tuning of an Oracle database, it's a good idea for you to understand some of the issues that are involved. This lesson begins with a discussion of users, roles, and the privileges granted to them.
During Day 3, "Logical Database Design," you went through the steps of adding a new user to an Oracle database. In addition to a user, Oracle also enables you to create a database rolea set of Oracle privileges that can correspond with a functional role in an organization. For example, you may want to allow a data
Page 514
entry clerk to insert and update rows in a particular table but prevent him or her from deleting any rows. To enforce this security scheme, you would create a database role named DATA_ENTRY, which would be granted these privileges.
On the other hand, the data entry manager should be able to insert, update, and delete rows in the tables. Therefore, you would create a separate role named DATA_ENTRY_MANAGER to implement this security policy. Once a database role is created, it can be granted to an individual user as needed. In addition, a role also can be granted to another role. Database roles not only help to ensure appropriate security, they also simplify database administration.
For an application environment with many tables, many users, and distinct functional roles, the implementation and maintenance of a security scheme is a major task. If the database administrator grants privileges directly to individual users, it's very easy for things to fall through the cracks in the long run. The DBA might forget to give some people a privilege they need to do their work or might give others a superfluous privilege. Also, if a change to the database application requires that the privileges of users also change, the DBA will have far more work to accomplish this without roles.
By defining a database role for each functional role that exists in the organization, you significantly reduce the task of managing users and their privileges. For instance, suppose you have 10 database usersthree belong to the marketing department and the other seven are in the engineering department. You would create two database roles, Marketer and Engineer, and grant the appropriate privileges to each role; the Marketer role needs access to one set of tables, whereas the Engineer role requires access to a different set. You would then grant the appropriate role to each user. If the database changesfor instance, the addition of a tableyou simply update the privileges of the role, not the user.
Every Oracle database has two pre-defined accounts that serve a special purposeSYS and SYSTEM. The SYS account owns the Oracle data dictionary tables and associated database objects. The SYSTEM account owns tables that are used by Oracle application development tools such as Oracle Forms or Reports. You should not create any database objects such as tables or indexes while connected as SYS or SYSTEM, except for Oracle-supplied SQL scripts that specifically indicate that they should be installed as SYS or SYSTEM.
When an Oracle database is installed, the five database roles are created:
Page 515
NOTE |
The historical reason for these pre-defined roles is that Oracle version 6 had only three privilegesconnect, resource, and DBA. Because Oracle re-defined these privileges as roles in Oracle7, SQL*Plus scripts developed for Oracle version 6 can be processed in Oracle8. These roles also simplify the assignment of system privileges to other roles and users. |
A role isn't useful unless it has been granted at least one privilege. Oracle privileges belong in two categories:
You can grant many different system privileges to a role or userin fact, Oracle has more than 80 system privileges. One system privilege that almost every Oracle user needs is CREATE SESSIONthe capability to establish an Oracle session.
To make these concepts more concrete, this section walks you through the process of creating a role and assigning it to an individual. You will also grant system privileges to the role. To do this, you'll need an account that has been granted the DBA role. Please realize that what you see on your screen may differ from the figures in this lesson because you may have users and roles already defined.
Page 516
Figure 19.1.
Viewing existing
database roles with
Security Manager.
Next, grant the CONNECT and RESOURCE roles to the new database role.