From a0c367ee8c7f04cfdf1f9d4863447f24279a537f Mon Sep 17 00:00:00 2001 From: Narayan Bhat <48803246+Narayanbhat166@users.noreply.github.com> Date: Thu, 18 Jul 2024 15:10:57 +0530 Subject: [PATCH] refactor(merchant_account): change primary key for merchant account (#5327) Co-authored-by: hrithikesh026 --- crates/diesel_models/src/query/merchant_account.rs | 2 +- crates/diesel_models/src/schema.rs | 2 +- crates/diesel_models/src/schema_v2.rs | 2 +- .../down.sql | 5 +++++ .../up.sql | 13 +++++++++++++ 5 files changed, 21 insertions(+), 3 deletions(-) create mode 100644 migrations/2024-07-15-111327_change_primary_key_for_merchant_account/down.sql create mode 100644 migrations/2024-07-15-111327_change_primary_key_for_merchant_account/up.sql diff --git a/crates/diesel_models/src/query/merchant_account.rs b/crates/diesel_models/src/query/merchant_account.rs index dd2f284305be..66526e11cb2d 100644 --- a/crates/diesel_models/src/query/merchant_account.rs +++ b/crates/diesel_models/src/query/merchant_account.rs @@ -22,7 +22,7 @@ impl MerchantAccount { ) -> StorageResult { match generics::generic_update_by_id::<::Table, _, _, _>( conn, - self.id, + self.merchant_id.clone(), merchant_account, ) .await diff --git a/crates/diesel_models/src/schema.rs b/crates/diesel_models/src/schema.rs index 68689e864407..b27d1e9611fd 100644 --- a/crates/diesel_models/src/schema.rs +++ b/crates/diesel_models/src/schema.rs @@ -633,7 +633,7 @@ diesel::table! { use diesel::sql_types::*; use crate::enums::diesel_exports::*; - merchant_account (id) { + merchant_account (merchant_id) { id -> Int4, #[max_length = 64] merchant_id -> Varchar, diff --git a/crates/diesel_models/src/schema_v2.rs b/crates/diesel_models/src/schema_v2.rs index e353cbd5666b..3fdbf45025fc 100644 --- a/crates/diesel_models/src/schema_v2.rs +++ b/crates/diesel_models/src/schema_v2.rs @@ -633,7 +633,7 @@ diesel::table! { use diesel::sql_types::*; use crate::enums::diesel_exports::*; - merchant_account (id) { + merchant_account (merchant_id) { id -> Int4, #[max_length = 64] merchant_id -> Varchar, diff --git a/migrations/2024-07-15-111327_change_primary_key_for_merchant_account/down.sql b/migrations/2024-07-15-111327_change_primary_key_for_merchant_account/down.sql new file mode 100644 index 000000000000..2f169d80194d --- /dev/null +++ b/migrations/2024-07-15-111327_change_primary_key_for_merchant_account/down.sql @@ -0,0 +1,5 @@ +-- This file should undo anything in `up.sql` +ALTER TABLE merchant_account DROP CONSTRAINT merchant_account_pkey; + +ALTER TABLE merchant_account +ADD PRIMARY KEY (id); diff --git a/migrations/2024-07-15-111327_change_primary_key_for_merchant_account/up.sql b/migrations/2024-07-15-111327_change_primary_key_for_merchant_account/up.sql new file mode 100644 index 000000000000..5db5076c07ae --- /dev/null +++ b/migrations/2024-07-15-111327_change_primary_key_for_merchant_account/up.sql @@ -0,0 +1,13 @@ +-- Your SQL goes here +-- The below query will lock the merchant account table +-- Running this query is not necessary on higher environments +-- as the application will work fine without these queries being run +-- This query is necessary for the application to not use id in update of merchant_account +-- This query should be run after the new version of application is deployed +ALTER TABLE merchant_account DROP CONSTRAINT merchant_account_pkey; + +-- Use the `merchant_id` column as primary key +-- This is already a unique, not null column +-- So this query should not fail for not null or duplicate values reasons +ALTER TABLE merchant_account +ADD PRIMARY KEY (merchant_id);