xxxxxxxxxx
A primary key allows each record in a table to be uniquely identified. There can only be one
primary key per table, and you can assign this constraint to any single or combination of columns.
However, this means each value within this column(s) must be unique.
Typically in a table, the primary key is an ID column, and is usually paired with the AUTO_
INCREMENT keyword. This means the value increases automatically as new records are created.
CREATE TABLE users (
id int NOT NULL AUTO_INCREMENT,
first_name varchar(255),
last_name varchar(255) NOT NULL,
address varchar(255),
email varchar(255),
PRIMARY KEY (id)
);
xxxxxxxxxx
# During table creation
# MySQL and SQL Server
CREATE TABLE table_name (
id INT PRIMARY KEY NOT NULL [AUTO_INCREMENT],
col2 VARCHAR(50),
col3 DECIMAL(6,2) CHECK(col3>0),
FOREIGN KEY (other_id) REFERENCES Other_Table(id) [ON DELETE CASCADE]
);
# PostgreSQL
CREATE TABLE table_name (
id SERIAL PRIMARY KEY,
col2 VARCHAR(50),
col3 DECIMAL(6,2) CHECK(col3>0),
FOREIGN KEY (other_id) REFERENCES Other_Table(id) [ON UPDATE NO ACTION]
);
# If table already exists
# Adding primary key in MySQL, PostgreSQL and SQL Server
ALTER TABLE table_name
ADD CONSTRAINT table_pkey
PRIMARY KEY (col1,col2);
# Adding foreign key in MySQL, PostgreSQL and SQL Server
ALTER TABLE table_name
ADD CONSTRAINT table_fkey
FOREIGN KEY (col1) REFERENCES Other_Table(id);
xxxxxxxxxx
CREATE TABLE Colleges (
college_id INT,
college_code VARCHAR(20) NOT NULL,
college_name VARCHAR(50),
CONSTRAINT CollegePK PRIMARY KEY (college_id)
);
xxxxxxxxxx
/* A primary key allows each record in a table to be uniquely identified. There can only be one
primary key per table, and you can assign this constraint to any single or combination of columns.
However, this means each value within this column(s) must be unique.
Typically in a table, the primary key is an ID column, and is usually paired with the AUTO_
INCREMENT keyword. This means the value increases automatically as new records are created. */
CREATE TABLE stats(id INT NOT NULL PRIMARY KEY, name TEXT)
xxxxxxxxxx
CREATE TABLE student
(
Roll integer (15) NOT NULL PRIMARY KEY,
Name varchar (255),
Class varchar (255),
Contact No varchar (255),
);
xxxxxxxxxx
A primary key is a field in a table which uniquely identifies each row/record in a database table. Primary keys must contain unique values. A primary key column cannot have NULL values.
A table can have only one primary key, which may consist of single or multiple fields. When multiple fields are used as a primary key, they are called a composite key.
If a table has a primary key defined on any field(s), then you cannot have two records having the same value of that field(s).
xxxxxxxxxx
-- NOTE: this is for SQL-Oracle specifically
-- example:
SELECT cols.table_name, cols.column_name, cols.position, cons.status, cons.owner
FROM all_constraints cons, all_cons_columns cols
WHERE cols.table_name = 'CUSTOMERS'
AND cons.constraint_type = 'P'
AND cons.constraint_name = cols.constraint_name
AND cons.owner = cols.owner;
-- syntax:
SELECT cols.table_name, cols.column_name, cols.position, cons.status, cons.owner
FROM all_constraints cons, all_cons_columns cols
WHERE cols.table_name = '<table-name>' -- Replace <table-name> with your table-name
AND cons.constraint_type = 'P'
AND cons.constraint_name = cols.constraint_name
AND cons.owner = cols.owner;
xxxxxxxxxx
CREATE TABLE Colleges (
college_id INT PRIMARY KEY,
college_code VARCHAR(20) NOT NULL,
college_name VARCHAR(50)
);
xxxxxxxxxx
Primary Key :
It is unique column in every table in a database
It can ONLY accept;
- nonduplicate values
- cannot be NULL