Preamble
Foreign Keys is a way to ensure data integrity in your Oracle database. A Foreign Keys means that values in one table must also appear in another table.
The reference table is called the parent table, and the table with the foreign key is called the child table. The foreign key in the child table is usually referred to as the primary key in the parent table.
The foreign key can be defined either in the CREATE TABLE statement or in the ALTER TABLE statement.
Using CREATE TABLE
Syntax for creating an external key using the CREATE TABLE operator:
CREATE TABLE table_name
(
column1 datatype null/not null,
column2 datatype null/not null,
…
CONSTRAINT fk_column
FOREIGN KEY (column1, column2, ... column_n)
REFERENCES parent_table (column1, column2, ... column_n)
);
Example
CREATE TABLE supplier
( supplier_id numeric(10) not null,
supplier_name varchar2(50) not null,
contact_name varchar2(50),
CONSTRAINT supplier_pk PRIMARY KEY (supplier_id)
);
CREATE TABLE products
( product_id numeric(10) not null,
supplier_id numeric(10) not null,
CONSTRAINT fk_supplier
FOREIGN KEY (supplier_id)
REFERENCES supplier(supplier_id)
);
In this example we created the primary key table of the supplier called supplier_pk. It consists of only one field – supplier_id. Then we created a foreign key named fk_supplier in the products table that refers to the supplier table based on the supplier_id field.
We could also create a foreign key with more than one field, as in the example below:
CREATE TABLE supplier
( supplier_id numeric(10) not null,
supplier_name varchar2(50) not null,
contact_name varchar2(50),
CONSTRAINT supplier_pk PRIMARY KEY (supplier_id, supplier_name)
);
CREATE TABLE products
( product_id numeric(10) not null,
supplier_id numeric(10) not null,
supplier_name varchar2(50) not null,
CONSTRAINT fk_supplier_comp
FOREIGN KEY (supplier_id, supplier_name)
REFERENCES supplier(supplier_id, supplier_name)
);
In this example, our foreign key called fk_foreign_comp refers to the supplier table based on two fields – supplier_id and supplier_name.
Using ALTER TABLE
Syntax for creating an external key in ALTER TABLE operator:
ALTER TABLE products
ADD CONSTRAINT fk_supplier
FOREIGN KEY (supplier_id)
REFERENCES supplier(supplier_id) ;
In this example, we created a foreign key named fk_supplier that refers to the supplier table based on the supplier_id field.
Example
Another example of creating a foreign key with more than one field in the example below:
ALTER TABLE products
ADD CONSTRAINT fk_supplier
FOREIGN KEY (supplier_id, supplier_name)
REFERENCES supplier(supplier_id, supplier_name) ;
Oracle SQL Tutorial: How to Create Foreign Keys
About Enteros
Enteros offers a patented database performance management SaaS platform. It proactively identifies root causes of complex business-impacting database scalability and performance issues across a growing number of clouds, RDBMS, NoSQL, and machine learning database platforms.
The views expressed on this blog are those of the author and do not necessarily reflect the opinions of Enteros Inc. This blog may contain links to the content of third-party sites. By providing such links, Enteros Inc. does not adopt, guarantee, approve, or endorse the information, views, or products available on such sites.
Are you interested in writing for Enteros’ Blog? Please send us a pitch!
RELATED POSTS
How to Scale Healthcare Sector Growth with Enteros AIOps Platform, Database Management, and Performance Intelligence
- 28 April 2026
- Database Performance Management
Introduction The healthcare sector is undergoing a massive digital transformation driven by electronic health records (EHRs), telemedicine, AI-powered diagnostics, and data-driven patient care. Healthcare providers, payers, and life sciences organizations are under increasing pressure to deliver high-quality, personalized care while managing operational costs and ensuring regulatory compliance. At the same time, the volume of healthcare … Continue reading “How to Scale Healthcare Sector Growth with Enteros AIOps Platform, Database Management, and Performance Intelligence”
Optimizing Digital Banking Systems with Intelligent Database Analytics
Introduction The banking industry is undergoing a rapid digital transformation. Mobile banking apps, online payment platforms, AI-driven fraud detection, open banking APIs, and real-time financial services have become essential components of modern financial ecosystems. Customers expect instant transactions, seamless digital experiences, and uninterrupted service availability. Behind every digital banking transaction lies a complex and mission-critical … Continue reading “Optimizing Digital Banking Systems with Intelligent Database Analytics”
How to Improve Financial Sector Efficiency with Enteros Database Software, Cloud FinOps, and RevOps Alignment
Introduction The financial sector is undergoing a rapid transformation driven by digital banking, real-time transactions, fintech disruption, and evolving customer expectations. Financial institutions are expected to deliver seamless, secure, and highly personalized experiences—while maintaining strict compliance and controlling operational costs. However, achieving efficiency in such a complex environment is not easy. Banks and financial organizations … Continue reading “How to Improve Financial Sector Efficiency with Enteros Database Software, Cloud FinOps, and RevOps Alignment”
Scaling FinTech Platforms with AI-Driven Database Performance Monitoring
The FinTech industry has revolutionized financial services by enabling real-time digital payments, automated investment platforms, digital banking apps, and AI-driven fraud detection systems. As financial services become increasingly digital, the infrastructure supporting these services must scale rapidly to handle growing transaction volumes, complex analytics, and regulatory requirements. At the core of every FinTech platform lies … Continue reading “Scaling FinTech Platforms with AI-Driven Database Performance Monitoring”