Skip to main content

Difference Between Primary key, Unique key And Foreign Key.

The difference between Primary key, Unique key and Foreign Key is the most common interview question for .NET as well as SQL developers.

 The PRIMARY Key and UNIQUE Key constraints, both are similar and enforce uniqueness of the column on which they are defined.


Primary Key

  • A primary key cannot have a NULL value.
  • Each table can have only one primary key.
  • By default, Primary key is clustered index, and the data in the database table is physically organized in the sequence of the clustered index.
  • A primary key can be related to other tables as a Foreign Key.
  • We can generate ID automatically with the help of Auto Increment field. Primary key supports Auto Increment value.
  • We can define a Primary key constraint on temporary table and table variable. 
  • We can't delete a primary key value from the parent table which is used as a foreign key in the child table. To delete we first need to delete that primary key value from the child table.


Unique Key

  • Unique Constraint may have a NULL value.
  • Each table can have more than one Unique Constraint.
  • By default, Unique key is a unique non-clustered index.
  • Unique Constraint cannot be related to another table's as a Foreign Key.


Foreign Key


  • A foreign key is a field in the table that is Primary key in another table.
  • A foreign key can accept multiple null values.
  • A foreign key does not automatically create an index, clustered or non-clustered. You can manually create an index on the foreign key.
  • We can have more than one foreign key in a table.
  • Foreign keys do not automatically create an index, clustered or non-clustered. You must manually create an index on foreign keys.
  • There are actual advantages to having a foreign key be supported with a clustered index, but you get only one per table. What's the advantage? If you are selecting the parent plus all child records, you want the child records next to each other. This is easy to accomplish using a clustered index.
  • Having a null foreign key is usually a bad idea instead of NULL  referred to as "orphan record".
  • We can’t define a foreign key constraint on a temporary table or table variable.
  • We can delete the foreign key value from the child table even though that refers to the primary key of the parent table.

Comments

Popular posts from this blog

How To See Logs Of Dropped Tables From The Database in MS SQL.

Here, I will explain you how you can see logs of users. Step 1 : First, create a new database with name "test". Step 2 : Create a new table. Step 3 : Now, go and drop the table by running the following command. Step 4 : Now, select your database under Object Explorer and go to Reports >> Standard Reports >> Schema Changes History. Step 5 : You will then see the schema change history. The report will show you who has dropped this table. Finally, you can locate the user activity with the help of log.

How To Deploy .net Core Application On Linux

Here, I can explain steps to deploy .net core application on linux machine. Step 1 - Publish your .net Core application: First, create a .net core application on VS; you can make an MVC project or Web API project and if you already have an existing project, then open it. Right Click on your project Click on publish Now create a new publish profile, and browse the folder where you want to publish your project dll Click on publish so it will create your dll in the folder Step 2 - Install required .net Module on Linux: Now we have our web application dll and now we need to host it on the Linux environment. First, we need to understand how the deployment works in Linux. .Net applications run on Kestrel servers and we run Apache or Nginx server in Linux environments, which acts as a proxy server and handles the traffic from outside the machine and redirects it to the Kestrel server so we will have Apache or Nginx server as the middle layer. In this article, we will use Apache as a proxy ser...

How to write Unit Tests in .net

Unit tests are automated tests that verify the behavior code like methods and functions. Writing unit tests is crucial to clean coding, as they help ensure your code works as intended and catches bugs early in the development process. I can share some tips for writing effective unit tests: Write tests for all public methods Every public method in your code should have a corresponding unit test. This helps ensure that your code behaves correctly and catches any unexpected behavior early. public class Calculator { public int Add(int a, int b) { return a + b; } } [TestClass] public class CalculatorTests { [TestMethod] public void Add_ShouldReturnCorrectSum() { // Arrange Calculator calculator = new Calculator(); int a = 1; int b = 2; // Act int result = calculator.Add(a, b); // Assert Assert.AreEqual(3, result); } } Test boundary conditions  Make sure to test boundary conditions, such a...