ORA-00942 Table or View Does Not Exist Oracle Error
Sometime when you compile an object or package or view in Oracle, or execute some PL/SQL statements on Oracle table, or when running an Oracle program or application, the following error my occurs:
ORA-00942: table or view does not exist
The cause or reason for ORA-00942 error message is because of Oracle tries to execute an SQL statement that references a table or view that either does not exist, or because of a synonym that is not allowed here was used, or because of you do not have access rights to the particular object. Other possible cause is that the table or view belongs to another schema and you didn’t reference the table by the schema name, or a view was referenced where a table is required.
Depending on what’s the cause of the problem, there are several resolutions or remedies to resolve this error. And due to several possible reasons that may cause the error, there are several actions or steps that you can take to identify where is the error and take the appropriate workaround or solution.
- Check existing user tables and views if they exists in Oracle by querying the data dictionary by executing the following SQL statement:
select *
from all_objects
where object_type in (’TABLE’,'VIEW’)
and object_name = ‘OBJECT_NAME‘;Replace OBJECT_NAME with the name of the table or view that you want to verify its existence.
If this error occurred because the table or view does not exist, take the following actions:
- Check and ensure that the spelling of the table (does not misspell) or view name is correct.
- Check and ensure that a view is not specified where a table is required.
- If no such table or view exists, create the table or view, or use another table or view.
- If the table or view exists, check and verify if the user has the necessary permissions and rights to read and access (i.e. select) from the table, as certain privileges may be required to access the table. In this case, you will need to have the owner of the table or view, or a Oracle DBA to grant the appropriate privileges, permissions or rights to this object.
Note that when selecting from a system view (such as v$session) the privilege or access rights to select from the view must be granted to the user directly and not via a role. This is the case if you can select from the view without problem but then get this error when trying to create a view on it.
- If the table or view exists but is in a different schema from the current schema where the SQL is executing (in other word, the table doesn’t own by you, but owned by other user), the ORA-00942 error will return too. Resolve this by explicitly reference the table or view by specifying the schema name, i.e. schema_name.table_name.
Related Articles
- ORA-02449 Oracle Drop Table Error
- Easily Duplicate, Copy or Backup Tables in Oracle, PostgreSQL, DB2 and SQLite with Create Table As SQL
- Oracle ORA-14074 Create or Add New Partition Fails Error
- Oracle EXP-00091 Error When Export Database
- Create, Add or Split Oracle Database Partition Fails with ORA-14080 Error
- Oracle Database Import Error 3113/3114
- Oracle PL/SQL ORA-00947 Not Enough Values Error
- ORA-25153 Temporary Tablespace is Empty Error in Oracle
- View and Retrieve Oracle Database Link Details
- IMP-00016 Required Character Set Conversion Not Supported Error when Import to Oracle Database









































