Home >Database >Mysql Tutorial >Simple comparison of primary key and unique key

Simple comparison of primary key and unique key

青灯夜游
青灯夜游Original
2019-01-29 14:32:498734browse

Both keys and unique keys are used to uniquely identify tuples and enforce uniqueness within a column or combination of columns. So how to distinguish them? The following article will give you a brief comparison between primary keys and unique keys, and introduce the differences between primary keys and unique keys. I hope it will be helpful to you.

Simple comparison of primary key and unique key

What is a primary key?

The primary key is a column in a table that uniquely identifies each tuple (row) in the table. The primary key enforces integrity constraints on the table. Only one primary key is allowed in the table. The primary key does not accept any duplicate values ​​and null values. Primary key values ​​in a table rarely change, so you need to be careful when choosing a primary key and choose a place that rarely changes. The primary key of one table can be referenced by the foreign key of another table. [Video tutorial recommendation: MySQL tutorial]

In order to better understand the primary key, we create a table named Student, which has attributes such as roll_number, name, batch, phone_number, citizen_id, etc.

Simple comparison of primary key and unique key

In the above example, the roll_number attribute can never have the same NULL value because a student registered in each university has a unique Roll_number, so two students cannot have the same Roll_number, and each row in the table can be uniquely identified by the student's roll_number attribute. So in this case we can make Roll_number attribute as primary key.

What is a unique key?

#Unique key constraints can uniquely identify a single tuple in a relationship or table. Unlike primary keys, a table can have multiple unique keys. A unique key constraint can only accept a null value for a column; a unique key constraint is also referenced by a foreign key from another table. It is used when one wants to enforce unique constraints on columns and column groups that are not primary keys.

To better understand the unique key, we use the Student table with the attributes Roll_number, Name, Batch, Phone_number and Citizen_ID; where the Roll_number attribute has been given to the primary key.

Simple comparison of primary key and unique key

In this example, a unique constraint can be assigned to Citizen_ID where each entry in the Citizen_ID column should be unique and not duplicates because Every citizen of a country must have his or her unique identification number. However, if the student migrates from another country, in this case he or she will not have a Citizen_ID and the entry may have a NULL value since a NULL is allowed in the unique constraint.

The main difference between primary key and unique key:

Simple comparison of primary key and unique key

1. When a When a property is declared as a primary key, it will not accept NULL values. On the other hand, when a property is declared as Unique, it can accept a NULL value.

2. There can be only one primary key in the table, but there can be multiple unique keys.

3. Automatically create a clustered index when defining the primary key. In contrast, Unique keys generate nonclustered indexes.

The above is the entire content of this article, I hope it will be helpful to everyone's study. For more exciting content, you can pay attention to the relevant tutorial columns of the PHP Chinese website! ! !

The above is the detailed content of Simple comparison of primary key and unique key. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Previous article:What’s new in MySQL 8.0Next article:What’s new in MySQL 8.0