The previous lesson of MySql Lessons series was about MySql Triggers and History Table and in this lesson we will learn about MySql Upsert Query.
data:image/s3,"s3://crabby-images/5af59/5af597fa25f536afa5ce2c75652983d17924c883" alt="MySql Upsert Query MySql Upsert Query"
MySql Upsert Statement is used to insert a new row in a table if a duplicate key does not exist and update an existing row if a duplicate key exists. To elaborate the functionality of MySql Upsert Statement consider the `user` table given in the image below:
data:image/s3,"s3://crabby-images/d4981/d49819751d83aee267fc5ab6c9707f33e918c64a" alt="Upsert User Table Upsert User Table"
The above `user` table contains (id, name, username, email, password) of a user. We want to insert a new row in the `user` table if the `username` and `email` does not exist in the table already and update the password of the user if the `username` or `email` already exists in the table. The first thing we need to do to achieve this is make the `username` and `email` fields UNIQUE. MySql queries to make the `username` and `email` fields UNIQUE are given below:
Now that we have UNIQUE `username` and `email` fields in our `user` table, we can write MySql Upsert query to achieve our goal.
The above query will update the password of user (John Malcom) as the `user` table already contains `username` john123 and `email` john123@gmail.com
data:image/s3,"s3://crabby-images/fe806/fe806a4c1fbcd39fbad00c408c58a80db90690a9" alt="Upsert Result Upsert Result"
Note that if the `username` and `email` fields are not UNIQUE for the `user` table, the above query will insert a new record and will not update the already existing data against user (John Malcom). Similarly the upsert query given below will insert a new record as the `username` john1234 and `email` john1234@gmail.com are UNIQUE in the table `user`.
Stay tuned for more lessons...
data:image/s3,"s3://crabby-images/5af59/5af597fa25f536afa5ce2c75652983d17924c883" alt="MySql Upsert Query MySql Upsert Query"
MySql Upsert Statement is used to insert a new row in a table if a duplicate key does not exist and update an existing row if a duplicate key exists. To elaborate the functionality of MySql Upsert Statement consider the `user` table given in the image below:
data:image/s3,"s3://crabby-images/d4981/d49819751d83aee267fc5ab6c9707f33e918c64a" alt="Upsert User Table Upsert User Table"
The above `user` table contains (id, name, username, email, password) of a user. We want to insert a new row in the `user` table if the `username` and `email` does not exist in the table already and update the password of the user if the `username` or `email` already exists in the table. The first thing we need to do to achieve this is make the `username` and `email` fields UNIQUE. MySql queries to make the `username` and `email` fields UNIQUE are given below:
ALTER TABLE `user` ADD UNIQUE(`username`);
ALTER TABLE `user` ADD UNIQUE(`email`);
Now that we have UNIQUE `username` and `email` fields in our `user` table, we can write MySql Upsert query to achieve our goal.
INSERT INTO `user` (`id`,`name`,`username`,`email`,`password`)
VALUES (4,'John Malcom','john123','john123@gmail.com','12345abc')
ON DUPLICATE KEY UPDATE `password` = 'newpass123';
The above query will update the password of user (John Malcom) as the `user` table already contains `username` john123 and `email` john123@gmail.com
data:image/s3,"s3://crabby-images/fe806/fe806a4c1fbcd39fbad00c408c58a80db90690a9" alt="Upsert Result Upsert Result"
Note that if the `username` and `email` fields are not UNIQUE for the `user` table, the above query will insert a new record and will not update the already existing data against user (John Malcom). Similarly the upsert query given below will insert a new record as the `username` john1234 and `email` john1234@gmail.com are UNIQUE in the table `user`.
INSERT INTO `user` (`id`,`name`,`username`,`email`,`password`)
VALUES (4,'John Malcom','john1234','john1234@gmail.com','12345abc')
ON DUPLICATE KEY UPDATE `password` = 'newpass123'
Stay tuned for more lessons...
No comments:
Post a Comment