{"id":25115,"date":"2026-06-09T07:36:22","date_gmt":"2026-06-09T07:36:22","guid":{"rendered":"https:\/\/umang.pk\/2026\/06\/09\/liquibase-%d8%a7%d9%88%d8%b1-spring-boot-%da%a9%db%92-%d8%b3%d8%a7%d8%aa%da%be-%da%88%db%8c%d9%b9%d8%a7-%d8%a8%db%8c%d8%b3-%d9%88%d8%b1%da%98%d9%86-%da%a9%d9%86%d9%b9%d8%b1%d9%88%d9%84\/"},"modified":"2026-06-09T07:36:23","modified_gmt":"2026-06-09T07:36:23","slug":"liquibase-%d8%a7%d9%88%d8%b1-spring-boot-%da%a9%db%92-%d8%b3%d8%a7%d8%aa%da%be-%da%88%db%8c%d9%b9%d8%a7-%d8%a8%db%8c%d8%b3-%d9%88%d8%b1%da%98%d9%86-%da%a9%d9%86%d9%b9%d8%b1%d9%88%d9%84","status":"publish","type":"post","link":"https:\/\/umang.pk\/ur\/2026\/06\/09\/liquibase-%d8%a7%d9%88%d8%b1-spring-boot-%da%a9%db%92-%d8%b3%d8%a7%d8%aa%da%be-%da%88%db%8c%d9%b9%d8%a7-%d8%a8%db%8c%d8%b3-%d9%88%d8%b1%da%98%d9%86-%da%a9%d9%86%d9%b9%d8%b1%d9%88%d9%84\/","title":{"rendered":"Liquibase \u0627\u0648\u0631 Spring Boot \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0648\u0631\u0698\u0646 \u06a9\u0646\u0679\u0631\u0648\u0644"},"content":{"rendered":"\n<div id=\"\">\n<p>\u062f\u0631\u062c \u0630\u06cc\u0644 \u0645\u0627\u0646\u0648\u0633 \u0645\u0646\u0638\u0631 \u0646\u0627\u0645\u06d2 \u067e\u0631 \u063a\u0648\u0631 \u06a9\u0631\u06cc\u06ba: \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0646\u0626\u06cc \u062e\u0635\u0648\u0635\u06cc\u062a \u067e\u0631 \u06a9\u0627\u0645 \u06a9\u0631 \u0631\u06c1\u0627 \u06c1\u0648\u06ba \u062c\u0633 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0646\u0626\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0627\u0644\u0645 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4 \u0627\u067e\u0646\u06d2 \u0645\u0642\u0627\u0645\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0644\u0627\u0626\u0646\u0679 \u06a9\u0648 \u06a9\u06be\u0648\u0644\u06cc\u06ba \u0627\u0648\u0631 <code>ALTER TABLE<\/code> \u0628\u06cc\u0627\u0646\u0627\u062a \u0644\u06a9\u06be\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0646 \u067e\u0631 \u0639\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u06d4 \u06a9\u0648\u0688 \u0628\u0627\u0644\u06a9\u0644 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0622\u067e \u0627\u067e\u0646\u06d2 \u062c\u0627\u0648\u0627 \u06a9\u0648\u0688 \u06a9\u0627 \u0627\u0631\u062a\u06a9\u0627\u0628 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u0627\u0633\u06d2 \u0630\u062e\u06cc\u0631\u06d2 \u06a9\u06cc \u0637\u0631\u0641 \u062f\u06be\u06a9\u06cc\u0644\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u0627\u0648\u0631 \u067e\u06be\u0631 \u06a9\u0686\u06be \u06a9\u0627\u0641\u06cc \u0644\u06cc\u0646\u06d2 \u062c\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u0686\u0646\u062f \u06af\u06be\u0646\u0679\u0648\u06ba \u0628\u0639\u062f\u060c \u062c\u0628 \u0679\u06cc\u0645 \u06a9\u0627 \u0627\u06cc\u06a9 \u0631\u06a9\u0646 \u0628\u0631\u0627\u0646\u0686 \u06a9\u0648 \u06a9\u06be\u06cc\u0646\u0686\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0686\u0644\u0627\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0633\u0628 \u06a9\u0686\u06be \u06a9\u0631\u06cc\u0634 \u06c1\u0648 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>&quot;\u06c1\u06cc\u0644\u0648\u060c&#8221; \u0648\u06c1 \u067e\u0648\u0631\u06d2 \u06a9\u0645\u0631\u06d2 \u0633\u06d2 \u067e\u0648\u0686\u06be\u062a\u06d2 \u06c1\u06cc\u06ba (\u06cc\u0627 \u0633\u0644\u06cc\u06a9 \u0686\u06cc\u0646\u0644 \u0645\u06cc\u06ba)\u060c &quot;\u06a9\u06cc\u0627 \u0622\u067e \u0646\u06d2 \u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u062a\u0628\u062f\u06cc\u0644\u06cc\u0627\u06ba \u06a9\u06cc \u06c1\u06cc\u06ba\u061f&#8221;<\/p>\n<p>\u0622\u067e \u06a9\u0648 \u0641\u0648\u0631\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0627\u062d\u0633\u0627\u0633 \u06c1\u0648 \u06af\u06cc\u0627 \u06a9\u06c1 \u0622\u067e \u0627\u067e\u0646\u06cc SQL \u0627\u0633\u06a9\u0631\u067e\u0679 \u06a9\u0627 \u0627\u0634\u062a\u0631\u0627\u06a9 \u06a9\u0631\u0646\u0627 \u0628\u06be\u0648\u0644 \u06af\u0626\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0628\u0633 \u0627\u0633\u06d2 \u0686\u06cc\u0679 \u0645\u06cc\u06ba \u0686\u0633\u067e\u0627\u06ba \u06a9\u0631\u06cc\u06ba\u06d4 \u0648\u06c1 \u0627\u0633\u06d2 \u0686\u0644\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0633\u0628 \u06a9\u0686\u06be \u06a9\u0627\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u067e\u06be\u0631\u060c \u0627\u06cc\u06a9 \u06c1\u0641\u062a\u06c1 \u0628\u0639\u062f\u060c \u0627\u0633\u0679\u06cc\u062c\u0646\u06af \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u0628\u0627\u0644\u06a9\u0644 \u0627\u0633\u06cc \u0648\u062c\u06c1 \u0633\u06d2 \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648\u062c\u0627\u062a\u06cc \u06c1\u06d2\u06d4 \u062c\u0628 \u062a\u06a9 \u06cc\u06c1 \u06a9\u0648\u0688 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u062a\u06a9 \u067e\u06c1\u0646\u0686 \u062c\u0627\u0626\u06d2 \u06af\u0627\u060c \u06c1\u0631 \u06a9\u0648\u0626\u06cc \u067e\u0631\u06cc\u0634\u0627\u0646 \u06a9\u0646 \u0633\u0648\u0627\u0644 \u067e\u0648\u0686\u06be \u0631\u06c1\u0627 \u06c1\u0648 \u06af\u0627\u060c &quot;\u0645\u062c\u06be\u06d2 \u06a9\u0648\u0646 \u0633\u06cc \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u0627\u0633\u06a9\u0631\u067e\u0679 \u0686\u0644\u0627\u0646\u06cc \u0686\u0627\u06c1\u06cc\u06d2\u061f&#8221;<\/p>\n<p>\u0627\u0633 \u0635\u0648\u0631\u062a\u062d\u0627\u0644 \u06a9\u0648 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u0688\u0631\u0641\u0679 \u06a9\u06c1\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4 \u06cc\u06c1 \u062a\u0628 \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u062c\u0628 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062d\u0627\u0644\u062a \u0645\u062a\u0639\u062f\u062f \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u0645\u062e\u062a\u0644\u0641 \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u06d4 \u0627\u0633\u0679\u06cc\u062c\u0646\u06af \u06a9\u0627 \u0627\u06cc\u06a9 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u06a9\u0627 \u062f\u0648\u0633\u0631\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u06c1\u0631 \u0688\u0648\u06cc\u0644\u067e\u0631 \u06a9\u06cc \u0645\u0642\u0627\u0645\u06cc \u0645\u0634\u06cc\u0646 \u0627\u0633 \u06a9\u06cc \u0627\u067e\u0646\u06cc \u0627\u0633\u0646\u0648 \u0641\u0644\u06cc\u06a9 \u06c1\u0648\u062a\u06cc \u06c1\u06d2 \u062c\u0633 \u06a9\u06cc \u062c\u0627\u0646\u0686 \u0646\u06c1\u06cc\u06ba \u06a9\u06cc \u06af\u0626\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u062a\u0631\u0645\u06cc\u0645 \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>\u0688\u06cc\u0679\u0627\u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0645\u0646\u0638\u0645 \u06a9\u0631\u0646\u0627 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u06a9\u06d2 \u0645\u0633\u0627\u0626\u0644 \u0627\u0648\u0631 \u0679\u06cc\u0645 \u06a9\u06d2 \u062a\u0639\u0627\u0648\u0646 \u06a9\u06d2 \u0645\u0633\u0627\u0626\u0644 \u06a9\u0648 \u062d\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u0627 \u0627\u06cc\u06a9 \u0637\u0631\u06cc\u0642\u06c1 \u06c1\u06d2\u06d4 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648\u0688 \u0628\u06d2 \u0648\u0637\u0646 \u0627\u0648\u0631 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u0646\u0627 \u0622\u0633\u0627\u0646 \u06c1\u06d2\u06d4 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u0679\u0648\u0631 \u06a9\u06cc \u062d\u0627\u0644\u062a\u06d4 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u0646\u0627\u0642\u0627\u0628\u0644 \u06cc\u0642\u06cc\u0646 \u062d\u062f \u062a\u06a9 \u0627\u0686\u06be\u06cc \u06cc\u0627\u062f\u06cc\u06ba \u06c1\u0648\u062a\u06cc \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u0628\u0631\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0648 \u0634\u0627\u0630 \u0648 \u0646\u0627\u062f\u0631 \u06c1\u06cc \u0628\u06be\u0648\u0644 \u062c\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>Liquibase \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u067e\u0631 \u0648\u0631\u0698\u0646 \u06a9\u0646\u0679\u0631\u0648\u0644 \u06a9\u06d2 \u0627\u0635\u0648\u0644\u0648\u06ba \u06a9\u0648 \u0644\u0627\u06af\u0648 \u06a9\u0631\u06a9\u06d2 \u0627\u0633 \u0645\u0633\u0626\u0644\u06d2 \u06a9\u0648 \u062d\u0644 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u0641\u0627\u0626\u0644 \u062f\u06cc\u0646\u06d2 \u0627\u0648\u0631 \u0644\u0648\u06af\u0648\u06ba \u0633\u06d2 \u0627\u0633\u06d2 \u0686\u0644\u0627\u0646\u06d2 \u06a9\u06cc \u062a\u0648\u0642\u0639 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2\u060c \u0622\u067e \u06a9\u0648\u0688 \u0645\u06cc\u06ba \u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u06cc \u0648\u0636\u0627\u062d\u062a \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u06cc\u06c1 \u062a\u0628\u062f\u06cc\u0644\u06cc\u0627\u06ba \u0622\u067e \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u06d2 \u0630\u062e\u06cc\u0631\u06d2 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0633\u0641\u0631 \u06a9\u0631\u062a\u06cc \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0686\u0644\u062a\u06cc \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u0630\u06cc\u0644 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0627\u0639\u0644\u06cc\u0670 \u0633\u0637\u062d\u06cc \u062c\u0627\u0626\u0632\u06c1 \u06c1\u06d2 \u06a9\u06c1 \u06cc\u06c1 \u0641\u0646 \u062a\u0639\u0645\u06cc\u0631 \u06a9\u06cc\u0633\u06d2 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u06cc\u06a9 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc \u06a9\u06d2 \u0633\u0641\u0631 \u06a9\u06d2 \u0628\u0627\u0631\u06d2 \u0645\u06cc\u06ba \u0633\u0648\u0686\u0626\u06d2\u06d4 \u0688\u0648\u06cc\u0644\u067e\u0631 \u062c\u0627\u0648\u0627 \u06a9\u0648\u0688 \u06a9\u06d2 \u0633\u0627\u062a\u06be Git \u0645\u06cc\u06ba \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0627 \u0627\u0631\u062a\u06a9\u0627\u0628 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u062c\u0628 \u0622\u067e \u06a9\u06cc CI\/CD \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 (\u06cc\u0627 \u0679\u06cc\u0645 \u0645\u0645\u0628\u0631) \u0627\u0633 \u06a9\u0648\u0688 \u06a9\u0648 \u06a9\u06be\u06cc\u0646\u0686\u062a\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u06a9\u0627 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0634\u0631\u0648\u0639 \u06c1\u0648 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4 \u062a\u0627\u06c1\u0645\u060c \u0627\u06cc\u067e \u06a9\u06d2 \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u0628\u0648\u0679 \u06c1\u0648\u0646\u06d2 \u0627\u0648\u0631 \u0648\u06cc\u0628 \u0679\u0631\u06cc\u0641\u06a9 \u06a9\u0648 \u0642\u0628\u0648\u0644 \u06a9\u0631\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2\u060c Liquibase \u0627\u0633 \u0639\u0645\u0644 \u06a9\u0648 \u0631\u0648\u06a9\u062a\u0627 \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0627\u06cc\u06a9 \u06af\u06cc\u0679 \u06a9\u06cc\u067e\u0631 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0633\u06d2 \u0645\u0646\u0633\u0644\u06a9 \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u06a9\u0633\u06cc \u0628\u06be\u06cc \u0645\u0637\u0644\u0648\u0628\u06c1 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u0644\u0627\u06af\u0648 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0622\u067e \u06a9\u0648 \u06cc\u06c1 \u06cc\u0642\u06cc\u0646\u06cc \u0628\u0646\u0627\u0646\u06d2 \u06a9\u06cc \u0627\u062c\u0627\u0632\u062a \u062f\u06cc\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0622\u067e \u06a9\u0627 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0628\u0627\u0644\u06a9\u0644 \u0627\u0633\u06cc \u0637\u0631\u062d \u0633\u06d2 \u0645\u06cc\u0644 \u06a9\u06be\u0627\u062a\u0627 \u06c1\u06d2 \u062c\u0633 \u06a9\u06cc \u0622\u067e \u06a9\u0648\u0688 \u06a9\u06cc \u062a\u0648\u0642\u0639 \u06c1\u06d2 \u0627\u0633 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u06a9\u06c1 \u06a9\u0648\u0626\u06cc \u0627\u06cc\u06a9 \u0635\u0627\u0631\u0641 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0631\u06d2\u06d4<\/p>\n<h2 id=\"heading-why-database-version-control-matters\">\u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0648\u0631\u0698\u0646\u0646\u06af \u06a9\u06cc\u0648\u06ba \u0636\u0631\u0648\u0631\u06cc \u06c1\u06d2\u06d4<\/h2>\n<p>\u0627\u06af\u0631 \u0622\u067e \u0646\u06d2 \u0679\u06cc\u0645 \u067e\u0631 \u0645\u0628\u0646\u06cc \u0627\u06cc\u067e\u0644\u06cc \u06a9\u06cc\u0634\u0646\u0632 \u067e\u0631 \u06a9\u0627\u0645 \u06a9\u0631\u0646\u06d2 \u0645\u06cc\u06ba \u06a9\u0648\u0626\u06cc \u0648\u0642\u062a \u0635\u0631\u0641 \u06a9\u06cc\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u0646\u06d2 \u0641\u0648\u0644\u0688\u0631 \u06a9\u06d2 \u0688\u06be\u0627\u0646\u0686\u06d2 \u06a9\u0648 \u0627\u0633 \u0637\u0631\u062d \u062f\u06cc\u06a9\u06be\u0627 \u06c1\u0648\u06af\u0627:<\/p>\n<pre><code class=\"language-plaintext\">project-sql-scripts\/\n\u251c\u2500\u2500 create_employee_table.sql\n\u251c\u2500\u2500 create_employee_table_final.sql\n\u251c\u2500\u2500 create_employee_table_final_v2.sql\n\u251c\u2500\u2500 add_email_column.sql\n\u251c\u2500\u2500 latest.sql\n\u2514\u2500\u2500 definitely_latest_use_this_one.sql\n<\/code><\/pre>\n<p>\u062c\u0645\u0644\u06c1 &quot;\u0627\u0633 \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u0627\u0633\u06a9\u0631\u067e\u0679 \u06a9\u0648 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0686\u0644\u0627\u0626\u06cc\u06ba&#8221; \u0646\u06d2 \u0628\u06c1\u062a \u0633\u06d2 \u06cc\u0627\u062f\u06af\u0627\u0631 \u0648\u0627\u0642\u0639\u0627\u062a \u06a9\u0648 \u062c\u0646\u0645 \u062f\u06cc\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u062f\u0633\u062a\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u067e \u0688\u06cc\u0679\u0633 \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u067e\u06cc\u0645\u0627\u0646\u06d2 \u067e\u0631 \u0646\u0627\u06a9\u0627\u0645\u06cc \u06a9\u06cc \u0636\u0645\u0627\u0646\u062a \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06cc\u06a9 \u0646\u0626\u06d2 \u0688\u0648\u06cc\u0644\u067e\u0631 \u06a9\u0648 \u0622\u0646 \u0628\u0648\u0631\u0688 \u06a9\u0631\u0646\u0627 \u0627\u06cc\u06a9 \u0622\u062b\u0627\u0631 \u0642\u062f\u06cc\u0645\u06c1 \u06a9\u06cc \u0645\u06c1\u0645 \u0628\u0646 \u062c\u0627\u062a\u0627 \u06c1\u06d2 \u062a\u0627\u06a9\u06c1 \u06cc\u06c1 \u0645\u0639\u0644\u0648\u0645 \u06a9\u06cc\u0627 \u062c\u0627 \u0633\u06a9\u06d2 \u06a9\u06c1 \u0645\u0642\u0627\u0645\u06cc \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u06cc\u0633\u06d2 \u0628\u0646\u0627\u06cc\u0627 \u062c\u0627\u0626\u06d2\u06d4 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc\u0627\u06ba \u062f\u0628\u0627\u0624 \u0648\u0627\u0644\u06d2 \u0648\u0627\u0642\u0639\u0627\u062a \u0628\u0646 \u062c\u0627\u062a\u06cc \u06c1\u06cc\u06ba \u062c\u0646 \u06a9\u06d2 \u0644\u06cc\u06d2 \u062f\u0633\u062a\u06cc \u0633\u0648\u0627\u0644\u0627\u062a \u06a9\u06cc \u0627\u06cc\u06a9 \u0641\u06c1\u0631\u0633\u062a \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u0648\u062a\u06cc \u06c1\u06d2 \u062c\u0633\u06d2 \u0627\u06cc\u06a9 \u062e\u0627\u0635 \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc\u06ba \u0627\u0646\u062c\u0627\u0645 \u062f\u06cc\u0627 \u062c\u0627\u0646\u0627 \u0686\u0627\u06c1\u06cc\u06d2\u06d4<\/p>\n<p>\u0648\u0631\u0698\u0646 \u06a9\u0646\u0679\u0631\u0648\u0644 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0627\u06ba \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u0648 \u06a9\u0648\u0688 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u0645\u0627\u0646\u062a\u06cc \u06c1\u06cc\u06ba\u06d4 \u062c\u0628 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0627\u06ba \u0622\u067e \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u06cc \u0645\u0646\u0637\u0642 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0644\u0627\u06af\u0648 \u06a9\u06cc \u062c\u0627\u062a\u06cc \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u06a9\u0686\u06be \u0641\u0648\u0631\u06cc \u0641\u0648\u0627\u0626\u062f \u062d\u0627\u0635\u0644 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba:<\/p>\n<ul wp_automatic_readability=\"2\">\n<li wp_automatic_readability=\"2\">\n<p><strong>\u0645\u0633\u062a\u0642\u0644 \u0645\u0632\u0627\u062c\u06cc:<\/strong> \u062a\u0645\u0627\u0645 \u0645\u0627\u062d\u0648\u0644 (\u0645\u0642\u0627\u0645\u06cc\u060c \u0633\u0679\u06cc\u062c\u0646\u06af\u060c \u067e\u06cc\u062f\u0627\u0648\u0627\u0631) \u0627\u06cc\u06a9 \u06c1\u06cc \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u06c1\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0627 \u0627\u0637\u0644\u0627\u0642 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"-1\">\n<p><strong>\u062d\u0641\u0627\u0638\u062a:<\/strong> \u0627\u0633\u06a9\u0631\u067e\u0679 \u06a9\u0648 \u0686\u06be\u0648\u0691 \u06a9\u0631 \u06cc\u0627 \u067e\u0631\u0627\u0646\u06d2 \u0633\u0648\u0627\u0644\u0627\u062a \u06a9\u0648 \u0686\u0644\u0627 \u06a9\u0631 \u0627\u0646\u0633\u0627\u0646\u06cc \u063a\u0644\u0637\u06cc \u06a9\u0648 \u062e\u062a\u0645 \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"0\">\n<p><strong>\u06af\u06be\u0691\u06cc:<\/strong> Git \u06a9\u0645\u0679 \u06a9\u0648 \u062f\u06cc\u06a9\u06be \u06a9\u0631\u060c \u0622\u067e \u0628\u0627\u0644\u06a9\u0644 \u062f\u06cc\u06a9\u06be \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba \u06a9\u06c1 \u0622\u067e \u06a9\u0627 \u062c\u0627\u0648\u0627 \u06a9\u0648\u0688 \u0627\u0648\u0631 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u0646\u0626\u06cc \u062e\u0635\u0648\u0635\u06cc\u0627\u062a \u06a9\u0648 \u0633\u067e\u0648\u0631\u0679 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0633\u0627\u062a\u06be \u06a9\u06cc\u0633\u06d2 \u062a\u0628\u062f\u06cc\u0644 \u06c1\u0648\u0627\u06d4<\/p>\n<\/li>\n<\/ul>\n<p>\u0622\u067e \u06a9\u06d2 \u06a9\u0648\u0688 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06af\u0679 \u062d\u0644 \u0634\u062f\u06c1 \u0648\u0631\u0698\u0646 \u06a9\u0646\u0679\u0631\u0648\u0644\u06d4 Liquibase \u0622\u067e \u06a9\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0628\u0627\u063a\u06cc \u0628\u06be\u0627\u0626\u06cc \u0628\u0646\u0646\u06d2 \u0633\u06d2 \u0631\u0648\u06a9\u0646\u06d2 \u0645\u06cc\u06ba \u0645\u062f\u062f \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<h2 id=\"heading-what-is-liquibase\">Liquibase \u06a9\u06cc\u0627 \u06c1\u06d2\u061f<\/h2>\n<p>\u0628\u0646\u06cc\u0627\u062f\u06cc \u0637\u0648\u0631 \u067e\u0631\u060c Liquibase \u0627\u06cc\u06a9 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0627 \u0679\u0648\u0644 \u06c1\u06d2 \u062c\u0648 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u0679\u0631\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0627\u0633\u06d2 \u0642\u0627\u0628\u0644 \u0642\u06cc\u0627\u0633 \u0627\u0648\u0631 \u062f\u06c1\u0631\u0627\u0646\u06d2 \u06a9\u06d2 \u0642\u0627\u0628\u0644 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u0644\u0627\u06af\u0648 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0688\u06be\u06cc\u0644\u0627 \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u0627\u0633\u06a9\u0631\u067e\u0679 \u0644\u06a9\u06be\u0646\u06d2 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2\u060c \u0622\u067e &quot;\u0645\u0627\u0626\u06cc\u06af\u0631\u06cc\u0634\u0646&#8221; \u0644\u06a9\u06be\u062a\u06d2 \u06c1\u06cc\u06ba (\u062c\u0633\u06d2 \u0686\u06cc\u0646\u062c \u0633\u06cc\u0679 \u0628\u06be\u06cc \u06a9\u06c1\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2)\u06d4 Liquibase \u0627\u0646 \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u067e\u0691\u06be\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0635\u0644 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u0627\u0646\u062f\u0631 \u0679\u0631\u06cc\u06a9\u0646\u06af \u0679\u06cc\u0628\u0644\u0632 \u0633\u06d2 \u0627\u0646 \u06a9\u0627 \u0645\u0648\u0627\u0632\u0646\u06c1 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u0628\u0627\u0644\u06a9\u0644 \u062c\u0627\u0646\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u062a\u0627\u0632\u06c1 \u062a\u0631\u06cc\u0646 \u0631\u06a9\u06be\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06a9\u06cc\u0627 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4<\/p>\n<p>Liquibase \u06a9\u0648 \u0645\u0624\u062b\u0631 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2\u060c \u0622\u067e \u06a9\u0648 \u0635\u0631\u0641 \u0686\u0646\u062f \u062a\u0635\u0648\u0631\u0627\u062a\u06cc \u0627\u0635\u0637\u0644\u0627\u062d\u0627\u062a \u06a9\u0648 \u0633\u0645\u062c\u06be\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4<\/p>\n<ul wp_automatic_readability=\"3.5\">\n<li wp_automatic_readability=\"0\">\n<p><strong>\u0686\u06cc\u0646\u062c \u0644\u0627\u06af:<\/strong> \u06cc\u06c1 \u0645\u0627\u0633\u0679\u0631 \u0641\u0627\u0626\u0644 \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0628\u0646\u06cc\u0627\u062f\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0627\u06cc\u06a9 \u0641\u06c1\u0631\u0633\u062a \u06c1\u06d2 \u062c\u0648 Liquibase \u06a9\u0648 \u0628\u062a\u0627\u062a\u06cc \u06c1\u06d2 \u06a9\u06c1 \u06a9\u0648\u0646 \u0633\u06cc \u0645\u0627\u0626\u06cc\u06af\u0631\u06cc\u0634\u0646 \u0641\u0627\u0626\u0644\u06cc\u06ba \u0686\u0644\u0646\u06cc \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u06a9\u0633 \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"1\">\n<p><strong>\u0633\u06cc\u0679 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u06cc\u06ba:<\/strong> \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0648\u0627\u062d\u062f \u062c\u0648\u06c1\u0631\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u06d4 \u0679\u06cc\u0628\u0644 \u0628\u0646\u0627\u0646\u0627 \u0627\u06cc\u06a9 ChangeSet \u06c1\u06d2\u06d4 \u06af\u0631\u0645\u06cc \u06a9\u0627 \u0627\u0636\u0627\u0641\u06c1 \u0627\u06cc\u06a9 \u0627\u0648\u0631 \u0686\u06cc\u0632 \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"0\">\n<p><strong>\u06c1\u062c\u0631\u062a \u06a9\u06cc \u062a\u0627\u0631\u06cc\u062e:<\/strong> Liquibase \u0645\u06cc\u0632\u06cc\u06ba \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0628\u0646 \u062c\u0627\u062a\u06cc \u06c1\u06cc\u06ba (\u06a9\u06c1\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2)\u06d4 <code>DATABASECHANGELOG<\/code>) \u06cc\u0627\u062f \u0631\u06a9\u06be\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u06a9\u0648\u0646 \u0633\u06d2 ChangeSets \u067e\u06c1\u0644\u06d2 \u06c1\u06cc \u0686\u0644\u0627\u0626\u06d2 \u062c\u0627 \u0686\u06a9\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"0\">\n<p><strong>\u0686\u06cc\u06a9\u0633\u0645:<\/strong> \u06c1\u0631 ChangeSet \u06a9\u06d2 \u0644\u06cc\u06d2 \u062a\u06cc\u0627\u0631 \u06a9\u0631\u062f\u06c1 \u0627\u06cc\u06a9 \u0645\u0646\u0641\u0631\u062f \u06c1\u06cc\u0634\u06d4 Liquibase \u0627\u0633 \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u0627\u0633 \u0628\u0627\u062a \u06a9\u0627 \u067e\u062a\u06c1 \u0644\u06af\u0627\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0622\u06cc\u0627 \u06a9\u0633\u06cc \u0646\u06d2 \u06a9\u0633\u06cc \u0641\u0627\u0626\u0644 \u06a9\u0648 \u067e\u06c1\u0644\u06d2 \u0633\u06d2 \u0646\u0627\u0641\u0630 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0628\u0639\u062f \u062e\u0641\u06cc\u06c1 \u0637\u0648\u0631 \u067e\u0631 \u0627\u0633 \u0645\u06cc\u06ba \u062a\u0631\u0645\u06cc\u0645 \u06a9\u06cc \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<\/ul>\n<p>Liquibase \u06a9\u0648 Spring Boot \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0636\u0645 \u06a9\u0631\u0646\u06d2 \u0633\u06d2\u060c \u06c1\u062c\u0631\u062a \u06a9\u0627 \u0639\u0645\u0644 \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u0627\u06cc\u067e\u0644\u06cc \u06a9\u06cc\u0634\u0646 \u06a9\u06d2 \u0622\u063a\u0627\u0632 \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/umang.pk\/wp-content\/uploads\/2026\/06\/1780990582_768_Liquibase-\u0627\u0648\u0631-Spring-Boot-\u06a9\u06d2-\u0633\u0627\u062a\u06be-\u0688\u06cc\u0679\u0627-\u0628\u06cc\u0633-\u0648\u0631\u0698\u0646-\u06a9\u0646\u0679\u0631\u0648\u0644.png\" alt=\"\u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u0633\u0679\u0627\u0631\u0679 \u0627\u067e \u06a9\u06cc \u062a\u0631\u062a\u06cc\u0628 \u06a9\u0627 \u062e\u0627\u06a9\u06c1 \u062c\u06c1\u0627\u06ba Liquibase \u0679\u0631\u06cc\u06a9\u0646\u06af \u0679\u06cc\u0628\u0644 \u06a9\u0648 \u0686\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0644\u0627\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0645\u0646\u062a\u0642\u0644\u06cc \u0686\u0644\u0627\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 HTTP \u0679\u0631\u06cc\u0641\u06a9 \u06a9\u06cc \u0627\u062c\u0627\u0632\u062a \u062f\u06cc\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u0644\u0627\u06a9 \u06a9\u0648 \u062c\u0627\u0631\u06cc \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4\" style=\"display:block;margin:0 auto\" width=\"600\" height=\"400\" loading=\"lazy\" title=\"\"><\/p>\n<p>\u0633\u0679\u0627\u0631\u0679 \u0627\u067e \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646\u060c \u0648\u06cc\u0628 \u0633\u0631\u0648\u0631 \u06a9\u0648 HTTP \u0679\u0631\u06cc\u0641\u06a9 \u062d\u0627\u0635\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0627\u062c\u0627\u0632\u062a \u062f\u06cc\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 Liquibase \u06a9\u0646\u0679\u0631\u0648\u0644 \u06a9\u0631 \u0644\u06cc\u062a\u0627 \u06c1\u06d2\u06d4 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0633\u06d2 \u062c\u0691\u06cc\u06ba \u0627\u0648\u0631 \u0679\u0631\u06cc\u06a9\u0646\u06af \u0679\u06cc\u0628\u0644 \u06a9\u0648 \u0686\u06cc\u06a9 \u06a9\u0631\u06cc\u06ba \u06a9\u06c1 \u06a9\u0648\u0646 \u0633\u06cc \u06c1\u062c\u0631\u062a \u067e\u06c1\u0644\u06d2 \u06c1\u06cc \u0686\u0644 \u0686\u06a9\u06cc \u06c1\u06d2\u06d4 \u062c\u0628 \u0627\u0633\u06d2 \u0645\u0642\u0627\u0645\u06cc \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0646\u0626\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u0645\u0644\u062a\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u06cc\u06c1 \u0628\u06cc\u06a9 \u0648\u0642\u062a \u0627\u067e \u0688\u06cc\u0679\u0633 \u06a9\u0648 \u0631\u0648\u06a9\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0644\u0627\u06a9 \u06a9\u0631 \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u0627\u0646\u062c\u0627\u0645 \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u060c \u0627\u06cc\u06a9 \u0646\u0626\u06cc \u062a\u0627\u0631\u06cc\u062e \u0644\u06a9\u06be\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u0622\u062e\u0631 \u0645\u06cc\u06ba \u0644\u0627\u06a9 \u06a9\u0648 \u062c\u0627\u0631\u06cc \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u0633 \u067e\u0648\u0631\u06d2 \u0639\u0645\u0644 \u06a9\u06d2 \u0645\u06a9\u0645\u0644 \u06c1\u0648\u0646\u06d2 \u06a9\u06d2 \u0628\u0639\u062f \u06c1\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0628\u0648\u0679 \u06c1\u0648\u06af\u0627\u06d4<\/p>\n<p>Liquibase \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u06a9\u06d2 \u0648\u06cc\u0628 \u0633\u0631\u0648\u0631 \u06a9\u0648 \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u0634\u0631\u0648\u0639 \u06a9\u0631\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u0686\u0644\u062a\u0627 \u06c1\u06d2\u060c \u0644\u06c1\u0630\u0627 \u0622\u067e \u06a9\u06cc \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u067e\u0631\u0627\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u067e\u0631 \u0679\u0631\u06cc\u0641\u06a9 \u06a9\u06cc \u062e\u062f\u0645\u062a \u0646\u06c1\u06cc\u06ba \u06a9\u0631\u06d2 \u06af\u06cc\u06d4 \u0627\u06af\u0631 \u0645\u0646\u062a\u0642\u0644\u06cc \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648\u062c\u0627\u062a\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0634\u0631\u0648\u0639 \u0646\u06c1\u06cc\u06ba \u06c1\u0648\u06af\u06cc\u060c \u0622\u067e \u06a9\u06d2 \u0633\u0633\u0679\u0645 \u06a9\u0648 \u0633\u0645\u062c\u06be\u0648\u062a\u06c1 \u0634\u062f\u06c1 \u062d\u0627\u0644\u062a \u0645\u06cc\u06ba \u062f\u0627\u062e\u0644 \u06c1\u0648\u0646\u06d2 \u0633\u06d2 \u0628\u0686\u0627\u0626\u06d2 \u06af\u06cc\u06d4<\/p>\n<h2 id=\"heading-project-setup\">\u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u06a9\u06cc \u062a\u0631\u062a\u06cc\u0628\u0627\u062a<\/h2>\n<p>\u0627\u0628 \u062c\u0628 \u06a9\u06c1 \u0622\u067e \u062a\u06be\u06cc\u0648\u0631\u06cc \u06a9\u0648 \u0633\u0645\u062c\u06be \u06af\u0626\u06d2 \u06c1\u06cc\u06ba\u060c \u0622\u0626\u06cc\u06d2 \u06a9\u0686\u06be \u067e\u0631\u06cc\u06a9\u0679\u06cc\u06a9\u0644 \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0622\u0626\u06cc\u06d2 \u0627\u06cc\u0645\u067e\u0644\u0627\u0626\u06cc \u0645\u06cc\u0646\u062c\u0645\u0646\u0679 API \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u06c1\u06c1 \u0628\u0646\u0627\u0626\u06cc\u06ba\u06d4<\/p>\n<p>\u06cc\u06c1 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u0627 \u06c1\u06d2:<\/p>\n<ul>\n<li>\n<p>Java 17+<\/p>\n<\/li>\n<li>\n<p>\u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 3.x<\/p>\n<\/li>\n<li>\n<p>\u0645\u0627\u0648\u06cc\u0646<\/p>\n<\/li>\n<li>\n<p>Liquibase<\/p>\n<\/li>\n<li>\n<p>H2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633<\/p>\n<\/li>\n<\/ul>\n<p>\u06c1\u0645 H2 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631 \u0631\u06c1\u06d2 \u06c1\u06cc\u06ba \u06a9\u06cc\u0648\u0646\u06a9\u06c1 \u06cc\u06c1 \u0627\u06cc\u06a9 \u0627\u0646 \u0645\u06cc\u0645\u0648\u0631\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06c1\u06d2 \u062c\u0633\u06d2 \u0627\u0646\u0633\u0679\u0627\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4 \u0622\u067e \u0688\u0648\u06a9\u0631 \u06a9\u0646\u0679\u06cc\u0646\u0631 \u06a9\u0648 \u06a9\u0646\u0641\u06cc\u06af\u0631 \u06a9\u06cc\u06d2 \u06cc\u0627 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0633\u0631\u0648\u0631 \u0627\u0646\u0633\u0679\u0627\u0644 \u06a9\u06cc\u06d2 \u0628\u063a\u06cc\u0631 \u0627\u0633 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u06a9\u0648 \u0641\u0648\u0631\u0627\u064b \u0686\u0644\u0627 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u062a\u0627\u06c1\u0645\u060c \u062c\u0648 \u06a9\u0686\u06be \u0622\u067e \u06cc\u06c1\u0627\u06ba \u0633\u06cc\u06a9\u06be\u062a\u06d2 \u06c1\u06cc\u06ba \u0648\u06c1 \u0628\u0627\u0644\u06a9\u0644 \u0627\u0633\u06cc \u0637\u0631\u062d PostgreSQL\u060c MySQL\u060c SQL Server\u060c \u06cc\u0627 Oracle \u067e\u0631 \u0644\u0627\u06af\u0648 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u062c\u0628 \u0622\u067e \u0627\u0633 \u067e\u0631\u0627\u062c\u06cc\u06a9\u0679 \u06a9\u0648 \u0627\u0633\u067e\u0631\u0646\u06af \u0627\u0646\u06cc\u0634\u06cc\u0644\u0627\u0626\u0632\u06cc\u0634\u0646 \u06a9\u06d2 \u0630\u0631\u06cc\u0639\u06d2 \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u0645\u0646\u062f\u0631\u062c\u06c1 \u0630\u06cc\u0644 \u0627\u0646\u062d\u0635\u0627\u0631 \u0645\u0646\u062a\u062e\u0628 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba: Spring Web\u060c Spring Data JPA\u060c Liquibase Migration\u060c \u0627\u0648\u0631 H2 Database\u06d4<\/p>\n<p>\u0622\u067e \u06a9\u0627 <code>pom.xml<\/code>\u0622\u067e \u0627\u0646\u062d\u0635\u0627\u0631 \u0686\u06cc\u06a9 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba \u062c\u0648 \u0627\u06cc\u0633\u0627 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06c1\u0645 \u06c1\u06cc\u06ba\u06d4<\/p>\n<pre><code class=\"language-xml\"><dependencies>\n    <dependency>\n        <groupid>org.springframework.boot<\/groupid>\n        <artifactid>spring-boot-starter-web<\/artifactid>\n    <\/dependency>\n    <dependency>\n        <groupid>org.springframework.boot<\/groupid>\n        <artifactid>spring-boot-starter-data-jpa<\/artifactid>\n    <\/dependency>\n\n    <dependency>\n        <groupid>com.h2database<\/groupid>\n        <artifactid>h2<\/artifactid>\n        <scope>runtime<\/scope>\n    <\/dependency>\n\n    <dependency>\n        <groupid>org.liquibase<\/groupid>\n        <artifactid>liquibase-core<\/artifactid>\n    <\/dependency>\n<\/dependencies>\n<\/code><\/pre>\n<p>\u0627\u06af\u0644\u0627\u060c \u06c1\u0645 H2 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0628\u0627\u062a \u0686\u06cc\u062a \u06a9\u0631\u0646\u06d2 \u0627\u0648\u0631 Liquibase \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u062a\u0644\u0627\u0634 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 Spring Boot \u06a9\u0648 \u062a\u0631\u062a\u06cc\u0628 \u062f\u06cc\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0622\u067e \u06a9\u0627 <code>src\/main\/resources\/application.properties<\/code> \u0627\u06cc\u06a9 \u0641\u0627\u0626\u0644 \u0628\u0646\u0627\u0626\u06cc\u06ba \u0627\u0648\u0631 \u062f\u0631\u062c \u0630\u06cc\u0644 \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba:<\/p>\n<pre><code class=\"language-plaintext\"># H2 Database Configuration\nspring.datasource.url=jdbc:h2:file:.\/data\/employeedb;DB_CLOSE_DELAY=-1\nspring.datasource.driverClassName=org.h2.Driver\nspring.datasource.username=sa\nspring.datasource.password=\n\n# Enable H2 Console to inspect the database in your browser\nspring.h2.console.enabled=true\nspring.h2.console.path=\/h2-console\n\n# Liquibase Configuration\nspring.liquibase.change-log=classpath:db\/changelog\/db.changelog-master.xml\n<\/code><\/pre>\n<p>\u0622\u062e\u0631\u06cc \u0644\u0627\u0626\u0646 \u0633\u0628 \u0633\u06d2 \u0627\u06c1\u0645 \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u06a9\u0648 \u0628\u062a\u0627\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u06cc &quot;\u0645\u0627\u0633\u0679\u0631 \u0644\u0633\u0679&#8221; \u06a9\u06c1\u0627\u06ba \u062a\u0644\u0627\u0634 \u06a9\u06cc \u062c\u0627\u0626\u06d2\u06d4<\/p>\n<p>\u0646\u0648\u0679: \u06c1\u0645 \u0627\u0646 \u0645\u06cc\u0645\u0648\u0631\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2 \u0641\u0627\u0626\u0644 \u067e\u0631 \u0645\u0628\u0646\u06cc H2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631 \u0631\u06c1\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0627\u0646 \u0645\u06cc\u0645\u0648\u0631\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0645\u0633\u0626\u0644\u06c1 \u06cc\u06c1 \u06c1\u06d2 \u06a9\u06c1 \u062c\u0628 \u0628\u06be\u06cc \u0622\u067e \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u062e\u0648\u062f \u06c1\u06cc \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u0645\u0679 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u062c\u0628 \u0628\u06be\u06cc \u0622\u067e \u0628\u0648\u0679 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u062a\u0648 Liquibase \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u0648 \u0634\u0631\u0648\u0639 \u0633\u06d2 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0628\u0646\u0627\u062a\u0627 \u06c1\u06d2\u060c \u0644\u06cc\u06a9\u0646 <strong>\u0641\u0627\u0626\u0644 \u06a9\u06cc \u0628\u0646\u06cc\u0627\u062f \u067e\u0631<\/strong> \u0627\u0633 \u0679\u06cc\u0648\u0679\u0648\u0631\u06cc\u0644 (\u0627\u0648\u0631 \u0627\u0635\u0644 \u0645\u0642\u0627\u0645\u06cc \u062a\u0631\u0642\u06cc) \u06a9\u06d2 \u0644\u06cc\u06d2\u060c \u0627\u06cc\u06a9 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0628\u06c1\u062a \u0628\u06c1\u062a\u0631 \u06c1\u06d2\u06d4 \u0641\u0627\u0626\u0644 \u067e\u0631 \u0645\u0628\u0646\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u0633\u0627\u062a\u06be\u060c \u0622\u067e \u06a9\u0627 \u0688\u06cc\u0679\u0627\u060c \u0627\u0648\u0631 \u0627\u0633 \u0633\u06d2 \u0628\u06be\u06cc \u0627\u06c1\u0645 \u0628\u0627\u062a\u060c \u0622\u067e \u06a9\u06cc Liquibase \u06a9\u06cc \u062a\u0627\u0631\u06cc\u062e\u060c \u062f\u0631\u062d\u0642\u06cc\u0642\u062a \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u06d2 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06c1\u0648\u0646\u06d2 \u067e\u0631 \u0628\u0631\u0642\u0631\u0627\u0631 \u0631\u06c1\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<h2 id=\"heading-understanding-core-liquibase-concepts\">Liquibase \u06a9\u06d2 \u0628\u0646\u06cc\u0627\u062f\u06cc \u062a\u0635\u0648\u0631\u0627\u062a \u06a9\u0648 \u0633\u0645\u062c\u06be\u06cc\u06ba\u06d4<\/h2>\n<p>\u0627\u067e\u0646\u0627 \u067e\u06c1\u0644\u0627 \u0679\u06cc\u0628\u0644 \u0628\u0646\u0627\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2\u060c \u0622\u067e \u06a9\u0648 \u06cc\u06c1 \u0633\u0645\u062c\u06be\u0646\u0627 \u06c1\u0648\u06af\u0627 \u06a9\u06c1 Liquibase \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u06a9\u06cc\u0633\u06d2 \u0645\u0646\u0638\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 Liquibase \u0627\u06cc\u06a9 \u062f\u0631\u062c\u06c1 \u0628\u0646\u062f\u06cc \u06a9\u0627 \u0688\u06be\u0627\u0646\u0686\u06c1 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u0633\u06d2 \u0627\u06cc\u06a9 \u06a9\u062a\u0627\u0628 \u06a9\u06cc \u0637\u0631\u062d \u0633\u0648\u0686\u06cc\u06ba\u06d4 \u06a9\u06c1 <code>changeLog<\/code> \u06cc\u06c1 \u0645\u0646\u062f\u0631\u062c\u0627\u062a \u06a9\u0627 \u062c\u062f\u0648\u0644 \u06c1\u06d2\u060c <code>changeSets<\/code> \u06cc\u06c1 \u0627\u06cc\u06a9 \u062d\u0642\u06cc\u0642\u06cc \u0628\u0627\u0628 \u06c1\u06d2\u06d4<\/p>\n<ol wp_automatic_readability=\"2\">\n<li wp_automatic_readability=\"1\">\n<p><strong>\u0645\u0627\u0633\u0679\u0631 \u062a\u0628\u062f\u06cc\u0644\u06cc \u0644\u0627\u06af:<\/strong> \u06cc\u06c1 \u062f\u0627\u062e\u0644\u06cc \u0646\u0642\u0637\u06c1 \u06c1\u06d2\u06d4 \u0627\u0633 \u0645\u06cc\u06ba \u0634\u0627\u0630 \u0648 \u0646\u0627\u062f\u0631 \u06c1\u06cc \u0627\u0635\u0644 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0627\u06ba \u0634\u0627\u0645\u0644 \u06c1\u0648\u062a\u06cc \u06c1\u06cc\u06ba\u06d4 \u0627\u0633 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2\u060c \u0627\u0633 \u06a9\u0627 \u0648\u0627\u062d\u062f \u06a9\u0627\u0645 \u062f\u0648\u0633\u0631\u06cc \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u0627\u06cc\u06a9 \u0645\u062e\u0635\u0648\u0635 \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06a9\u0631\u0646\u0627 \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"-1\">\n<p><strong>\u0686\u0627\u0626\u0644\u0688 \u0686\u06cc\u0646\u062c \u0644\u0627\u06af:<\/strong> \u06cc\u06c1 \u06af\u0631\u0648\u067e \u0633\u06d2 \u0645\u062a\u0639\u0644\u0642 \u062a\u0628\u062f\u06cc\u0644\u06cc\u0627\u06ba \u0627\u06cc\u06a9 \u0633\u0627\u062a\u06be \u06af\u0631\u0648\u067e \u06a9\u06cc \u062c\u0627\u062a\u06cc \u06c1\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"1\">\n<p><strong>\u0633\u06cc\u0679 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u06cc\u06ba:<\/strong> \u06cc\u06c1 \u0627\u0635\u0644 \u0627\u06cc\u0679\u0645 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0645\u0627\u0646\u0688\u0632 \u06c1\u06cc\u06ba (\u062c\u06cc\u0633\u06d2 \u0679\u06cc\u0628\u0644 \u0628\u0646\u0627\u0646\u0627 \u06cc\u0627 \u06a9\u0627\u0644\u0645 \u0634\u0627\u0645\u0644 \u06a9\u0631\u0646\u0627)\u06d4<\/p>\n<\/li>\n<\/ol>\n<p>\u06cc\u06c1\u0627\u06ba \u0627\u06cc\u06a9 \u0628\u0635\u0631\u06cc \u062e\u0631\u0627\u0628\u06cc \u06c1\u06d2 \u06a9\u06c1 \u06cc\u06c1 \u062f\u0631\u062c\u06c1 \u0628\u0646\u062f\u06cc \u0627\u06cc\u06a9 \u062d\u0642\u06cc\u0642\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u0645\u06cc\u06ba \u06a9\u06cc\u0633\u06d2 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/umang.pk\/wp-content\/uploads\/2026\/06\/1780990582_54_Liquibase-\u0627\u0648\u0631-Spring-Boot-\u06a9\u06d2-\u0633\u0627\u062a\u06be-\u0688\u06cc\u0679\u0627-\u0628\u06cc\u0633-\u0648\u0631\u0698\u0646-\u06a9\u0646\u0679\u0631\u0648\u0644.png\" alt=\"\u0641\u0627\u0626\u0644 \u0688\u06be\u0627\u0646\u0686\u06c1 \u06a9\u0627 \u062e\u0627\u06a9\u06c1 \u062c\u0648 \u0645\u0627\u0633\u0679\u0631 \u062a\u0628\u062f\u06cc\u0644\u06cc \u0644\u0627\u06af XML \u0641\u0627\u0626\u0644 \u06a9\u0648 \u062f\u06a9\u06be\u0627 \u0631\u06c1\u0627 \u06c1\u06d2 \u062c\u0648 \u062a\u06cc\u0646 \u0686\u0627\u0626\u0644\u0688 \u0645\u0627\u0626\u06cc\u06af\u0631\u06cc\u0634\u0646 \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u06cc \u0637\u0631\u0641 \u0627\u0634\u0627\u0631\u06c1 \u06a9\u0631 \u0631\u06c1\u0627 \u06c1\u06d2\u06d4\" style=\"display:block;margin:0 auto\" width=\"600\" height=\"400\" loading=\"lazy\" title=\"\"><\/p>\n<p>Liquibase \u06c1\u062c\u0631\u062a \u06a9\u0648 \u062f\u0631\u062c\u06c1 \u0628\u0646\u062f\u06cc \u06a9\u06d2 \u0645\u0637\u0627\u0628\u0642 \u0645\u0646\u0638\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06cc\u06a9 \u0648\u0627\u062d\u062f \u0645\u0627\u0633\u0679\u0631 \u0641\u0627\u0626\u0644 \u06a9\u0648 \u0628\u0631\u0642\u0631\u0627\u0631 \u0631\u06a9\u06be\u06cc\u06ba \u062c\u0648 \u0645\u0646\u062f\u0631\u062c\u0627\u062a \u06a9\u06cc \u0645\u06cc\u0632 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u06cc \u06c1\u06d2\u06d4 \u0627\u0633 \u0645\u0627\u0633\u0679\u0631 \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u0628\u06c1\u062a \u06a9\u0645 \u0627\u0635\u0644 SQL \u06a9\u0645\u0627\u0646\u0688\u0632 \u06c1\u06cc\u06ba\u06d4 \u0627\u0633 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2\u060c \u0648\u0627\u0636\u062d \u0637\u0648\u0631 \u067e\u0631 \u0686\u0627\u0626\u0644\u0688 XML \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u0633\u062e\u062a \u0639\u0645\u0644 \u062f\u0631\u0622\u0645\u062f \u06a9\u06d2 \u062d\u06a9\u0645 \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u06d4 \u06c1\u0631 \u0630\u06cc\u0644\u06cc \u0641\u0627\u0626\u0644\u060c \u062c\u06cc\u0633\u06d2 <code>01-create-employees.xml<\/code>) \u0627\u06cc\u06a9 \u06cc\u0627 \u0632\u06cc\u0627\u062f\u06c1 \u0627\u0646\u0641\u0631\u0627\u062f\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0645\u0627\u0646\u0688\u0632 \u067e\u0631 \u0645\u0634\u062a\u0645\u0644 \u06c1\u06d2 \u062c\u0633\u06d2 Liquibase changeSets \u06a9\u06c1\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u06a9\u0648\u0626\u06cc \u0631\u0627\u0633\u062a\u06c1 \u0646\u06c1\u06cc\u06ba <code>changeSet<\/code> \u0627\u0633 \u06a9\u06cc \u0634\u0646\u0627\u062e\u062a \u062a\u06cc\u0646 \u0686\u06cc\u0632\u0648\u06ba \u0633\u06d2 \u0645\u0646\u0641\u0631\u062f \u06c1\u06d2:<\/p>\n<ul wp_automatic_readability=\"0\">\n<li wp_automatic_readability=\"-1\">\n<p><strong>ID:<\/strong> \u0627\u06cc\u06a9 \u0645\u0646\u0641\u0631\u062f \u062a\u0627\u0631 (\u0627\u06a9\u062b\u0631 \u0627\u06cc\u06a9 \u0646\u0645\u0628\u0631 \u06cc\u0627 \u062c\u06cc\u0631\u0627 \u0679\u06a9\u0679 ID)\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"-1\">\n<p><strong>\u0645\u0635\u0646\u0641:<\/strong> \u0645\u06cc\u06ba \u0648\u06c1 \u0634\u062e\u0635 \u06c1\u0648\u06ba \u062c\u0633 \u0646\u06d2 \u06c1\u062c\u0631\u062a \u0644\u06a9\u06be\u06cc\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"-1\">\n<p><strong>\u0641\u0627\u0626\u0644 \u06a9\u0627 \u0631\u0627\u0633\u062a\u06c1:<\/strong> \u06cc\u06c1 \u0648\u06c1 \u062c\u06af\u06c1 \u06c1\u06d2 \u062c\u06c1\u0627\u06ba \u0641\u0627\u0626\u0644 \u0648\u0627\u0642\u0639 \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<\/ul>\n<p>\u062c\u0628 Liquibase \u0686\u0644\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u06a9\u0648 \u062f\u0631\u062c \u0630\u06cc\u0644 \u0646\u0638\u0631 \u0622\u062a\u0627 \u06c1\u06d2: <code>changeSet<\/code>\u0645\u0648\u0627\u062f \u06a9\u06cc \u0627\u06cc\u06a9 \u06a9\u0631\u067e\u0679\u0648\u06af\u0631\u0627\u0641\u06a9 \u06c1\u06cc\u0634 (\u0686\u06cc\u06a9\u0633\u0645) \u06a9\u0627 \u062d\u0633\u0627\u0628 \u0644\u06af\u0627\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba ID\u060c \u0645\u0635\u0646\u0641 \u0627\u0648\u0631 \u0686\u06cc\u06a9\u0633\u0645 \u06a9\u0648 \u0631\u06cc\u06a9\u0627\u0631\u0688 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06af\u0644\u06d2 \u0633\u0679\u0627\u0631\u0679 \u0627\u067e \u067e\u0631\u060c \u0627\u06af\u0631 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba ID\u060c creator\u060c \u0627\u0648\u0631 \u0641\u0627\u0626\u0644 \u067e\u0627\u062a\u06be \u06a9\u06d2 \u062f\u0631\u0633\u062a \u0627\u0645\u062a\u0632\u0627\u062c \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0686\u06cc\u06a9 \u06a9\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0627\u0633\u06d2 \u0686\u06be\u0648\u0691 \u062f\u06cc\u0627 \u062c\u0627\u0626\u06d2 \u06af\u0627\u06d4<\/p>\n<h2 id=\"heading-create-the-initial-employee-schema-version-1\">\u0627\u06cc\u06a9 \u0627\u0628\u062a\u062f\u0627\u0626\u06cc \u0645\u0644\u0627\u0632\u0645 \u0633\u06a9\u06cc\u0645\u0627 \u0628\u0646\u0627\u0626\u06cc\u06ba (\u0648\u0631\u0698\u0646 1)<\/h2>\n<p>\u0622\u0626\u06cc\u06d2 \u067e\u06c1\u0644\u0627 \u0648\u0631\u0698\u0646 \u0644\u06a9\u06be\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0622\u067e \u06a9\u0648 \u0627\u067e\u0646\u06d2 \u0639\u0645\u0644\u06d2 \u06a9\u0648 \u0630\u062e\u06cc\u0631\u06c1 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0645\u06cc\u0632 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u0648\u06af\u06cc\u06d4<\/p>\n<p>\u0633\u0628 \u0633\u06d2 \u067e\u06c1\u0644\u06d2\u060c \u0627\u06cc\u06a9 \u0645\u0627\u0633\u0679\u0631 \u0641\u0627\u0626\u0644 \u0628\u0646\u0627\u0626\u06cc\u06ba. <code>src\/main\/resources\/db\/changelog\/db.changelog-master.xml<\/code>:<\/p>\n<pre><code class=\"language-xml\"><?xml version=\"1.0\" encoding=\"UTF-8\"?????>\n<databasechangelog xmlns=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\" xsi:schemalocation=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\n        http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\/dbchangelog-4.20.xsd\">\n\n    <include file=\"db\/changelog\/changes\/01-create-employees.xml\"\/>\n\n<\/databasechangelog>\n<\/code><\/pre>\n<p>\u0627\u06af\u0644\u0627\u060c \u06c1\u0645 \u0627\u0635\u0644 \u0645\u0627\u0626\u06cc\u06af\u0631\u06cc\u0634\u0646 \u0641\u0627\u0626\u0644 \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 <code>src\/main\/resources\/db\/changelog\/changes\/01-create-employees.xml<\/code>:<\/p>\n<pre><code class=\"language-xml\"><?xml version=\"1.0\" encoding=\"UTF-8\"?????>\n<databasechangelog xmlns=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\" xsi:schemalocation=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\n        http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\/dbchangelog-4.20.xsd\">\n\n    <changeset id=\"1\" author=\"ashutoshkrris\">\n        <createtable tablename=\"employees\">\n            <column name=\"id\" type=\"BIGINT\" autoincrement=\"true\">\n                <constraints primarykey=\"true\" nullable=\"false\"\/>\n            <\/column>\n            <column name=\"first_name\" type=\"VARCHAR(50)\">\n                <constraints nullable=\"false\"\/>\n            <\/column>\n            <column name=\"last_name\" type=\"VARCHAR(50)\">\n                <constraints nullable=\"false\"\/>\n            <\/column>\n        <\/createtable>\n    <\/changeset>\n\n<\/databasechangelog>\n<\/code><\/pre>\n<p>\u0622\u0626\u06cc\u06d2 \u0627\u0633 \u067e\u0631 \u0627\u06cc\u06a9 \u0646\u0638\u0631 \u0688\u0627\u0644\u06cc\u06ba \u06a9\u06c1 \u06c1\u0645 \u0646\u06d2 \u0627\u0628\u06be\u06cc \u06a9\u06cc\u0627 \u06a9\u06cc\u0627\u06d4 \u06c1\u0645 \u06c1\u06cc\u06ba <code>changeSet<\/code> \u0627\u0648\u0631 <code>id<\/code> &quot;1&#8221; \u0627\u0648\u0631 <code>author<\/code> &quot;\u0622\u0634\u0648\u062a\u0648\u0634\u06a9\u0631\u06cc\u0633&#8221;\u06d4 \u0627\u0646\u062f\u0631\u0648\u0646\u06cc \u0637\u0648\u0631 \u067e\u0631\u060c \u06c1\u0645 \u0646\u06d2 Liquibase \u06a9\u06d2 XML \u0646\u062d\u0648 \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u0648\u0626\u06d2 \u062c\u062f\u0648\u0644\u0648\u06ba \u06a9\u06cc \u0648\u0636\u0627\u062d\u062a \u06a9\u06cc\u06d4<\/p>\n<p>\u0633\u0627\u062f\u06c1 SQL \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2 XML \u06a9\u06cc\u0648\u06ba \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u06cc\u06ba\u061f \u06a9\u06cc\u0648\u0646\u06a9\u06c1 Liquibase \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 agnostic \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0639\u06cc\u0646 \u0645\u0637\u0627\u0628\u0642 XML PostgreSQL \u06a9\u06d2 \u0644\u06cc\u06d2 \u062f\u0631\u0633\u062a \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0646\u062d\u0648 \u062a\u06cc\u0627\u0631 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<code>SERIAL<\/code>)\u060c MySQL(<code>AUTO_INCREMENT<\/code>) \u06cc\u0627 \u0627\u0648\u0631\u06cc\u06a9\u0644(<code>IDENTITY<\/code>)\u06d4 \u0622\u067e \u0627\u067e\u0646\u06cc \u0633\u0627\u062e\u062a \u06a9\u06cc \u0648\u0636\u0627\u062d\u062a \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u0627\u0648\u0631 Liquibase \u0627\u0633\u06d2 \u0622\u067e \u06a9\u06d2 \u0645\u062e\u0635\u0648\u0635 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0628\u0648\u0644\u06cc \u0645\u06cc\u06ba \u062a\u0631\u062c\u0645\u06c1 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u0628 \u0627\u067e\u0646\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0686\u0644\u0627\u0626\u06cc\u06ba\u06d4 \u0679\u0631\u0645\u06cc\u0646\u0644 \u0622\u0624\u0679 \u067e\u0679 \u067e\u0631 \u0627\u06cc\u06a9 \u0646\u0638\u0631 \u0688\u0627\u0644\u06cc\u06ba\u06d4 \u0622\u067e \u06a9\u0648 \u062f\u0631\u062c \u0630\u06cc\u0644 \u0633\u06d2 \u0645\u0644\u062a\u06d2 \u062c\u0644\u062a\u06d2 \u0646\u0648\u0634\u062a\u06c1 \u062c\u0627\u062a \u0646\u0638\u0631 \u0622\u0626\u06cc\u06ba \u06af\u06d2\u06d4<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/umang.pk\/wp-content\/uploads\/2026\/06\/1780990582_18_Liquibase-\u0627\u0648\u0631-Spring-Boot-\u06a9\u06d2-\u0633\u0627\u062a\u06be-\u0688\u06cc\u0679\u0627-\u0628\u06cc\u0633-\u0648\u0631\u0698\u0646-\u06a9\u0646\u0679\u0631\u0648\u0644.png\" alt=\"Liquibase \u0634\u0631\u0648\u0639 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0679\u0631\u0645\u06cc\u0646\u0644 \u0644\u0627\u06af\" style=\"display:block;margin:0 auto\" width=\"600\" height=\"400\" loading=\"lazy\" title=\"\"><\/p>\n<p>Liquibase \u0646\u06d2 \u0645\u062d\u0633\u0648\u0633 \u06a9\u06cc\u0627 \u06a9\u06c1 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u062e\u0627\u0644\u06cc \u06c1\u06d2\u06d4 \u0679\u0631\u06cc\u06a9\u0646\u06af \u0679\u06cc\u0628\u0644 \u06a9\u0648 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0679\u0631\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 (<code>DATABASECHANGELOG<\/code>)\u060c \u06c1\u0645\u0627\u0631\u0627 \u0645\u0636\u0645\u0648\u0646 \u067e\u0691\u06be\u06cc\u06ba <code>changeSet<\/code>\u0645\u06cc\u06ba \u0646\u06d2 \u0679\u06cc\u0628\u0644 \u062a\u062e\u0644\u06cc\u0642 \u06a9\u06cc\u0627 \u0627\u0648\u0631 \u0627\u06cc\u0648\u0646\u0679 \u06a9\u0648 \u0644\u0627\u06af \u06a9\u06cc\u0627\u06d4<\/p>\n<p>\u0627\u067e\u0646\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0648 \u0627\u0628\u06be\u06cc \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 Liquibase \u062f\u0648\u0628\u0627\u0631\u06c1 \u0686\u0644\u06d2 \u06af\u0627\u06d4 \u0644\u06cc\u06a9\u0646 \u0622\u0626\u06cc\u06d2 \u0627\u0633 \u0628\u0627\u0631 \u0627\u0633\u06d2 \u0686\u06cc\u06a9 \u06a9\u0631\u06cc\u06ba\u06d4 <code>DATABASECHANGELOG<\/code> \u0645\u06cc\u0632\u060c \u0627\u0633\u06d2 \u062f\u06cc\u06a9\u06be\u0648 <code>id=\"1\"<\/code> \u0627\u0648\u0631 <code>author=\"ashutoshkrris\"<\/code> \u06cc\u06c1 \u067e\u06c1\u0644\u06d2 \u06c1\u06cc \u0686\u0644 \u0686\u06a9\u0627 \u06c1\u06d2\u060c \u0627\u0633 \u0644\u06cc\u06d2 \u0627\u0633\u06d2 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0686\u06be\u0648\u0691 \u062f\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4 \u0622\u067e \u06a9\u0627 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0628 \u0645\u062d\u0641\u0648\u0638 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u0648\u0631\u0698\u0646 \u0645\u06cc\u06ba \u06c1\u06d2\u06d4<\/p>\n<h2 id=\"heading-what-just-happened\">\u0628\u0633 \u06a9\u06cc\u0627 \u06c1\u0648\u0627\u061f<\/h2>\n<p>\u0627\u0633 \u0645\u0642\u0627\u0645 \u062a\u06a9\u060c Liquibase \u062a\u06be\u0648\u0691\u0627 \u0633\u0627 \u062c\u0627\u062f\u0648\u0626\u06cc \u0645\u062d\u0633\u0648\u0633 \u06a9\u0631 \u0633\u06a9\u062a\u0627 \u06c1\u06d2\u06d4 XML \u0641\u0627\u0626\u0644 \u06a9\u0648 \u0641\u0648\u0644\u0688\u0631 \u0645\u06cc\u06ba \u0631\u06a9\u06be\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba\u060c \u062c\u0648 \u0622\u067e \u06a9\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u0648 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631 \u062f\u06d2 \u06af\u0627\u06d4<\/p>\n<p>\u062a\u0627\u06c1\u0645\u060c \u06cc\u06c1 \u0633\u0645\u062c\u06be\u0646\u0627 \u0636\u0631\u0648\u0631\u06cc \u06c1\u06d2 \u06a9\u06c1 Liquibase \u0627\u0646\u062f\u0631\u0648\u0646\u06cc \u0637\u0648\u0631 \u067e\u0631 \u06a9\u06cc\u0633\u06d2 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0622\u063a\u0627\u0632 \u06a9\u06cc \u062a\u0631\u062a\u06cc\u0628 \u06a9\u0648 \u0633\u0645\u062c\u06be\u0646\u06d2 \u0633\u06d2 \u0622\u067e \u06a9\u0648 \u06cc\u06c1 \u062c\u0627\u0646\u0646\u06d2 \u0645\u06cc\u06ba \u0645\u062f\u062f \u0645\u0644\u06d2 \u06af\u06cc \u06a9\u06c1 \u0622\u062e\u0631\u06a9\u0627\u0631 \u0645\u0633\u0627\u0626\u0644 \u067e\u06cc\u062f\u0627 \u06c1\u0648\u0646\u06d2 \u067e\u0631 \u0627\u067e\u0646\u06cc \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u06a9\u0648 \u06a9\u06cc\u0633\u06d2 \u0688\u06cc\u0628\u06af \u06a9\u0631\u0646\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u062c\u0628 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0634\u0631\u0648\u0639 \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u06cc\u06c1 \u0641\u0648\u0631\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0648\u06cc\u0628 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u0648\u06ba \u06a9\u0648 \u0642\u0628\u0648\u0644 \u06a9\u0631\u0646\u0627 \u0634\u0631\u0648\u0639 \u0646\u06c1\u06cc\u06ba \u06a9\u0631\u062a\u06cc \u06c1\u06d2\u06d4 \u067e\u06c1\u0644\u06d2 \u06c1\u0645 \u0627\u0646\u062f\u0631\u0648\u0646\u06cc \u0627\u062c\u0632\u0627\u0621 \u06a9\u0648 \u0634\u0631\u0648\u0639 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba: \u0627\u06cc\u06a9 \u0628\u0627\u0631 \u062c\u0628 Liquibase \u0627\u062c\u0632\u0627\u0621 \u0628\u0646 \u062c\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0627 \u0639\u0645\u0644 \u0634\u0631\u0648\u0639 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u06cc\u06c1\u0627\u06ba \u0628\u0627\u0644\u06a9\u0644 \u0648\u06c1\u06cc \u06c1\u06d2 \u062c\u0648 \u0622\u063a\u0627\u0632 \u06a9\u06d2 \u0645\u0631\u062d\u0644\u06d2 \u0645\u06cc\u06ba \u06c1\u0648\u062a\u0627 \u06c1\u06d2:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/umang.pk\/wp-content\/uploads\/2026\/06\/1780990582_571_Liquibase-\u0627\u0648\u0631-Spring-Boot-\u06a9\u06d2-\u0633\u0627\u062a\u06be-\u0688\u06cc\u0679\u0627-\u0628\u06cc\u0633-\u0648\u0631\u0698\u0646-\u06a9\u0646\u0679\u0631\u0648\u0644.png\" alt=\"\u062a\u0641\u0635\u06cc\u0644\u06cc \u062a\u0631\u062a\u06cc\u0628 \u06a9\u0627 \u062e\u0627\u06a9\u06c1 \u062c\u0633 \u0645\u06cc\u06ba \u062f\u06a9\u06be\u0627\u06cc\u0627 \u06af\u06cc\u0627 \u06c1\u06d2 \u06a9\u06c1 Liquibase \u0644\u0627\u06a9 \u0679\u06cc\u0628\u0644 \u06a9\u0648 \u0686\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0644\u0627\u06a9 \u06a9\u0648 \u062d\u0627\u0635\u0644 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u063a\u06cc\u0631 \u0639\u0645\u0644 \u0634\u062f\u06c1 \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0648 \u0627\u0646\u062c\u0627\u0645 \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 Tomcat \u0634\u0631\u0648\u0639 \u06c1\u0648\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u0644\u0627\u06a9 \u06a9\u0648 \u062c\u0627\u0631\u06cc \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4\" style=\"display:block;margin:0 auto\" width=\"600\" height=\"400\" loading=\"lazy\" title=\"\"><\/p>\n<p>\u0622\u0626\u06cc\u06d2 \u0639\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u06a9\u0627 \u0633\u0631\u0627\u063a \u0644\u06af\u0627\u0626\u06cc\u06ba\u06d4 \u062c\u0628 Spring Boot Liquibase \u06a9\u0648 \u0634\u0631\u0648\u0639 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0679\u0648\u0644 \u0633\u0628 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u0644\u0627\u06a9 \u0679\u06cc\u0628\u0644 \u0633\u06d2 \u0627\u0633\u062a\u0641\u0633\u0627\u0631 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u062a\u0627\u06a9\u06c1 \u0627\u0633 \u0628\u0627\u062a \u06a9\u0648 \u06cc\u0642\u06cc\u0646\u06cc \u0628\u0646\u0627\u06cc\u0627 \u062c\u0627 \u0633\u06a9\u06d2 \u06a9\u06c1 \u0645\u0648\u062c\u0648\u062f\u06c1 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0645\u0646\u062a\u0642\u0644 \u06a9\u0631\u0646\u06d2 \u0648\u0627\u0644\u06cc \u06a9\u0648\u0626\u06cc \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0645\u062b\u0627\u0644 \u0645\u0648\u062c\u0648\u062f \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4 \u0627\u06af\u0631 \u0633\u0627\u062d\u0644 \u0635\u0627\u0641 \u06c1\u0648 \u062a\u0648 \u062a\u0627\u0644\u0627 \u0644\u06af\u0627 \u0644\u06cc\u06ba\u06d4 \u0627\u0633 \u06a9\u06d2 \u0628\u0639\u062f \u06cc\u06c1 \u0645\u0642\u0627\u0645\u06cc XML \u0641\u0627\u0626\u0644 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u06a9\u0631\u067e\u0679\u0648\u06af\u0631\u0627\u0641\u06a9 \u0686\u06cc\u06a9\u0633\u0645 \u06a9\u0627 \u062d\u0633\u0627\u0628 \u0644\u06af\u0627\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0633 \u06a9\u0627 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0631\u06cc\u06a9\u0627\u0631\u0688 \u0633\u06d2 \u0645\u0648\u0627\u0632\u0646\u06c1 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u06a9\u0633\u06cc \u0628\u06be\u06cc \u0686\u06be\u0648\u0679\u06cc \u06c1\u0648\u0626\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc \u06a9\u0648 \u0627\u0646\u062c\u0627\u0645 \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u0627\u0646 \u06a9\u0648 \u0644\u0627\u06af \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0622\u062e\u0631 \u0645\u06cc\u06ba\u060c Tomcat \u0648\u06cc\u0628 \u0633\u0631\u0648\u0631 \u06a9\u0648 \u063a\u06cc\u0631 \u0645\u0642\u0641\u0644 \u06a9\u0631\u06cc\u06ba \u062a\u0627\u06a9\u06c1 \u06cc\u06c1 \u0645\u062d\u0641\u0648\u0638 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u0634\u0631\u0648\u0639 \u06c1\u0648 \u0633\u06a9\u06d2\u06d4<\/p>\n<p>\u06cc\u06c1 \u0622\u0631\u0688\u0631 \u0627\u0633 \u0628\u0627\u062a \u06a9\u0648 \u06cc\u0642\u06cc\u0646\u06cc \u0628\u0646\u0627\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0622\u067e \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0635\u0627\u0631\u0641 \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u067e\u0631 \u06a9\u0627\u0631\u0631\u0648\u0627\u0626\u06cc \u0646\u06c1 \u06a9\u0631\u06d2 \u0627\u0633 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u06a9\u06c1 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u0635\u0627\u0631\u0641 \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u067e\u0631 \u06a9\u0627\u0631\u0631\u0648\u0627\u0626\u06cc \u06a9\u06d2 \u0644\u06cc\u06d2 \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u062a\u06cc\u0627\u0631 \u06c1\u0648\u06d4<\/p>\n<p>\u0622\u0626\u06cc\u06d2 \u0627\u0633 \u067e\u0631 \u0627\u06cc\u06a9 \u0646\u0638\u0631 \u0688\u0627\u0644\u062a\u06d2 \u06c1\u06cc\u06ba \u06a9\u06c1 \u06cc\u06c1 \u0631\u06cc\u06a9\u0627\u0631\u0688\u0632 \u0627\u0648\u0631 \u062a\u0627\u0644\u06d2 \u062f\u0631\u0627\u0635\u0644 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u0627\u0646\u062f\u0631 \u06c1\u06cc \u06a9\u06cc\u0633\u06d2 \u0646\u0638\u0631 \u0622\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0627\u0628 \u062c\u0628 \u06a9\u06c1 \u06c1\u0645 \u0646\u06d2 \u067e\u06c1\u0644\u06d2 H2 \u06a9\u0646\u0633\u0648\u0644 \u06a9\u0648 \u06a9\u0646\u0641\u06cc\u06af\u0631 \u06a9\u0631 \u0644\u06cc\u0627 \u06c1\u06d2\u060c \u06c1\u0645 \u062e\u0627\u0645 \u0645\u06cc\u0632\u0648\u06ba \u06a9\u0627 \u0645\u0639\u0627\u0626\u0646\u06c1 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u062c\u0628 \u0622\u067e \u06a9\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0686\u0644 \u0631\u06c1\u06cc \u06c1\u0648\u060c \u0627\u067e\u0646\u0627 \u0628\u0631\u0627\u0624\u0632\u0631 \u06a9\u06be\u0648\u0644\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0633 \u067e\u0631 \u062c\u0627\u0626\u06cc\u06ba: <code>http:\/\/localhost:8080\/h2-console<\/code>. JDBC URL \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u0648\u0626\u06d2 \u062c\u0691\u06cc\u06ba\u06d4 <code>jdbc:h2:file:.\/data\/employeedb<\/code> \u0635\u0627\u0631\u0641 \u0646\u0627\u0645 \u0633\u06d2 <code>sa<\/code> \u0627\u0648\u0631 \u0627\u06cc\u06a9 \u062e\u0627\u0644\u06cc \u067e\u0627\u0633 \u0648\u0631\u0688\u06d4<\/p>\n<p>\u0622\u067e \u0627\u0633 \u0645\u06cc\u06ba \u0627\u067e\u0646\u06d2 \u0622\u067e \u06a9\u0648 \u062f\u06cc\u06a9\u06be \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 <code>employees<\/code> \u0645\u06cc\u0632 \u0622\u067e Liquibase \u06a9\u06d2 \u0630\u0631\u06cc\u0639\u06c1 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u062a\u06cc\u0627\u0631 \u06a9\u0631\u062f\u06c1 \u062f\u0648 \u0627\u0636\u0627\u0641\u06cc \u0645\u06cc\u0632\u06cc\u06ba \u0628\u06be\u06cc \u062f\u06cc\u06a9\u06be \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 <code>DATABASECHANGELOG<\/code> \u0627\u0648\u0631 <code>DATABASECHANGELOGLOCK<\/code>.<\/p>\n<h3 id=\"heading-the-databasechangelog-table\">\u06a9\u06c1 <code>DATABASECHANGELOG<\/code> \u0645\u06cc\u0632<\/h3>\n<p>\u06cc\u06c1 \u062c\u062f\u0648\u0644 \u0622\u067e \u06a9\u06cc \u0646\u0642\u0644 \u0645\u06a9\u0627\u0646\u06cc \u06a9\u06cc \u062d\u06a9\u0645\u062a \u0639\u0645\u0644\u06cc \u06a9\u0627 \u0645\u0631\u06a9\u0632 \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0627\u0633 \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u06a9\u06cc \u06af\u0626\u06cc \u062a\u0645\u0627\u0645 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u06d2 \u0645\u0633\u062a\u0642\u0644 \u0644\u06cc\u062c\u0631 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u06af\u0631 \u0622\u067e \u0628\u06be\u0627\u06af\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 <code>SELECT * FROM DATABASECHANGELOG;<\/code>\u0622\u067e \u0627\u0633 \u0637\u0631\u062d \u0622\u0624\u0679 \u067e\u0679 \u062f\u06cc\u06a9\u06be\u06cc\u06ba \u06af\u06d2:<\/p>\n<table>\n<thead>\n<tr>\n<th>ID<\/th>\n<th>\u0645\u0635\u0646\u0641<\/th>\n<th>\u0641\u0627\u0626\u0644 \u06a9\u0627 \u0646\u0627\u0645<\/th>\n<th>\u0686\u0644\u0627\u0646\u06d2 \u06a9\u06cc \u062a\u0627\u0631\u06cc\u062e<\/th>\n<th>\u0622\u067e \u06a9\u0627 \u062d\u06a9\u0645 \u0628\u062c\u0627 \u0644\u0627\u06cc\u0627 \u06af\u06cc\u0627 \u06c1\u06d2\u06d4<\/th>\n<th>EXECTYPE<\/th>\n<th>MD5SUM<\/th>\n<th>\u0648\u0636\u0627\u062d\u062a<\/th>\n<th>\u062a\u0628\u0635\u0631\u06c1<\/th>\n<th>\u0679\u06cc\u06af<\/th>\n<th>Liquibase<\/th>\n<th>\u0633\u06cc\u0627\u0642 \u0648 \u0633\u0628\u0627\u0642<\/th>\n<th>\u0644\u06cc\u0628\u0644<\/th>\n<th>DEPLOYMENT_ID<\/th>\n<\/tr>\n<\/thead>\n<tbody wp_automatic_readability=\"4\">\n<tr wp_automatic_readability=\"8\">\n<td>1<\/td>\n<td>\u0627\u0634\u0648\u062a\u0648\u0634\u06a9\u0631\u06cc\u0633<\/td>\n<td>db\/changelog\/changes\/01-create-employees.xml<\/td>\n<td>2026-05-30 13:11:35.937919<\/td>\n<td>1<\/td>\n<td>\u067e\u06be\u0627\u0646\u0633\u06cc \u062f\u06cc \u06af\u0626\u06cc\u06d4<\/td>\n<td>9:66e7dcffb2b1902a4e9f01670cb5f192<\/td>\n<td>createTable tableName=\u0645\u0644\u0627\u0632\u0645<\/td>\n<td\/>\n<td><em>null<\/em><\/td>\n<td>4.31.1<\/td>\n<td><em>null<\/em><\/td>\n<td><em>null<\/em><\/td>\n<td>0126894849<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u0622\u0626\u06cc\u06d2 \u0633\u0628 \u0633\u06d2 \u0627\u06c1\u0645 \u06a9\u0627\u0644\u0645\u0648\u06ba \u06a9\u0627 \u062a\u062c\u0632\u06cc\u06c1 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<ul wp_automatic_readability=\"18.5\">\n<li wp_automatic_readability=\"3\">\n<p><strong>ID\u060c \u0645\u0635\u0646\u0641\u060c \u0641\u0627\u0626\u0644 \u06a9\u0627 \u0646\u0627\u0645:<\/strong> \u06cc\u06c1 \u062a\u06cc\u0646\u0648\u06ba \u06a9\u0627\u0644\u0645 \u0627\u06cc\u06a9 \u062c\u0627\u0645\u0639 \u06a9\u0644\u06cc\u062f \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0648\u06c1 \u0645\u0644 \u06a9\u0631 \u0645\u0646\u0641\u0631\u062f \u0637\u0648\u0631 \u067e\u0631 \u0627\u06cc\u06a9 \u06c1\u06cc \u06c1\u062c\u0631\u062a \u06a9\u06cc \u0634\u0646\u0627\u062e\u062a \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"-1\">\n<p><strong>\u0639\u0645\u0644\u062f\u0631\u0622\u0645\u062f \u06a9\u06cc \u062a\u0627\u0631\u06cc\u062e \u0627\u0648\u0631 \u062d\u06a9\u0645 \u067e\u0631 \u0639\u0645\u0644 \u062f\u0631\u0622\u0645\u062f \u06a9\u06cc \u062a\u0627\u0631\u06cc\u062e:<\/strong> \u06cc\u06c1 \u0622\u067e \u06a9\u0648 \u0628\u0627\u0644\u06a9\u0644 \u0628\u062a\u0627\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0627\u0633\u06a9\u0631\u067e\u0679 \u06a9\u0648 \u06a9\u0628 \u0627\u0648\u0631 \u06a9\u0633 \u062a\u0631\u062a\u06cc\u0628 \u0633\u06d2 \u0639\u0645\u0644 \u0645\u06cc\u06ba \u0644\u0627\u06cc\u0627 \u06af\u06cc\u0627 \u062a\u06be\u0627\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"4\">\n<p><strong>MD5 \u06a9\u0644:<\/strong> \u06cc\u06c1 XML \u0641\u0627\u0626\u0644 \u06a9\u0627 \u0627\u06cc\u06a9 \u06a9\u0631\u067e\u0679\u0648\u06af\u0631\u0627\u0641\u06a9 \u06c1\u06cc\u0634 \u06c1\u06d2\u06d4 \u062c\u0628 Liquibase \u0634\u0631\u0648\u0639 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u06cc\u06c1 \u0645\u0642\u0627\u0645\u06cc XML \u0641\u0627\u0626\u0644 \u06a9\u0648 \u06c1\u06cc\u0634 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0627\u0633 \u06a9\u0627 \u0627\u0633 \u06a9\u0627\u0644\u0645 \u0633\u06d2 \u0645\u0648\u0627\u0632\u0646\u06c1 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06af\u0631 \u0622\u067e \u0641\u0627\u0626\u0644 \u06a9\u0648 \u0686\u0644\u0627\u0646\u06d2 \u06a9\u06d2 \u0628\u0639\u062f \u062e\u0641\u06cc\u06c1 \u0637\u0648\u0631 \u067e\u0631 \u0627\u0633 \u0645\u06cc\u06ba \u062a\u0631\u0645\u06cc\u0645 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u06cc\u06c1 \u06c1\u06cc\u0634\u0632 \u0645\u0645\u0627\u062b\u0644 \u0646\u06c1\u06cc\u06ba \u06c1\u0648\u06ba \u06af\u06cc \u0627\u0648\u0631 Liquibase \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062d\u0641\u0627\u0638\u062a \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u0633\u0679\u0627\u0631\u0679 \u0627\u067e \u06a9\u0648 \u0631\u0648\u06a9 \u062f\u06d2 \u06af\u0627\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"4\">\n<p><strong>\u0645\u062b\u0627\u0644 \u06a9\u06cc \u0627\u0642\u0633\u0627\u0645:<\/strong> \u0632\u06cc\u0627\u062f\u06c1 \u062a\u0631 \u0645\u0639\u0627\u0645\u0644\u0627\u062a \u0645\u06cc\u06ba \u06cc\u06c1 \u0635\u0631\u0641 \u06a9\u06c1\u062a\u0627 \u06c1\u06d2: <code>EXECUTED<\/code>. \u062a\u0627\u06c1\u0645\u060c \u06cc\u06c1 \u0627\u06cc\u06a9 \u0627\u06c1\u0645 \u0622\u0688\u0679 \u0679\u0631\u06cc\u0644 \u0641\u0631\u0627\u06c1\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06af\u0631 \u0622\u067e \u062c\u0627\u0646 \u0628\u0648\u062c\u06be \u06a9\u0631 \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0648 \u0686\u06be\u0648\u0691 \u062f\u06cc\u062a\u06d2 \u06c1\u06cc\u06ba \u0627\u0648\u0631 Liquibase \u06a9\u0645\u0627\u0646\u0688 \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u0648\u0626\u06d2 \u0627\u0633\u06d2 \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u0644\u0627\u06af \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c <code>MARK_RAN<\/code>. \u0627\u06af\u0631 \u06c1\u062c\u0631\u062a \u06a9\u0648 \u0686\u06be\u0648\u0691 \u062f\u06cc\u0627 \u06af\u06cc\u0627 \u062a\u06be\u0627 \u06a9\u06cc\u0648\u0646\u06a9\u06c1 \u0627\u06cc\u06a9 \u0634\u0631\u0637 \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u06af\u0626\u06cc \u062a\u06be\u06cc\u060c \u062a\u0648 \u0622\u067e \u062f\u0631\u062c \u0630\u06cc\u0644 \u062f\u06cc\u06a9\u06be\u06cc\u06ba \u06af\u06d2: <code>SKIPPED<\/code>.<\/p>\n<\/li>\n<li wp_automatic_readability=\"6\">\n<p><strong>\u0679\u06cc\u06af:<\/strong> \u0627\u0633\u06d2 \u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06af\u0679 \u0679\u06cc\u06af \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u0633\u0648\u0686\u06cc\u06ba\u06d4 Liquibase \u06a9\u0648 \u06a9\u0633\u06cc \u0628\u0691\u06d2 \u06c1\u0627\u0626\u06cc \u0631\u0633\u06a9 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0645\u0648\u062c\u0648\u062f\u06c1 \u062d\u0627\u0644\u062a \u06a9\u0648 &quot;\u0679\u06cc\u06af&#8221; \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06a9\u0646\u0641\u06cc\u06af\u0631 \u06a9\u06cc\u0627 \u062c\u0627 \u0633\u06a9\u062a\u0627 \u06c1\u06d2\u060c \u062c\u06cc\u0633\u06d2 <code>v1.4.0<\/code>)\u06d4 \u0627\u06af\u0631 \u0622\u067e \u06a9\u06cc \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u062a\u0646\u0642\u06cc\u062f\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u062c\u0627\u062a\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u0627\u06cc\u06a9 \u0631\u0648\u0644 \u0628\u06cc\u06a9 \u06a9\u0645\u0627\u0646\u0688 \u062c\u0627\u0631\u06cc \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba \u062c\u0648 Liquibase \u06a9\u0648 \u0628\u0639\u062f \u0645\u06cc\u06ba \u0644\u0627\u06af\u0648 \u06c1\u0648\u0646\u06d2 \u0648\u0627\u0644\u06cc \u062a\u0645\u0627\u0645 \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u06a9\u0627\u0644\u0639\u062f\u0645 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u06c1\u062f\u0627\u06cc\u062a \u06a9\u0631\u062a\u06cc \u06c1\u06d2\u06d4 <code>v1.4.0<\/code> \u0679\u06cc\u06af<\/p>\n<\/li>\n<li wp_automatic_readability=\"3\">\n<p><strong>\u0633\u06cc\u0627\u0642 \u0648 \u0633\u0628\u0627\u0642:<\/strong> \u0627\u0633 \u0637\u0631\u062d \u0622\u067e \u0645\u0627\u062d\u0648\u0644 \u0633\u06d2 \u0645\u062a\u0639\u0644\u0642 \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0627 \u0646\u0638\u0645 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 ChangeSet \u0645\u06cc\u06ba \u0633\u06cc\u0627\u0642 \u0648 \u0633\u0628\u0627\u0642 \u06a9\u06cc \u062e\u0635\u0648\u0635\u06cc\u0627\u062a \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u060c \u062c\u06cc\u0633\u06d2 <code><changeset id=\"7\" author=\"ashutoshkrris\" context=\"dev, qa\"\/><\/code>)\u060c \u0648\u06c1 \u06c1\u062c\u0631\u062a \u0635\u0631\u0641 \u0627\u0633 \u0635\u0648\u0631\u062a \u0645\u06cc\u06ba \u0686\u0644\u06d2 \u06af\u06cc \u062c\u0628 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u0633\u0679\u0627\u0631\u0679 \u0627\u067e \u06a9\u06d2 \u0648\u0642\u062a &quot;dev&#8221; \u06cc\u0627 &quot;qa&#8221; \u06a9\u0648 Liquibase \u0645\u06cc\u06ba \u0645\u0646\u062a\u0642\u0644 \u06a9\u0631\u06d2\u06d4 \u067e\u06cc\u062f\u0627\u0648\u0627\u0631 \u0627\u0633 \u06a9\u0648 \u0646\u0638\u0631 \u0627\u0646\u062f\u0627\u0632 \u06a9\u0631\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"3\">\n<p><strong>\u0644\u06cc\u0628\u0644:<\/strong> \u062c\u0628\u06a9\u06c1 \u0633\u06cc\u0627\u0642 \u0648 \u0633\u0628\u0627\u0642 \u0645\u0627\u062d\u0648\u0644 \u06a9\u0648 \u0646\u0634\u0627\u0646\u06c1 \u0628\u0646\u0627\u062a\u0627 \u06c1\u06d2\u060c \u0644\u06cc\u0628\u0644 \u0679\u0627\u0633\u06a9 \u06a9\u06d2 \u0632\u0645\u0631\u06d2 \u06a9\u0648 \u0646\u0634\u0627\u0646\u06c1 \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u062c\u06cc\u0631\u0627 \u0679\u06a9\u0679 \u0646\u0645\u0628\u0631 (<code>issue-842<\/code>) \u06cc\u0627 \u0631\u06cc\u0644\u06cc\u0632 \u0679\u0631\u06cc\u0646 (<code>Q3-release<\/code>)\u06d4 \u06cc\u06c1 \u0627\u0639\u0644\u06cc \u062f\u0631\u062c\u06d2 \u06a9\u06cc \u0679\u06cc\u0645\u0648\u06ba \u06a9\u0648 \u0628\u0627\u0642\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0645\u062a\u0627\u062b\u0631 \u06a9\u06cc\u06d2 \u0628\u063a\u06cc\u0631 \u0641\u0639\u0627\u0644\u06cc\u062a \u06a9\u06d2 \u0645\u062e\u0635\u0648\u0635 \u0630\u06cc\u0644\u06cc \u0633\u06cc\u0679\u0648\u06ba \u06a9\u0648 \u0645\u0646\u062a\u062e\u0628 \u0637\u0648\u0631 \u067e\u0631 \u0686\u0644\u0627\u0646\u06d2 \u06cc\u0627 \u0631\u0648\u0644 \u0628\u06cc\u06a9 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0627\u062c\u0627\u0632\u062a \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-the-databasechangeloglock-table\">\u06a9\u06c1 <code>DATABASECHANGELOGLOCK<\/code> \u0645\u06cc\u0632<\/h3>\n<p>\u0627\u06af\u0631\u0686\u06c1 \u06cc\u06c1 \u0645\u06cc\u0632 \u0686\u06be\u0648\u0679\u0627 \u06c1\u06d2\u060c \u0644\u06cc\u06a9\u0646 \u06cc\u06c1 \u062c\u062f\u06cc\u062f \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc\u0648\u06ba \u0645\u06cc\u06ba \u0628\u06c1\u062a \u0628\u0691\u0627 \u06a9\u0631\u062f\u0627\u0631 \u0627\u062f\u0627 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u06af\u0631 \u0622\u067e \u0628\u06be\u0627\u06af\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 <code>SELECT * FROM DATABASECHANGELOGLOCK;<\/code>\u0627\u06cc\u06a9 \u0642\u0637\u0627\u0631 \u0638\u0627\u06c1\u0631 \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<table>\n<thead>\n<tr>\n<th>ID<\/th>\n<th>\u0645\u0642\u0641\u0644<\/th>\n<th>\u0644\u0627\u06a9 \u062f\u06cc\u0627 \u06af\u06cc\u0627\u06d4<\/th>\n<th>\u0645\u0642\u0641\u0644<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>1<\/td>\n<td>\u062c\u06be\u0648\u0679<\/td>\n<td><em>null<\/em><\/td>\n<td><em>null<\/em><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u062a\u0635\u0648\u0631 \u06a9\u0631\u06cc\u06ba \u06a9\u06c1 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u06a9\u0628\u0631\u0646\u06cc\u0679\u0633 \u06a9\u0644\u0633\u0679\u0631 \u0645\u06cc\u06ba \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u0631\u0646\u0627 \u06c1\u06d2\u06d4 Kubernetes \u06a9\u0648 \u06c1\u062f\u0627\u06cc\u062a \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0648\u06c1 \u0628\u06cc\u06a9 \u0648\u0642\u062a \u062a\u06cc\u0646 \u0627\u06cc\u06a9 \u062c\u06cc\u0633\u06d2 \u0648\u0627\u0642\u0639\u0627\u062a \u06a9\u0648 \u06af\u06be\u0645\u0627\u0626\u06cc\u06ba\u06d4 \u062a\u06cc\u0646\u0648\u06ba \u0645\u062b\u0627\u0644\u06cc\u06ba \u0628\u0627\u0644\u06a9\u0644 \u0627\u0633\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0633\u06d2 \u062c\u0691\u062a\u06cc \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u0627\u06af\u0631 \u0622\u067e \u062a\u06cc\u0646\u0648\u06ba \u0645\u062b\u0627\u0644\u0648\u06ba \u06a9\u0648 \u0686\u0644\u0627\u0646\u06d2 \u06a9\u06cc \u06a9\u0648\u0634\u0634 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 <code>CREATE TABLE<\/code> \u0628\u0627\u0644\u06a9\u0644 \u0627\u0633\u06cc \u0645\u0644\u06cc \u0633\u06cc\u06a9\u0646\u0688 \u0645\u06cc\u06ba \u0645\u0646\u062a\u0642\u0644\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u06c1\u0645 \u0622\u06c1\u0646\u06af\u06cc \u06a9\u06cc \u062e\u0631\u0627\u0628\u06cc \u06a9\u0627 \u0633\u0628\u0628 \u0628\u0646\u06d2 \u06af\u06cc\u06d4 \u0644\u0627\u06a9 \u0679\u06cc\u0628\u0644 \u0627\u0633 \u06a9\u0648 \u0631\u0648\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0633\u06cc\u0679 \u062a\u06a9 \u067e\u06c1\u0646\u0686\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u067e\u06c1\u0644\u06cc \u0645\u062b\u0627\u0644 <code>LOCKED<\/code> \u06a9\u0648 <code>TRUE<\/code>. \u062f\u06cc\u06af\u0631 \u062f\u0648 \u0645\u062b\u0627\u0644\u06cc\u06ba \u0645\u06cc\u0632 \u06a9\u0648 \u0686\u06cc\u06a9 \u06a9\u0631\u06cc\u06ba\u060c \u0644\u0627\u06a9 \u0686\u06cc\u06a9 \u06a9\u0631\u06cc\u06ba\u060c \u0627\u0648\u0631 \u0634\u0627\u0626\u0633\u062a\u06af\u06cc \u0633\u06d2 \u0627\u0646\u062a\u0638\u0627\u0631 \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<p><strong>\u0679\u0631\u0628\u0644 \u0634\u0648\u0679\u0646\u06af \u06a9\u06cc \u0639\u0645\u0644\u06cc \u062a\u062c\u0627\u0648\u06cc\u0632:<\/strong> \u0628\u0639\u0636 \u0627\u0648\u0642\u0627\u062a \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc\u0627\u06ba \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u0633\u06a9\u062a\u06cc \u06c1\u06cc\u06ba (\u0633\u0631\u0648\u0631 \u0637\u0627\u0642\u062a \u06a9\u06be\u0648 \u0633\u06a9\u062a\u0627 \u06c1\u06d2)\u06d4 \u0627\u06af\u0631 \u0627\u06cc\u0633\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u062a\u0648\u060c Liquibase \u0633\u06cc\u0679 \u0627\u067e \u06c1\u0648\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u06c1\u06cc \u0645\u0631 \u0633\u06a9\u062a\u0627 \u06c1\u06d2\u06d4 <code>LOCKED<\/code> \u062f\u0648\u0628\u0627\u0631\u06c1 <code>FALSE<\/code>.<\/p>\n<p>\u0627\u06af\u0644\u06cc \u0628\u0627\u0631 \u062c\u0628 \u0622\u067e \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba \u06af\u06d2\u060c \u0644\u0627\u06af \u063a\u06cc\u0631 \u0645\u0639\u06cc\u0646\u06c1 \u0645\u062f\u062a \u062a\u06a9 \u0645\u0646\u062c\u0645\u062f \u06c1\u0648\u062c\u0627\u0626\u06d2 \u06af\u0627 \u0627\u0648\u0631 \u067e\u06be\u0631 \u062f\u06c1\u0631\u0627\u0626\u06cc\u06ba \u06af\u06d2: <code>Waiting for changelog lock....<\/code><\/p>\n<p>\u0627\u06af\u0631 \u0622\u067e \u06a9\u0648 \u06cc\u0642\u06cc\u0646 \u06c1\u06d2 \u06a9\u06c1 \u0641\u06cc \u0627\u0644\u062d\u0627\u0644 \u06a9\u0648\u0626\u06cc \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06c1\u062c\u0631\u062a \u0646\u06c1\u06cc\u06ba \u06a9\u0631 \u0631\u06c1\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0644\u0627\u0626\u0646\u0679 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0633\u0627\u062f\u06c1 SQL \u06a9\u0645\u0627\u0646\u0688 \u0686\u0644\u0627 \u06a9\u0631 \u0627\u0633 \u0645\u0633\u0626\u0644\u06d2 \u06a9\u0648 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 \u062d\u0644 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<pre><code class=\"language-sql\">UPDATE DATABASECHANGELOGLOCK SET LOCKED = FALSE;\n<\/code><\/pre>\n<p>\u06cc\u06c1 \u0644\u0627\u06a9 \u06a9\u0648 \u0632\u0628\u0631\u062f\u0633\u062a\u06cc \u06a9\u06be\u0648\u0644\u06d2 \u06af\u0627 \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0627\u062c\u0627\u0632\u062a \u062f\u06d2 \u06af\u0627\u06d4<\/p>\n<h2 id=\"heading-evolving-the-employee-api\">\u0627\u06cc\u0645\u067e\u0644\u0627\u0626\u06cc API \u06a9\u0627 \u0627\u0631\u062a\u0642\u0627\u0621<\/h2>\n<p>\u0633\u0627\u0641\u0679 \u0648\u06cc\u0626\u0631 \u06a9\u0628\u06be\u06cc \u062e\u062a\u0645 \u0646\u06c1\u06cc\u06ba \u06c1\u0648\u062a\u0627\u06d4 \u06a9\u0627\u0645\u06cc\u0627\u0628 \u0648\u0631\u0698\u0646 1 \u06a9\u06cc \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u06a9\u06d2 \u062f\u0648 \u06c1\u0641\u062a\u06d2 \u0628\u0639\u062f\u060c \u06a9\u0627\u0631\u0648\u0628\u0627\u0631\u06cc \u0679\u06cc\u0645 \u0646\u0626\u06cc \u0636\u0631\u0648\u0631\u06cc\u0627\u062a \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0648\u0627\u067e\u0633 \u0622\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u0628 \u062c\u0628 \u06a9\u06c1 \u0622\u067e \u0633\u0645\u062c\u06be \u06af\u0626\u06d2 \u06c1\u06cc\u06ba \u06a9\u06c1 Liquibase \u0631\u06cc\u06a9\u0627\u0631\u0688\u0632 \u06a9\u0648 \u06a9\u06cc\u0633\u06d2 \u0679\u0631\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u062a\u06cc\u0627\u0631 \u06a9\u0631\u0646\u0627 \u0622\u0633\u0627\u0646 \u06c1\u06d2\u06d4 \u0628\u0633 \u0645\u0627\u0633\u0679\u0631 \u0644\u0633\u0679 \u0645\u06cc\u06ba \u0646\u0626\u06cc \u200b\u200b\u0641\u0627\u0626\u0644\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<h3 id=\"heading-version-2-adding-an-email-field\">\u0648\u0631\u0698\u0646 2: \u0627\u06cc \u0645\u06cc\u0644 \u0641\u06cc\u0644\u0688 \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u06d4<\/h3>\n<p>\u0622\u067e \u06a9\u06cc HR \u0679\u06cc\u0645 \u06a9\u0648 \u0622\u067e \u06a9\u06d2 \u0645\u0644\u0627\u0632\u0645\u06cc\u0646 \u062a\u06a9 \u067e\u06c1\u0646\u0686\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4 \u0645\u062c\u06be\u06d2 \u0627\u06cc\u06a9 \u0627\u06cc \u0645\u06cc\u0644 \u06a9\u0627\u0644\u0645 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4<\/p>\n<p>\u062f\u0631\u062c \u0630\u06cc\u0644 \u062c\u06af\u06c1 \u067e\u0631 \u0627\u06cc\u06a9 \u0646\u0626\u06cc \u0641\u0627\u0626\u0644 \u0628\u0646\u0627\u0626\u06cc\u06ba: <code>src\/main\/resources\/db\/changelog\/changes\/02-add-employee-email.xml<\/code>:<\/p>\n<pre><code class=\"language-xml\"><?xml version=\"1.0\" encoding=\"UTF-8\"?????>\n<databasechangelog xmlns=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\" xsi:schemalocation=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\n        http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\/dbchangelog-4.20.xsd\">\n\n    <changeset id=\"2\" author=\"ashutoshkrris\">\n        <addcolumn tablename=\"employees\">\n            <column name=\"email\" type=\"VARCHAR(100)\">\n                <constraints nullable=\"false\" unique=\"true\"\/>\n            <\/column>\n        <\/addcolumn>\n    <\/changeset>\n\n<\/databasechangelog>\n<\/code><\/pre>\n<p>\u06cc\u06c1 \u0622\u067e \u06a9\u0627 \u06c1\u06d2\u06d4 <code>db.changelog-master.xml<\/code> \u0641\u0627\u0626\u0644 \u06a9\u0648 \u067e\u06c1\u0644\u06d2 \u0634\u0627\u0645\u0644 \u06a9\u06d2 \u0628\u0627\u0644\u06a9\u0644 \u0646\u06cc\u0686\u06d2 \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<pre><code class=\"language-xml\"><include file=\"db\/changelog\/changes\/02-add-employee-email.xml\"\/>\n<\/code><\/pre>\n<p>\u062c\u0628 \u0622\u067e \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 Liquibase \u062f\u0631\u062c \u0630\u06cc\u0644 \u06a9\u0648 \u0686\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2: <code>DATABASECHANGELOG<\/code> \u0645\u06cc\u0632 \u06cc\u06c1 \u062f\u06cc\u06a9\u06be\u062a\u0627 \u06c1\u06d2 <code>id=\"1\"<\/code> \u06cc\u06c1 \u067e\u06c1\u0644\u06d2 \u0633\u06d2 \u0645\u0648\u062c\u0648\u062f \u06c1\u06d2\u060c \u0644\u06c1\u0630\u0627 \u0627\u0633\u06d2 \u0686\u06be\u0648\u0691 \u062f\u06cc\u06ba\u06d4 \u06cc\u06c1 \u062f\u06cc\u06a9\u06be\u062a\u0627 \u06c1\u06d2 <code>id=\"2\"<\/code> \u0686\u0648\u0646\u06a9\u06c1 \u06cc\u06c1 \u063a\u0627\u0626\u0628 \u06c1\u06d2\u060c \u06c1\u0645 \u0627\u0633\u06d2 \u0686\u0644\u0627\u062a\u06d2 \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u0679\u0631\u06cc\u06a9\u0646\u06af \u0679\u06cc\u0628\u0644 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0646\u0626\u06cc \u0642\u0637\u0627\u0631 \u0634\u0627\u0645\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<h3 id=\"heading-version-3-adding-departments-support\">\u0648\u0631\u0698\u0646 3: \u0688\u067e\u0627\u0631\u0679\u0645\u0646\u0679 \u0633\u067e\u0648\u0631\u0679 \u0634\u0627\u0645\u0644 \u06a9\u06cc\u0627 \u06af\u06cc\u0627\u06d4<\/h3>\n<p>\u06a9\u0645\u067e\u0646\u06cc \u0628\u0691\u06be \u0631\u06c1\u06cc \u06c1\u06d2\u06d4 \u0627\u0628 \u0645\u0644\u0627\u0632\u0645\u06cc\u0646 \u06a9\u0627 \u062a\u0639\u0644\u0642 \u0645\u062d\u06a9\u0645\u0648\u06ba \u0633\u06d2 \u06c1\u06d2\u06d4 \u062a\u0645 \u06c1\u0648 <code>departments<\/code> \u0627\u06cc\u06a9 \u0645\u06cc\u0632 \u0627\u0648\u0631 \u0627\u06cc\u06a9 \u063a\u06cc\u0631 \u0645\u0644\u06a9\u06cc \u06a9\u0644\u06cc\u062f\u06cc \u0631\u06a9\u0627\u0648\u0679 \u062c\u0648 \u062f\u0648\u0646\u0648\u06ba \u06a9\u0648 \u062c\u0648\u0691\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>\u0628\u0646\u0627\u0646\u0627 <code>03-add-departments.xml<\/code>:<\/p>\n<pre><code class=\"language-xml\"><?xml version=\"1.0\" encoding=\"UTF-8\"?????>\n<databasechangelog xmlns=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\" xsi:schemalocation=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\n        http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\/dbchangelog-4.20.xsd\">\n\n    <changeset id=\"3\" author=\"ashutoshkrris\">\n        <createtable tablename=\"departments\">\n            <column name=\"id\" type=\"BIGINT\" autoincrement=\"true\">\n                <constraints primarykey=\"true\" nullable=\"false\"\/>\n            <\/column>\n            <column name=\"name\" type=\"VARCHAR(50)\">\n                <constraints nullable=\"false\" unique=\"true\"\/>\n            <\/column>\n        <\/createtable>\n    <\/changeset>\n\n    <changeset id=\"4\" author=\"ashutoshkrris\">\n        <addcolumn tablename=\"employees\">\n            <column name=\"department_id\" type=\"BIGINT\"\/>\n        <\/addcolumn>\n        <addforeignkeyconstraint basetablename=\"employees\" basecolumnnames=\"department_id\" constraintname=\"fk_employee_department\" referencedtablename=\"departments\" referencedcolumnnames=\"id\"\/>\n    <\/changeset>\n\n<\/databasechangelog>\n<\/code><\/pre>\n<p>\u0646\u0648\u0679 \u06a9\u0631\u06cc\u06ba \u06a9\u06c1 \u0645\u06cc\u06ba \u0646\u06d2 \u0627\u06cc\u06a9 \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u062f\u0648 \u0627\u0644\u06af \u0627\u0644\u06af ChangeSets \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u06cc\u06d2 \u06c1\u06cc\u06ba\u06d4 \u06cc\u06c1 \u0628\u06c1\u062a\u0631\u06cc\u0646 \u0639\u0645\u0644 \u06c1\u06d2\u06d4 \u06c1\u0631 ChangeSet \u0627\u06cc\u06a9 \u0645\u0646\u0637\u0642\u06cc \u0639\u0645\u0644 \u06a9\u06cc \u0646\u0645\u0627\u0626\u0646\u062f\u06af\u06cc \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06af\u0631 \u063a\u06cc\u0631 \u0645\u0644\u06a9\u06cc \u06a9\u0644\u06cc\u062f \u06a9\u06cc \u062a\u062e\u0644\u06cc\u0642 (id=&#8221;4&#8243;) \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u062c\u0627\u062a\u06cc \u06c1\u06d2 \u062a\u0648\u060c \u0688\u06cc\u067e\u0627\u0631\u0679\u0645\u0646\u0679 \u0679\u06cc\u0628\u0644 \u06a9\u06cc \u062a\u062e\u0644\u06cc\u0642 (id=&#8221;3&#8243;) \u06a9\u0648 \u0627\u0628 \u0628\u06be\u06cc \u06a9\u0627\u0645\u06cc\u0627\u0628 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u0631\u06cc\u06a9\u0627\u0631\u0688 \u06a9\u06cc\u0627 \u062c\u0627\u0626\u06d2 \u06af\u0627 \u0627\u0648\u0631 \u0635\u0631\u0641 id=&#8221;4&#8243; \u06a9\u0648 \u0631\u0648\u0644 \u0628\u06cc\u06a9 \u06a9\u06cc\u0627 \u062c\u0627\u0626\u06d2 \u06af\u0627\u06d4<\/p>\n<h3 id=\"heading-version-4-amp-5-employee-status-and-performance-indexes\">\u0648\u0631\u0698\u0646 4 \u0627\u0648\u0631 5: \u0645\u0644\u0627\u0632\u0645 \u06a9\u06cc \u062d\u06cc\u062b\u06cc\u062a \u0627\u0648\u0631 \u06a9\u0627\u0631\u06a9\u0631\u062f\u06af\u06cc \u06a9\u06d2 \u0627\u0634\u0627\u0631\u06d2<\/h3>\n<p>\u0622\u062e\u0631 \u0645\u06cc\u06ba\u060c HR \u0641\u0639\u0627\u0644 \u0627\u0648\u0631 \u063a\u06cc\u0631 \u0641\u0639\u0627\u0644 \u0645\u0644\u0627\u0632\u0645\u06cc\u0646 \u06a9\u0648 \u0679\u0631\u06cc\u06a9 \u06a9\u0631\u0646\u0627 \u0686\u0627\u06c1\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0679\u06cc\u0645 \u06a9\u0648 \u0645\u0639\u0644\u0648\u0645 \u06c1\u0648 \u0631\u06c1\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0622\u062e\u0631\u06cc \u0646\u0627\u0645 \u0633\u06d2 \u062a\u0644\u0627\u0634 \u06a9\u0631\u0646\u0627 \u0633\u0633\u062a \u06c1\u06d2\u06d4<\/p>\n<p>\u0628\u0646\u0627\u0646\u0627 <code>04-status-and-indexes.xml<\/code>:<\/p>\n<pre><code class=\"language-xml\"><?xml version=\"1.0\" encoding=\"UTF-8\"?????>\n<databasechangelog xmlns=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\" xsi:schemalocation=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\n        http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\/dbchangelog-4.20.xsd\">\n\n    <changeset id=\"3\" author=\"ashutoshkrris\">\n        <createtable tablename=\"departments\">\n            <column name=\"id\" type=\"BIGINT\" autoincrement=\"true\">\n                <constraints primarykey=\"true\" nullable=\"false\"\/>\n            <\/column>\n            <column name=\"name\" type=\"VARCHAR(50)\">\n                <constraints nullable=\"false\" unique=\"true\"\/>\n            <\/column>\n        <\/createtable>\n    <\/changeset>\n\n    <changeset id=\"4\" author=\"ashutoshkrris\">\n        <addcolumn tablename=\"employees\">\n            <column name=\"department_id\" type=\"BIGINT\"\/>\n        <\/addcolumn>\n        <addforeignkeyconstraint basetablename=\"employees\" basecolumnnames=\"department_id\" constraintname=\"fk_employee_department\" referencedtablename=\"departments\" referencedcolumnnames=\"id\"\/>\n    <\/changeset>\n\n<\/databasechangelog>\n<\/code><\/pre>\n<p>\u062a\u0645\u0627\u0645 \u0646\u0626\u06cc \u0641\u0627\u0626\u0644\u06cc\u06ba <code>db.changelog-master.xml<\/code>. \u0634\u0627\u0645\u0644 \u0628\u06cc\u0627\u0646\u0627\u062a \u06a9\u06cc \u062a\u0631\u062a\u06cc\u0628 \u0648\u06c1\u06cc \u062a\u0631\u062a\u06cc\u0628 \u06c1\u06d2 \u062c\u0633 \u0645\u06cc\u06ba Liquibase \u0627\u0646 \u067e\u0631 \u0639\u0645\u0644 \u062f\u0631\u0622\u0645\u062f \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<h2 id=\"heading-the-golden-rule-never-modify-executed-changesets\">\u0633\u0646\u06c1\u0631\u06cc \u0627\u0635\u0648\u0644: \u067e\u06be\u0627\u0646\u0633\u06cc \u0634\u062f\u06c1 \u062a\u0628\u062f\u06cc\u0644\u06cc \u0633\u06cc\u0679 \u0645\u06cc\u06ba \u06a9\u0628\u06be\u06cc \u0628\u06be\u06cc \u062a\u0631\u0645\u06cc\u0645 \u0646\u06c1 \u06a9\u0631\u06cc\u06ba\u06d4<\/h2>\n<p>\u0628\u0627\u0644\u0622\u062e\u0631\u060c \u0622\u067e \u06a9\u06cc \u0679\u06cc\u0645 \u06a9\u06d2 \u0688\u0648\u06cc\u0644\u067e\u0631\u0632 \u06a9\u0631\u06cc\u06ba \u06af\u06d2\u06d4 <code>01-create-employees.xml<\/code> \u0627\u067e\u0646\u06cc \u0641\u0627\u0626\u0644 \u062c\u0645\u0639 \u06a9\u0631\u0648\u0627\u0626\u06cc\u06ba \u0627\u0648\u0631 \u0627\u067e\u0646\u06cc \u063a\u0644\u0637\u06cc\u0648\u06ba \u06a9\u0627 \u0646\u0648\u0679\u0633 \u0644\u06cc\u06ba\u06d4 \u0634\u0627\u06cc\u062f \u0627\u0646\u06c1\u0648\u06ba \u0646\u06d2 \u06a9\u0627\u0644\u0645 \u06a9\u06d2 \u0646\u0627\u0645 \u0645\u06cc\u06ba \u0679\u0627\u0626\u067e\u0646\u06af \u06a9\u06cc \u063a\u0644\u0637\u06cc \u067e\u0627\u0626\u06cc \u06cc\u0627 \u0645\u062d\u0633\u0648\u0633 \u06a9\u06cc\u0627 \u06a9\u06c1 \u06a9\u0627\u0644\u0645 \u0645\u06cc\u06ba \u06a9\u0648\u0626\u06cc \u0633\u062e\u062a \u063a\u06cc\u0631 null \u0631\u06a9\u0627\u0648\u0679 \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4<\/p>\n<p>\u0645\u0639\u06cc\u0627\u0631\u06cc \u062c\u0627\u0648\u0627 \u06a9\u0648\u0688 \u0644\u06a9\u06be\u0646\u06d2 \u06a9\u06d2 \u0633\u0627\u0644\u0648\u06ba \u067e\u0631 \u0645\u0628\u0646\u06cc \u0627\u0646 \u06a9\u06cc \u062c\u0628\u0644\u062a\u060c \u0627\u0633 XML \u0641\u0627\u0626\u0644 \u06a9\u0648 \u06a9\u06be\u0648\u0644\u0646\u0627\u060c \u063a\u0644\u0637\u06cc \u06a9\u0648 \u062f\u0631\u0633\u062a \u06a9\u0631\u0646\u0627\u060c \u0641\u0627\u0626\u0644 \u06a9\u0648 \u0645\u062d\u0641\u0648\u0638 \u06a9\u0631\u0646\u0627 \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u0646\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0622\u0626\u06cc\u06d2 \u0627\u0635\u0644 \u0645\u06cc\u06ba \u0627\u0633 \u06a9\u06cc \u06a9\u0648\u0634\u0634 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 \u062f\u06cc\u06a9\u06be\u06cc\u06ba \u06a9\u06c1 \u06a9\u06cc\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0622\u067e \u06a9\u0627 <code>src\/main\/resources\/db\/changelog\/changes\/01-create-employees.xml<\/code> \u0641\u0627\u0626\u0644 \u062a\u0628\u062f\u06cc\u0644\u06cc <code>first_name<\/code> \u06af\u0631\u0645\u06cc <code>given_name<\/code>:<\/p>\n<pre><code class=\"language-xml\"><column name=\"given_name\" type=\"VARCHAR(50)\">\n    <constraints nullable=\"false\"\/>\n<\/column>\n<\/code><\/pre>\n<p>\u0641\u0627\u0626\u0644 \u06a9\u0648 \u0645\u062d\u0641\u0648\u0638 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 \u0627\u067e\u0646\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<p>\u0627\u06cc\u06a9 \u06c1\u0645\u0648\u0627\u0631 \u0622\u063a\u0627\u0632 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2\u060c \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0641\u0648\u0631\u06cc \u0637\u0648\u0631 \u067e\u0631 \u06a9\u0631\u06cc\u0634 \u06c1\u0648 \u062c\u0627\u062a\u06cc \u06c1\u06d2 \u0627\u0648\u0631 \u0679\u0631\u0645\u06cc\u0646\u0644 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0628\u06c1\u062a \u0628\u0691\u0627 \u0627\u0633\u0679\u06cc\u06a9 \u0679\u0631\u06cc\u0633 \u067e\u06cc\u062f\u0627 \u06a9\u0631\u062a\u06cc \u06c1\u06d2\u06d4 \u062e\u0631\u0627\u0628\u06cc \u06a9\u06d2 \u0644\u0627\u06af \u06a9\u06d2 \u0627\u0648\u067e\u0631\u06cc \u062d\u0635\u06d2 \u06a9\u0648 \u0642\u0631\u06cc\u0628 \u0633\u06d2 \u062f\u06cc\u06a9\u06be\u06cc\u06ba\u06d4 \u0622\u067e \u06a9\u0648 \u06cc\u06c1 \u062f\u0631\u0633\u062a \u067e\u06cc\u063a\u0627\u0645 \u0646\u0638\u0631 \u0622\u0626\u06d2 \u06af\u0627:<\/p>\n<pre><code class=\"language-shell\">Caused by: liquibase.exception.ValidationFailedException: Validation Failed:\n     1 changesets check sum\n          db\/changelog\/changes\/01-create-employees.xml::1::ashutoshkrris was: 9:66e7dcffb2b1902a4e9f01670cb5f192 but is now: 9:2bd3ef21343d3b5c9448cc50bc35deef\n<\/code><\/pre>\n<p>\u0627\u06cc\u0633\u0627 \u06a9\u06cc\u0648\u06ba \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u0627\u0633 \u06a9\u06cc \u0648\u062c\u06c1 \u06cc\u06c1 \u06c1\u06d2: \u062c\u0628 \u0627\u06cc\u06a9 ChangeSet \u06a9\u0633\u06cc \u0645\u0627\u062d\u0648\u0644 \u06a9\u06d2 \u062e\u0644\u0627\u0641 \u0686\u0644\u0627\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u06cc\u06c1 \u0627\u06cc\u06a9 \u0646\u0627\u0642\u0627\u0628\u0644 \u062a\u063a\u06cc\u0631 \u0631\u06cc\u06a9\u0627\u0631\u0688 \u0628\u0646 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4 \u0645\u0627\u0636\u06cc \u06a9\u0648 \u062a\u0628\u062f\u06cc\u0644 \u0646\u06c1\u06cc\u06ba \u06a9\u06cc\u0627 \u062c\u0627 \u0633\u06a9\u062a\u0627\u06d4<\/p>\n<p>\u062c\u0628 Liquibase \u0634\u0631\u0648\u0639 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u06cc\u06c1 \u0645\u0642\u0627\u0645\u06cc XML \u0641\u0627\u0626\u0644 \u06a9\u06d2 \u0627\u06cc\u06a9 \u06a9\u0631\u067e\u0679\u0648\u06af\u0631\u0627\u0641\u06a9 \u06c1\u06cc\u0634 (MD5 checksum) \u06a9\u0627 \u062d\u0633\u0627\u0628 \u0644\u06af\u0627\u062a\u0627 \u06c1\u06d2\u06d4 \u067e\u06be\u0631 <code>DATABASECHANGELOG<\/code> \u0627\u06cc\u06a9 \u0679\u06cc\u0628\u0644 \u0628\u0646\u0627\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0646\u0626\u06cc \u06a9\u06cc\u0644\u06a9\u0648\u0644\u06cc\u0634\u0646 \u06a9\u06cc \u06af\u0626\u06cc \u06c1\u06cc\u0634 \u06a9\u0627 \u0645\u0648\u0627\u0632\u0646\u06c1 \u0627\u0633 \u06c1\u06cc\u0634 \u0633\u06d2 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u062c\u0628 \u0641\u0627\u0626\u0644 \u067e\u06c1\u0644\u06cc \u0628\u0627\u0631 \u0686\u0644\u0627\u0626\u06cc \u06af\u0626\u06cc \u062a\u06be\u06cc\u06d4<\/p>\n<p>\u067e\u06c1\u0644\u06d2 \u0633\u06d2 \u0639\u0645\u0644\u062f\u0631\u0622\u0645\u062f \u0634\u062f\u06c1 \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u06a9\u0631\u06cc\u06a9\u0679\u0631 \u06a9\u0648 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u0646\u06d2 \u0633\u06d2 \u06c1\u06cc\u0634 \u0628\u062f\u0644 \u062c\u0627\u0626\u06d2 \u06af\u06cc\u06d4 Liquibase \u0686\u06be\u06cc\u0691 \u0686\u06be\u0627\u0691 \u06a9\u0627 \u067e\u062a\u06c1 \u0644\u06af\u0627\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0634\u0631\u0648\u0639 \u06a9\u0631\u0646\u06d2 \u0633\u06d2 \u0627\u0646\u06a9\u0627\u0631 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0622\u067e \u06a9\u06d2 \u0688\u06cc\u0679\u0627 \u06a9\u06cc \u062d\u0641\u0627\u0638\u062a \u06a9\u06d2 \u0644\u06cc\u06d2 \u06c1\u06d2\u06d4 \u0627\u06af\u0631 \u0622\u067e \u06a9\u0627 XML \u06a9\u0648\u0688 \u0638\u0627\u06c1\u0631 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u06a9\u0627\u0644\u0645 \u06a9\u06d2 \u0646\u0627\u0645 \u0628\u062a\u0627\u0626\u06d2 \u06af\u0626\u06d2 \u06c1\u06cc\u06ba: <code>first_name<\/code> \u062a\u0627\u06c1\u0645\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0635\u0644 \u0645\u06cc\u06ba \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u0648\u0626\u06d2 \u0628\u0646\u0627\u06cc\u0627 \u06af\u06cc\u0627 \u062a\u06be\u0627: <code>fist_name<\/code>Spring Data JPA \u0630\u062e\u06cc\u0631\u06c1 \u0628\u06c1\u0631\u062d\u0627\u0644 \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u062c\u0627\u0626\u06d2 \u06af\u0627\u06d4<\/p>\n<h3 id=\"heading-how-to-fix-it-the-right-way\">\u0645\u0633\u0626\u0644\u06c1 \u062d\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u0627 \u0637\u0631\u06cc\u0642\u06c1 (\u0635\u062d\u06cc\u062d \u0637\u0631\u06cc\u0642\u06c1)<\/h3>\n<p>\u0627\u06af\u0631 \u0622\u067e \u0645\u0642\u0627\u0645\u06cc \u0637\u0648\u0631 \u067e\u0631 \u06cc\u06c1 \u063a\u0644\u0637\u06cc \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u062c\u0627 \u06a9\u0631 \u0642\u0637\u0627\u0631 \u06a9\u0648 \u062d\u0630\u0641 \u06a9\u0631\u0646\u0627 \u0686\u0627\u06c1\u06cc\u06ba \u06af\u06d2\u06d4 <code>DATABASECHANGELOG<\/code> \u0628\u0631\u0627\u06c1 \u06a9\u0631\u0645 \u0627\u06cc\u06a9 \u0679\u06cc\u0628\u0644 \u0645\u0646\u062a\u062e\u0628 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 \u062f\u0648\u0628\u0627\u0631\u06c1 \u06a9\u0648\u0634\u0634 \u06a9\u0631\u06cc\u06ba\u06d4 \u0627\u06cc\u0633\u0627 \u0645\u062a \u06a9\u0631\u0648\u06d4 \u0627\u06cc\u06a9 \u0628\u0627\u0631 \u062c\u0628 \u06cc\u06c1 \u06a9\u0648\u0688 \u0633\u0679\u06cc\u062c\u0646\u06af \u06cc\u0627 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u062a\u06a9 \u067e\u06c1\u0646\u0686 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0633\u0631\u0648\u0631 \u067e\u0631 \u0642\u0637\u0627\u0631\u0648\u06ba \u06a9\u0648 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 \u062d\u0630\u0641 \u0646\u06c1\u06cc\u06ba \u06a9\u0631 \u067e\u0627\u0626\u06cc\u06ba \u06af\u06d2\u06d4<\/p>\n<p>\u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u06cc \u063a\u0644\u0637\u06cc\u0648\u06ba \u06a9\u0648 \u0679\u06be\u06cc\u06a9 \u06a9\u0631\u0646\u06d2 \u06a9\u0627 \u0635\u062d\u06cc\u062d \u0637\u0631\u06cc\u0642\u06c1 \u062f\u0631\u062c \u0630\u06cc\u0644 \u06c1\u06d2: <strong>\u0622\u06af\u06d2 \u0628\u0691\u06be\u0648<\/strong>.<\/p>\n<p>\u067e\u06c1\u0644\u06d2 \u0627\u067e\u0646\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u06a9\u0627\u0644\u0639\u062f\u0645 \u06a9\u0631\u06cc\u06ba\u06d4 <code>01-create-employees.xml<\/code> \u06c1\u06cc\u0634 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u062e\u0644\u0627\u0641 \u0645\u0645\u0627\u062b\u0644 \u06c1\u06d2\u06d4 \u0627\u0633 \u06a9\u06d2 \u0628\u0639\u062f \u06c1\u0645 \u062a\u0631\u0645\u06cc\u0645 \u06a9\u0648 \u0644\u0627\u06af\u0648 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0646\u06cc\u0627 ChangeSet \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<pre><code class=\"language-xml\"><changeset id=\"7\" author=\"ashutosh\">\n    <renamecolumn tablename=\"employees\" oldcolumnname=\"first_name\" newcolumnname=\"given_name\" columndatatype=\"VARCHAR(50)\"\/>\n<\/changeset>\n<\/code><\/pre>\n<p>\u0645\u0627\u0633\u0679\u0631 \u062a\u0628\u062f\u06cc\u0644\u06cc \u0644\u0627\u06af \u0645\u06cc\u06ba \u0627\u0633 \u06a9\u0648 \u0634\u0627\u0645\u0644 \u06a9\u0631\u0646\u0627 \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u0646\u0627 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0645\u062d\u0641\u0648\u0638 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u062f\u0631\u0633\u062a \u062d\u0627\u0644\u062a \u0645\u06cc\u06ba \u0644\u06d2 \u062c\u0627\u0626\u06d2 \u06af\u0627\u06d4<\/p>\n<h2 id=\"heading-working-with-seed-data\">\u0628\u06cc\u062c \u0688\u06cc\u0679\u0627 \u0622\u067e\u0631\u06cc\u0634\u0646\u0632<\/h2>\n<p>\u0628\u0639\u0636 \u0627\u0648\u0642\u0627\u062a \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u0648 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0645\u0641\u06cc\u062f \u06c1\u0648\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u0628\u062a\u062f\u0627\u0626\u06cc \u0688\u06cc\u0679\u0627 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>\u0645\u062b\u0627\u0644 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u0648\u0631\u0698\u0646 3 \u0645\u06cc\u06ba <code>departments<\/code> \u0645\u06cc\u0632 \u0645\u06cc\u0632 \u0627\u0628 \u0628\u0627\u0644\u06a9\u0644 \u062e\u0627\u0644\u06cc \u06c1\u06d2\u06d4 \u062c\u0628 \u0646\u0626\u06d2 \u0688\u0648\u06cc\u0644\u067e\u0631\u0632 \u0631\u06cc\u067e\u0648\u0632\u0679\u0631\u06cc \u06a9\u0648 \u06a9\u0644\u0648\u0646 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u06a9\u0648 \u0645\u0642\u0627\u0645\u06cc \u0637\u0648\u0631 \u067e\u0631 \u06af\u06be\u0645\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0627\u0646\u06c1\u06cc\u06ba \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 SQL \u0644\u06a9\u06be\u0646\u0627 \u067e\u0691\u062a\u0627 \u06c1\u06d2\u06d4 <code>INSERT<\/code> API \u06a9\u06cc \u062c\u0627\u0646\u0686 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0628\u06cc\u0627\u0646\u0627\u062a\u06d4<\/p>\n<p>\u0622\u067e \u0627\u067e\u0646\u06cc \u0646\u0642\u0644 \u0645\u06a9\u0627\u0646\u06cc \u06a9\u06cc \u062d\u06a9\u0645\u062a \u0639\u0645\u0644\u06cc \u06a9\u06d2 \u062d\u0635\u06d2 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u0628\u06cc\u0633 \u0644\u0627\u0626\u0646 \u0688\u06cc\u0679\u0627 \u0627\u0646\u062f\u0631\u0627\u062c\u0627\u062a \u0628\u0646\u0627 \u06a9\u0631 \u0627\u0633\u06d2 \u062e\u0648\u062f\u06a9\u0627\u0631 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u062f\u0631\u062c \u0630\u06cc\u0644 \u062c\u06af\u06c1 \u067e\u0631 \u0627\u06cc\u06a9 \u0646\u0626\u06cc \u0641\u0627\u0626\u0644 \u0628\u0646\u0627\u0626\u06cc\u06ba: <code>src\/main\/resources\/db\/changelog\/changes\/05-seed-departments.xml<\/code>:<\/p>\n<pre><code class=\"language-xml\"><?xml version=\"1.0\" encoding=\"UTF-8\"?????>\n<databasechangelog xmlns=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\" xsi:schemalocation=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\n        http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\/dbchangelog-4.20.xsd\">\n\n    <changeset id=\"8\" author=\"ashutoshkrris\">\n        \n            <column name=\"name\" value=\"Engineering\"\/>\n        <\/insert>\n        \n            <column name=\"name\" value=\"Human Resources\"\/>\n        <\/insert>\n        \n            <column name=\"name\" value=\"Finance\"\/>\n        <\/insert>\n    <\/changeset>\n\n<\/databasechangelog>\n<\/code><\/pre>\n<p>\u0628\u06cc\u0627\u0646 \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba <code>db.changelog-master.xml<\/code> \u0641\u0627\u0626\u0644 \u062c\u0628 \u0622\u067e \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba \u06af\u06d2\u060c \u062a\u0648 Liquibase \u0627\u0646 \u0642\u0637\u0627\u0631\u0648\u06ba \u06a9\u0648 \u062f\u0627\u062e\u0644 \u06a9\u0631\u06d2 \u06af\u0627\u06d4 \u0622\u067e \u06a9\u0627 API \u0627\u0628 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u06d2 \u0644\u06cc\u06d2 \u062a\u06cc\u0627\u0631 \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-the-danger-of-data-migrations\">\u0688\u06cc\u0679\u0627 \u06a9\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u06d2 \u062e\u0637\u0631\u0627\u062a<\/h3>\n<p>\u0688\u06cc\u0679\u0627 \u0633\u06cc\u0688\u0646\u06af \u0637\u0627\u0642\u062a\u0648\u0631 \u06c1\u06d2\u060c \u0644\u06cc\u06a9\u0646 \u0646\u0638\u0645 \u0648 \u0636\u0628\u0637 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4 \u06cc\u06c1\u0627\u06ba \u0627\u0646\u06af\u0648\u0679\u06be\u06d2 \u06a9\u06d2 \u06a9\u0686\u06be \u0639\u0645\u0644\u06cc \u0627\u0646\u062c\u06cc\u0646\u0626\u0631\u0646\u06af \u0627\u0635\u0648\u0644 \u06c1\u06cc\u06ba:<\/p>\n<p><strong>Liquibase \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u06cc\u06ba:<\/strong><\/p>\n<ul wp_automatic_readability=\"0\">\n<li wp_automatic_readability=\"1\">\n<p>\u062c\u0627\u0645\u062f \u062a\u0644\u0627\u0634 \u06a9\u06cc \u0645\u06cc\u0632\u06cc\u06ba (\u0627\u0633\u0679\u06cc\u0679\u0633 \u06a9\u0648\u0688\u060c \u0645\u0644\u06a9 \u06a9\u06cc \u0641\u06c1\u0631\u0633\u062a\u060c \u0688\u06cc\u0641\u0627\u0644\u0679 \u0688\u06cc\u067e\u0627\u0631\u0679\u0645\u0646\u0679)<\/p>\n<\/li>\n<li wp_automatic_readability=\"-1\">\n<p>\u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u0628\u0648\u0679 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0633\u0633\u0679\u0645 \u06a9\u0646\u0641\u06cc\u06af\u0631\u06cc\u0634\u0646 \u062c\u06be\u0646\u0688\u0648\u06ba \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<\/ul>\n<p><strong>\u062f\u0631\u062c \u0630\u06cc\u0644 \u0635\u0648\u0631\u062a\u0648\u06ba \u0645\u06cc\u06ba Liquibase \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u0646\u06c1 \u06a9\u0631\u06cc\u06ba:<\/strong><\/p>\n<ul wp_automatic_readability=\"0\">\n<li wp_automatic_readability=\"-1\">\n<p>\u06c1\u0645 \u062c\u0627\u0646\u0686 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06c1\u0632\u0627\u0631\u0648\u06ba \u062c\u0639\u0644\u06cc \u0635\u0627\u0631\u0641\u06cc\u0646 \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"1\">\n<p>\u0644\u06cc\u0646 \u062f\u06cc\u0646 \u06a9\u06d2 \u0627\u0639\u062f\u0627\u062f \u0648 \u0634\u0645\u0627\u0631 \u06a9\u06cc \u0628\u0691\u06cc \u0645\u0642\u062f\u0627\u0631 \u06a9\u0648 \u0645\u0646\u062a\u0642\u0644 \u06a9\u0631\u06cc\u06ba (\u0645\u062b\u0644\u0627\u064b 5 \u0645\u0644\u06cc\u0646 \u0631\u06cc\u06a9\u0627\u0631\u0688\u0632 \u06a9\u0648 \u0627\u06cc\u06a9 \u0679\u06cc\u0628\u0644 \u0633\u06d2 \u062f\u0648\u0633\u0631\u06d2 \u0645\u06cc\u06ba \u0645\u0646\u062a\u0642\u0644 \u06a9\u0631\u0646\u0627)<\/p>\n<\/li>\n<\/ul>\n<p>\u0688\u06cc\u0679\u0627 \u06a9\u06cc \u0628\u0691\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0679\u06cc\u0628\u0644\u0632 \u06a9\u0648 \u06a9\u0626\u06cc \u06af\u06be\u0646\u0679\u0648\u06ba \u06a9\u06d2 \u0644\u06cc\u06d2 \u0645\u0642\u0641\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u0627 \u0633\u0628\u0628 \u0628\u0646 \u0633\u06a9\u062a\u06cc \u06c1\u06d2\u06d4 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646 \u06a9\u0648\u0631 \u0679\u06cc\u0628\u0644\u0632 \u06a9\u0648 \u0644\u0627\u06a9 \u06a9\u0631\u0646\u06d2 \u0633\u06d2 \u0622\u067e \u06a9\u06cc \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u0628\u0691\u06d2 \u067e\u06cc\u0645\u0627\u0646\u06d2 \u067e\u0631 \u0628\u0646\u062f\u0634 \u06a9\u0627 \u0633\u0627\u0645\u0646\u0627 \u06a9\u0631\u0646\u0627 \u067e\u0691\u06d2 \u06af\u0627\u06d4 \u0633\u06a9\u06cc\u0645\u0627 \u0688\u06be\u0627\u0646\u0686\u06c1 \u0627\u0648\u0631 \u0636\u0631\u0648\u0631\u06cc \u0628\u06cc\u0633 \u0644\u0627\u0626\u0646 \u0688\u06cc\u0679\u0627 \u067e\u0631 \u0686\u06cc\u0646\u062c \u0633\u06cc\u0679 \u067e\u0631 \u062a\u0648\u062c\u06c1 \u062f\u06cc\u06ba\u06d4 \u0628\u06be\u0627\u0631\u06cc \u0688\u06cc\u0679\u0627 \u06c1\u06cc\u0631\u0627 \u067e\u06be\u06cc\u0631\u06cc \u06a9\u06d2 \u0644\u06cc\u06d2 \u0633\u0631\u0634\u0627\u0631 \u0627\u0633\u06a9\u0631\u067e\u0679\u0633 \u06cc\u0627 \u0628\u06cc\u06a9 \u06af\u0631\u0627\u0624\u0646\u0688 \u0679\u0627\u0633\u06a9 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<h2 id=\"heading-rollbacks\">\u0631\u0648\u0644 \u0628\u06cc\u06a9<\/h2>\n<p>\u0627\u06cc\u06a9 \u0628\u06c1\u062a\u0631\u06cc\u0646 \u062f\u0646\u06cc\u0627 \u0645\u06cc\u06ba\u060c \u0622\u067e \u06a9\u0627 \u06a9\u0648\u0688 \u06c1\u0645\u06cc\u0634\u06c1 \u06a9\u0627\u0645 \u06a9\u0631\u06d2 \u06af\u0627\u06d4 \u0639\u0645\u0644\u06cc \u0637\u0648\u0631 \u067e\u0631\u060c \u0622\u067e \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u062c\u0648 \u067e\u06cc\u062f\u0627\u0648\u0627\u0631 \u06a9\u06d2 \u0627\u06c1\u0645 \u0633\u0648\u0627\u0644\u0627\u062a \u06cc\u0627 \u06a9\u0631\u067e\u0679 \u0688\u06cc\u0679\u0627 \u06a9\u0648 \u062a\u0648\u0691 \u062f\u06cc\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u062c\u0628 \u0627\u06cc\u0633\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u062a\u0648 \u0645\u062c\u06be\u06d2 \u0627\u0646\u0688\u0648 \u0628\u0679\u0646 \u06a9\u0648 \u062f\u0628\u0627\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0637\u0631\u06cc\u0642\u06c1 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>Liquibase \u0631\u0648\u0644 \u0628\u06cc\u06a9\u0633 \u06a9\u0648 \u0633\u067e\u0648\u0631\u0679 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0644\u06cc\u06a9\u0646 \u0622\u067e \u06a9\u0648 \u06cc\u06c1 \u0633\u0645\u062c\u06be\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2 \u06a9\u06c1 \u0627\u0646 \u06a9\u06cc \u062a\u0634\u0631\u06cc\u062d \u06a9\u06cc\u0633\u06d2 \u06a9\u06cc \u062c\u0627\u0626\u06d2\u06d4<\/p>\n<h3 id=\"heading-automatic-vs-explicit-rollbacks\">\u062e\u0648\u062f\u06a9\u0627\u0631 \u0627\u0648\u0631 \u0648\u0627\u0636\u062d \u0631\u0648\u0644 \u0628\u06cc\u06a9<\/h3>\n<p>\u0628\u06c1\u062a \u0633\u06d2 Liquibase \u06a9\u0645\u0627\u0646\u0688\u0632 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0627\u0644\u0679 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0645\u062b\u0627\u0644 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631\u060c \u0627\u06af\u0631 \u0622\u067e \u0627\u0633 \u0637\u0631\u062d \u0627\u06cc\u06a9 ChangeSet \u0644\u06a9\u06be\u062a\u06d2 \u06c1\u06cc\u06ba: <code><createtable\/><\/code> \u06cc\u0627 <code><addcolumn\/><\/code>Liquibase \u0648\u0627\u0636\u062d \u0637\u0648\u0631 \u067e\u0631 \u062c\u0627\u0646\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u06a9\u0627\u0644\u0645 \u06a9\u0648 \u0634\u0627\u0645\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0628\u0631\u0639\u06a9\u0633 \u06a9\u0627\u0644\u0645 \u06a9\u0648 \u062d\u0630\u0641 \u06a9\u0631\u0646\u0627 \u06c1\u06d2\u06d4 \u0622\u067e \u06a9\u0648 \u06cc\u06c1 \u0628\u062a\u0627\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u0646\u06c1\u06cc\u06ba \u06c1\u06d2 \u06a9\u06c1 \u0627\u0646 \u06a9\u0627\u0631\u0631\u0648\u0627\u0626\u06cc\u0648\u06ba \u06a9\u0648 \u06a9\u06cc\u0633\u06d2 \u06a9\u0627\u0644\u0639\u062f\u0645 \u06a9\u06cc\u0627 \u062c\u0627\u0626\u06d2\u06d4<\/p>\n<p>\u062a\u0627\u06c1\u0645\u060c \u06a9\u0686\u06be \u0622\u067e\u0631\u06cc\u0634\u0646\u0632 \u0645\u0648\u0631\u0648\u062b\u06cc \u0637\u0648\u0631 \u067e\u0631 \u062a\u0628\u0627\u06c1 \u06a9\u0646 \u06cc\u0627 \u0645\u0628\u06c1\u0645 \u06c1\u0648\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0627\u067e\u0646\u06cc \u0645\u0631\u0636\u06cc \u06a9\u06d2 \u0645\u0637\u0627\u0628\u0642 \u06a9\u0628 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u06cc\u06ba\u06d4 <code><sql\/><\/code> \u0679\u06cc\u06af\u0632 \u06cc\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u06cc\u06ba\u06d4 <code><droptable\/><\/code>Liquibase \u0688\u06cc\u0679\u0627 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0645\u062d\u0641\u0648\u0638 \u06a9\u0631\u0646\u06d2 \u06a9\u0627 \u0637\u0631\u06cc\u0642\u06c1 \u0646\u06c1\u06cc\u06ba \u062c\u0627\u0646\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u0646 \u0635\u0648\u0631\u062a\u0648\u06ba \u0645\u06cc\u06ba\u060c \u0648\u0627\u0636\u062d \u0631\u0648\u0644 \u0628\u06cc\u06a9 \u06c1\u062f\u0627\u06cc\u0627\u062a \u0641\u0631\u0627\u06c1\u0645 \u06a9\u06cc \u062c\u0627\u0646\u06cc \u0686\u0627\u06c1\u0626\u06cc\u06ba\u06d4<\/p>\n<p>\u0622\u0626\u06cc\u06d2 \u0627\u06cc\u06a9 \u0627\u06cc\u0633\u06d2 \u0645\u0646\u0638\u0631 \u0646\u0627\u0645\u06d2 \u06a9\u06cc \u062a\u0642\u0644\u06cc\u062f \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u062c\u06c1\u0627\u06ba \u06c1\u0645 \u0627\u06cc\u06a9 \u0639\u0627\u0631\u0636\u06cc \u0631\u0633\u0627\u0626\u06cc \u06a9\u0648\u0688 \u06a9\u0627\u0644\u0645 \u0634\u0627\u0645\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0644\u06cc\u06a9\u0646 \u0645\u06cc\u06ba \u06cc\u06c1 \u062c\u0627\u0646\u0646\u0627 \u0686\u0627\u06c1\u062a\u0627 \u06c1\u0648\u06ba \u06a9\u06c1 \u0627\u0633\u06d2 \u0645\u062d\u0641\u0648\u0638 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u06a9\u06cc\u0633\u06d2 \u06c1\u0679\u0627\u06cc\u0627 \u062c\u0627\u0626\u06d2\u06d4<\/p>\n<p>\u0628\u0646\u0627\u0646\u0627 <code>06-temporary-access.xml<\/code>:<\/p>\n<pre><code class=\"language-xml\"><?xml version=\"1.0\" encoding=\"UTF-8\"?????>\n<databasechangelog xmlns=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\" xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\" xsi:schemalocation=\"http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\n        http:\/\/www.liquibase.org\/xml\/ns\/dbchangelog\/dbchangelog-4.20.xsd\">\n\n    <changeset id=\"9\" author=\"ashutosh\">\n        <addcolumn tablename=\"employees\">\n            <column name=\"temp_access_code\" type=\"VARCHAR(10)\"\/>\n        <\/addcolumn>\n        \n        <rollback>\n            <dropcolumn tablename=\"employees\" columnname=\"temp_access_code\"\/>\n        <\/rollback>\n    <\/changeset>\n\n<\/databasechangelog>\n<\/code><\/pre>\n<p>\u0627\u0633\u06d2 \u0627\u067e\u0646\u06cc \u0645\u0627\u0633\u0679\u0631 \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0686\u0644\u0627\u0626\u06cc\u06ba\u06d4 \u0627\u06cc\u06a9 \u06a9\u0627\u0644\u0645 \u0634\u0627\u0645\u0644 \u06a9\u06cc\u0627 \u06af\u06cc\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u06af\u0631 \u0622\u067e \u0627\u0633\u06d2 \u0627\u067e\u0646\u06cc CI\/CD \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 \u06a9\u06d2 \u0630\u0631\u06cc\u0639\u06d2 \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u062c\u0627\u062a\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e Liquibase Maven \u06a9\u0645\u0627\u0646\u0688 \u06a9\u0648 \u0627\u06cc\u06a9 \u0645\u062e\u0635\u0648\u0635 \u062a\u0639\u062f\u0627\u062f \u06a9\u06d2 \u0630\u0631\u06cc\u0639\u06d2 \u0648\u0627\u067e\u0633 \u0631\u0648\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0645\u062a\u062d\u0631\u06a9 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062c\u06cc\u0633\u06d2 <code>mvn liquibase:rollback -Dliquibase.rollbackCount=1<\/code>) \u06cc\u0627 \u0622\u067e \u0627\u06cc\u06a9 \u0645\u062e\u0635\u0648\u0635 \u0679\u06cc\u06af \u067e\u0631 \u0648\u0627\u067e\u0633 \u062c\u0627 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba \u062c\u06cc\u0633\u0627 \u06a9\u06c1 \u067e\u06c1\u0644\u06d2 \u0628\u0627\u062a \u06a9\u06cc \u06af\u0626\u06cc \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-the-reality-check-on-rollbacks\">\u0631\u0648\u0644 \u0628\u06cc\u06a9\u0633 \u067e\u0631 \u062d\u0642\u06cc\u0642\u062a \u06a9\u06cc \u062c\u0627\u0646\u0686<\/h3>\n<p>\u06cc\u06c1 \u062c\u0627\u0646\u0646\u0627 \u0636\u0631\u0648\u0631\u06cc \u06c1\u06d2 \u06a9\u06c1 \u0631\u0648\u0644 \u0628\u06cc\u06a9\u0633 \u06a9\u06cc\u0633\u06d2 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u0644\u06cc\u06a9\u0646 \u0628\u06cc\u06a9 \u0627\u06cc\u0646\u0688 \u0627\u0646\u062c\u06cc\u0646\u0626\u0631\u0646\u06af \u06a9\u06cc \u0627\u0635\u0644 \u062f\u0646\u06cc\u0627 \u06cc\u06c1 \u06c1\u06d2: <strong>\u0631\u0648\u0644 \u0628\u06cc\u06a9\u0633 \u067e\u0631 \u0627\u06a9\u062b\u0631 \u062a\u0628\u0627\u062f\u0644\u06c1 \u062e\u06cc\u0627\u0644 \u06a9\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u060c \u0644\u06cc\u06a9\u0646 \u067e\u06cc\u062f\u0627\u0648\u0627\u0631\u06cc \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u0634\u0627\u0630 \u0648 \u0646\u0627\u062f\u0631 \u06c1\u06cc \u0635\u0627\u0641 \u0633\u062a\u06be\u0631\u0627 \u06a9\u0627\u0645 \u06a9\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4<\/strong><\/p>\n<p>\u06a9\u0627\u0644\u0645 \u06a9\u0648 \u062d\u0630\u0641 \u06a9\u0631\u0646\u0627 \u0631\u06cc\u0627\u0636\u06cc \u06a9\u06d2 \u0644\u062d\u0627\u0638 \u0633\u06d2 \u0622\u0633\u0627\u0646 \u06c1\u06d2\u06d4 15 \u0645\u0646\u0679 \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646 \u0627\u0633 \u06a9\u0627\u0644\u0645 \u0645\u06cc\u06ba \u0631\u06cc\u06a9\u0627\u0631\u0688 \u06a9\u0631\u062f\u06c1 \u06a9\u0633\u0679\u0645\u0631 \u0688\u06cc\u0679\u0627 \u06a9\u0648 \u0628\u0627\u0632\u06cc\u0627\u0641\u062a \u06a9\u0631\u0646\u0627 \u0646\u0627\u0642\u0627\u0628\u0644 \u06cc\u0642\u06cc\u0646 \u062d\u062f \u062a\u06a9 \u0645\u0634\u06a9\u0644 \u06c1\u06d2 \u06a9\u06c1 \u063a\u0644\u0637 \u06a9\u0648\u0688 \u0645\u0648\u062c\u0648\u062f \u062a\u06be\u0627\u06d4<\/p>\n<p>\u0627\u0633 \u06a9\u06cc \u0648\u062c\u06c1 \u0633\u06d2\u060c \u062c\u062f\u06cc\u062f \u0627\u0646\u062c\u06cc\u0646\u0626\u0631\u0646\u06af \u0679\u06cc\u0645\u06cc\u06ba \u0627\u06a9\u062b\u0631 &quot;\u0631\u0648\u0644 \u0641\u0627\u0631\u0648\u0631\u0688&#8221; \u062d\u06a9\u0645\u062a \u0639\u0645\u0644\u06cc \u06a9\u0648 \u062a\u0631\u062c\u06cc\u062d \u062f\u06cc\u062a\u06cc \u06c1\u06cc\u06ba\u06d4 \u0627\u06af\u0631 \u06c1\u062c\u0631\u062a \u0633\u06d2 \u06a9\u0648\u0626\u06cc \u0645\u0633\u0626\u0644\u06c1 \u067e\u06cc\u062f\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u062e\u0648\u0641\u0646\u0627\u06a9 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0631\u0648\u0644 \u0628\u06cc\u06a9 \u06a9\u0645\u0627\u0646\u0688 \u062c\u0627\u0631\u06cc \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2\u060c \u0622\u067e \u0641\u0648\u0631\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0627\u06cc\u06a9 \u0646\u06cc\u0627 \u062a\u0628\u062f\u06cc\u0644\u06cc \u0633\u06cc\u0679 \u0628\u0646\u0627\u062a\u06d2 \u06c1\u06cc\u06ba \u062c\u0648 \u0645\u0633\u0626\u0644\u06c1 \u06a9\u0648 \u062d\u0644 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 (\u062c\u06cc\u0633\u06d2 \u06af\u0645\u0634\u062f\u06c1 \u0627\u0646\u0688\u06cc\u06a9\u0633 \u06a9\u0648 \u0634\u0627\u0645\u0644 \u06a9\u0631\u0646\u0627 \u06cc\u0627 \u06a9\u0633\u06cc \u0631\u06a9\u0627\u0648\u0679 \u06a9\u0648 \u06a9\u0645 \u06a9\u0631\u0646\u0627) \u0627\u0648\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<p>\u0688\u06cc\u0679\u0627\u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u0627\u0636\u0627\u0641\u06cc \u0627\u0648\u0631 \u063a\u06cc\u0631 \u062a\u0628\u0627\u06c1 \u06a9\u0646 \u0628\u0646\u0627\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0688\u06cc\u0632\u0627\u0626\u0646 \u06a9\u0631\u0646\u0627 \u0628\u06c1\u062a\u0631 \u06c1\u06d2 \u062a\u0627\u06a9\u06c1 \u067e\u06c1\u0644\u06d2 \u067e\u06cc\u0686\u06cc\u062f\u06c1 \u0631\u0648\u0644 \u0628\u06cc\u06a9\u0633 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u0646\u06c1 \u06c1\u0648\u06d4<\/p>\n<h2 id=\"heading-common-beginner-mistakes\">\u0639\u0627\u0645 \u0627\u0628\u062a\u062f\u0627\u0626\u06cc \u063a\u0644\u0637\u06cc\u0627\u06ba<\/h2>\n<p>\u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0648\u0631\u0698\u0646 \u06a9\u0646\u0679\u0631\u0648\u0644 \u06a9\u0648 \u0627\u067e\u0646\u0627\u0646\u0627 \u06a9\u0633\u06cc \u0628\u06be\u06cc \u0627\u0646\u062c\u06cc\u0646\u0626\u0631\u0646\u06af \u0679\u06cc\u0645 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0628\u0691\u0627 \u0642\u062f\u0645 \u06c1\u06d2\u060c \u0644\u06cc\u06a9\u0646 \u06cc\u06c1 \u0633\u06cc\u06a9\u06be\u0646\u06d2 \u06a9\u06d2 \u0645\u0646\u062d\u0646\u06cc \u062e\u0637\u0648\u0637 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0622\u062a\u0627 \u06c1\u06d2\u06d4 \u062c\u0628 \u0688\u0648\u06cc\u0644\u067e\u0631\u0632 \u0688\u06be\u06cc\u0644\u06d2 SQL \u0627\u0633\u06a9\u0631\u067e\u0679 \u0644\u06a9\u06be\u0646\u06d2 \u0633\u06d2 Liquibase \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0637\u0631\u0641 \u0645\u0646\u062a\u0642\u0644 \u06c1\u0648\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0648\u06c1 \u06a9\u0686\u06be \u067e\u06cc\u0634\u06cc\u0646 \u06af\u0648\u0626\u06cc \u06a9\u0631\u0646\u06d2 \u0648\u0627\u0644\u06d2 \u0646\u0642\u0635\u0627\u0646\u0627\u062a \u0645\u06cc\u06ba \u067e\u0691 \u062c\u0627\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u06cc\u06c1\u0627\u06ba \u0633\u0628 \u0633\u06d2 \u0639\u0627\u0645 \u063a\u0644\u0637\u06cc\u0627\u06ba \u06c1\u06cc\u06ba \u062c\u0648 \u0627\u0628\u062a\u062f\u0627\u0626\u06cc \u0627\u0641\u0631\u0627\u062f \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0646 \u0633\u06d2 \u06a9\u06cc\u0633\u06d2 \u0628\u0686\u0646\u0627 \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-1-the-mega-changeset\">1. &quot;\u0645\u06cc\u06af\u0627&#8221; \u062a\u0631\u0645\u06cc\u0645 \u0633\u06cc\u0679<\/h3>\n<p>\u0634\u0631\u0648\u0639 \u06c1\u0648\u0646\u06d2 \u067e\u0631\u060c \u06cc\u06c1 \u0627\u06cc\u06a9 XML \u0641\u0627\u0626\u0644 \u06a9\u06d2 \u062a\u062d\u062a \u067e\u0648\u0631\u06d2 \u0627\u0628\u062a\u062f\u0627\u0626\u06cc \u0633\u06a9\u06cc\u0645\u0627 \u06a9\u0648 \u0627\u06cc\u06a9 \u0648\u0627\u062d\u062f XML \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u067e\u06be\u06cc\u0646\u06a9\u0646\u06d2 \u06a9\u06d2 \u0644\u0626\u06d2 \u067e\u0631\u06a9\u0634\u0634 \u06c1\u06d2\u06d4 <code>changeSet<\/code>. \u0622\u067e \u0648\u06c1\u0627\u06ba 15 \u0688\u0627\u0644 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 <code>createTable<\/code> \u0628\u06cc\u0627\u0646 \u0627\u0648\u0631 20 <code>addForeignKeyConstraint<\/code> \u0628\u06cc\u0627\u0646 <code>id=\"1\"<\/code>.<\/p>\n<p>\u06cc\u06c1 \u0633\u0627\u062f\u06c1 \u0648\u062c\u06c1 \u0633\u06d2 \u0627\u06cc\u06a9 \u062e\u0648\u0641\u0646\u0627\u06a9 \u062e\u06cc\u0627\u0644 \u06c1\u06d2 \u062c\u0633 \u06a9\u06cc \u0648\u062c\u06c1 \u0633\u06d2 \u06cc\u06c1 \u0645\u0639\u0627\u06c1\u062f\u06c1 \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u06af\u0631 \u0688\u06cc\u0679\u0627\u0628\u06cc\u0633 \u0627\u0646\u062c\u0646 \u0679\u06cc\u0628\u0644 \u0646\u0645\u0628\u0631 14 \u067e\u0631 \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648\u062c\u0627\u062a\u0627 \u06c1\u06d2 (\u0646\u062d\u0648\u06cc \u063a\u0644\u0637\u06cc \u06a9\u06cc \u0648\u062c\u06c1 \u0633\u06d2)\u060c \u067e\u06c1\u0644\u06d2 13 \u0679\u06cc\u0628\u0644\u0632 \u06a9\u0627 \u06a9\u06cc\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u061f \u06a9\u0686\u06be \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0646\u062c\u0646 \u0679\u0631\u0627\u0646\u0632\u06cc\u06a9\u0634\u0646\u0644 \u0688\u06cc\u0679\u0627 \u0688\u06cc\u0641\u06cc\u0646\u06cc\u0634\u0646 \u0644\u06cc\u0646\u06af\u0648\u06cc\u062c (DDL) \u06a9\u0648 \u0633\u067e\u0648\u0631\u0679 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0627\u0633 \u06a9\u0627 \u0645\u0637\u0644\u0628 \u06c1\u06d2 \u06a9\u06c1 \u06cc\u06c1 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u062a\u0645\u0627\u0645 13 \u0679\u06cc\u0628\u0644\u0632 \u06a9\u0648 \u0648\u0627\u067e\u0633 \u06a9\u0631 \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u06d4 \u062a\u0627\u06c1\u0645\u060c \u0628\u06c1\u062a \u0633\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u06cc\u0633\u0627 \u0646\u06c1\u06cc\u06ba \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u0627\u06af\u0631 \u0627\u0646\u0679\u0631\u0645\u06cc\u0688\u06cc\u0679 \u06a9\u06cc \u0646\u0627\u06a9\u0627\u0645\u06cc \u06c1\u0648\u062a\u06cc \u06c1\u06d2 \u062a\u0648\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0628 \u06cc\u062a\u06cc\u0645 \u062d\u0627\u0644\u062a \u0645\u06cc\u06ba \u06c1\u0648\u06af\u0627\u06d4 Liquibase \u0646\u06d2 \u0631\u06cc\u06a9\u0627\u0631\u0688 \u0646\u06c1\u06cc\u06ba \u06a9\u06cc\u0627\u06d4 <code>id=\"1\"<\/code> \u0627\u06af\u0631 \u06a9\u0627\u0645\u06cc\u0627\u0628 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0627\u06af\u0644\u06cc \u0628\u0627\u0631 \u062c\u0628 \u0622\u067e \u0627\u06cc\u067e \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba \u06af\u06d2 \u062a\u0648 \u06cc\u06c1 \u062a\u0645\u0627\u0645 15 \u0679\u06cc\u0628\u0644\u0632 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0628\u0646\u0627\u0646\u06d2 \u06a9\u06cc \u06a9\u0648\u0634\u0634 \u06a9\u0631\u06d2 \u06af\u0627\u06d4 \u0686\u0648\u0646\u06a9\u06c1 \u062c\u062f\u0648\u0644 1 \u067e\u06c1\u0644\u06d2 \u0633\u06d2 \u0645\u0648\u062c\u0648\u062f \u06c1\u06d2\u060c \u0627\u0633 \u0644\u06cc\u06d2 \u0641\u0648\u0631\u06cc \u062a\u0646\u0627\u0632\u0639\u06c1 \u06c1\u06d2\u06d4<\/p>\n<p><strong>\u0627\u0635\u0644\u0627\u062d\u0627\u062a:<\/strong> &quot;\u0627\u06cc\u06a9 \u0644\u0627\u062c\u06cc\u06a9\u0644 \u0622\u067e\u0631\u06cc\u0634\u0646 \u0641\u06cc \u0686\u06cc\u0646\u062c \u0633\u06cc\u0679&#8221; \u06a9\u06d2 \u0627\u0635\u0648\u0644 \u067e\u0631 \u0639\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u06d4 \u0627\u06af\u0631 \u0622\u067e 3 \u0679\u06cc\u0628\u0644\u0632 \u0628\u0646\u0627 \u0631\u06c1\u06d2 \u06c1\u06cc\u06ba \u062a\u0648 3 \u0639\u0644\u06cc\u062d\u062f\u06c1 ChangeSets \u0628\u0646\u0627\u0626\u06cc\u06ba\u06d4 \u0627\u06af\u0631 \u0627\u06cc\u06a9 \u0628\u06be\u06cc \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u062c\u0627\u062a\u0627 \u06c1\u06d2 \u062a\u0648\u060c \u06a9\u0627\u0645\u06cc\u0627\u0628\u06cc \u0645\u0633\u062a\u0642\u0644 \u0637\u0648\u0631 \u067e\u0631 \u0631\u06cc\u06a9\u0627\u0631\u0688 \u06a9\u06cc \u062c\u0627\u062a\u06cc \u06c1\u06d2\u060c \u0627\u0648\u0631 \u0635\u0631\u0641 \u0679\u0648\u0679\u06d2 \u06c1\u0648\u0626\u06d2 \u06a9\u0648 \u0679\u06be\u06cc\u06a9 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-2-manual-database-tweaking-the-phantom-menace\">2. \u062f\u0633\u062a\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0679\u06cc\u0648\u0646\u0646\u06af (\u063a\u06cc\u0631 \u0645\u0631\u0626\u06cc \u062e\u0637\u0631\u06c1)<\/h3>\n<p>\u06cc\u06c1 \u062a\u0631\u06a9 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0633\u0628 \u0633\u06d2 \u062e\u0637\u0631\u0646\u0627\u06a9 \u0639\u0627\u062f\u062a \u06c1\u06d2\u06d4 \u0627\u06cc\u06a9 \u0688\u0648\u06cc\u0644\u067e\u0631 \u0646\u06d2 \u067e\u06cc\u062f\u0627\u0648\u0627\u0631 \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u06af\u0645\u0634\u062f\u06c1 \u0627\u0634\u0627\u0631\u06cc\u06c1 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u06cc\u0627\u06d4 Liquibase \u0645\u0627\u0626\u06cc\u06af\u0631\u06cc\u0634\u0646\u0632 \u06a9\u0648 \u0644\u06a9\u06be\u0646\u06d2\u060c \u06a9\u0648\u0688 \u06a9\u0627 \u062c\u0627\u0626\u0632\u06c1 \u0644\u06cc\u0646\u06d2 \u0627\u0648\u0631 \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2\u060c \u0644\u0627\u06af \u0627\u0646 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0646\u06c1\u06cc\u06ba \u0628\u0631\u0627\u06c1 \u0631\u0627\u0633\u062a \u0627\u067e\u0646\u06d2 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u067e\u0631 \u0686\u0644\u0627\u0626\u06cc\u06ba\u06d4 <code>CREATE INDEX<\/code> \u0648\u0642\u062a \u0628\u0686\u0627\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631\u06d4<\/p>\n<p>\u0627\u06cc\u06a9 \u06c1\u0641\u062a\u06c1 \u0628\u0639\u062f\u060c \u0627\u06cc\u06a9 \u0627\u0648\u0631 \u0688\u0648\u06cc\u0644\u067e\u0631 \u0628\u0627\u0644\u06a9\u0644 \u0648\u06c1\u06cc \u0627\u0646\u0688\u06cc\u06a9\u0633 \u0628\u0646\u0627\u0646\u06d2 \u0627\u0648\u0631 \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0645\u0646\u0627\u0633\u0628 Liquibase \u0645\u0646\u062a\u0642\u0644\u06cc \u0644\u06a9\u06be\u062a\u0627 \u06c1\u06d2\u06d4 \u0633\u0679\u0627\u0631\u0679 \u0627\u067e \u067e\u0631 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0631\u06cc\u0634 \u06c1\u0648 \u062c\u0627\u062a\u06cc \u06c1\u06d2\u06d4 Liquibase \u0686\u0644\u0627\u0646\u06d2 \u06a9\u06cc \u06a9\u0648\u0634\u0634 \u06a9\u0631\u06d2 \u06af\u0627: <code>CREATE INDEX<\/code> \u0645\u06cc\u06ba \u0646\u06d2 \u06a9\u0645\u0627\u0646\u0688 \u0686\u0644\u0627\u0626\u06cc\u060c \u0644\u06cc\u06a9\u0646 \u0645\u062c\u06be\u06d2 \u06cc\u06c1 \u06a9\u06c1\u062a\u06d2 \u06c1\u0648\u0626\u06d2 \u0627\u06cc\u06a9 \u063a\u0644\u0637\u06cc \u06c1\u0648\u0626\u06cc \u06a9\u06c1 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u0627\u0646\u0688\u06cc\u06a9\u0633 \u067e\u06c1\u0644\u06d2 \u0633\u06d2 \u0645\u0648\u062c\u0648\u062f \u06c1\u06d2\u06d4<\/p>\n<p>Liquibase \u06a9\u0648 \u0627\u067e\u0646\u0627\u062a\u06d2 \u0648\u0642\u062a\u060c \u0622\u067e \u06a9\u0648 \u062f\u0631\u062c \u0630\u06cc\u0644 \u0628\u0646\u06cc\u0627\u062f\u06cc \u0627\u0635\u0648\u0644\u0648\u06ba \u06a9\u0648 \u0642\u0628\u0648\u0644 \u06a9\u0631\u0646\u0627 \u06c1\u0648\u06af\u0627: <strong>Liquibase \u0627\u0633\u06a9\u06cc\u0645\u0648\u06ba \u06a9\u06d2 \u0628\u0627\u0631\u06d2 \u0645\u06cc\u06ba \u0645\u0639\u0644\u0648\u0645\u0627\u062a \u06a9\u0627 \u0645\u06a9\u0645\u0644 \u0630\u0631\u06cc\u0639\u06c1 \u06c1\u06d2\u06d4<\/strong> \u0627\u0646\u0633\u0627\u0646\u06cc \u06c1\u0627\u062a\u06be \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0633\u0627\u062e\u062a \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0628\u0631\u0627\u06c1 \u0631\u0627\u0633\u062a \u0631\u0627\u0628\u0637\u06d2 \u0645\u06cc\u06ba \u0646\u06c1\u06cc\u06ba \u0622\u0646\u0627 \u0686\u0627\u06c1\u06cc\u06d2\u06d4<\/p>\n<p><strong>\u0627\u0635\u0644\u0627\u062d\u0627\u062a:<\/strong> \u0627\u06af\u0631 \u06a9\u0633\u06cc \u0646\u06d2 \u063a\u0644\u0637\u06cc \u0633\u06d2 \u0627\u06cc\u0633\u0627 \u06a9\u06cc\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0622\u067e \u06a9\u06d2 \u067e\u0627\u0633 \u0627\u067e\u0646\u06cc \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 \u06a9\u0648 \u0679\u06be\u06cc\u06a9 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u062f\u0648 \u0627\u062e\u062a\u06cc\u0627\u0631\u0627\u062a \u06c1\u06cc\u06ba: \u0622\u067e \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0633\u06d2 \u0627\u0646\u0688\u06cc\u06a9\u0633 \u06a9\u0648 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 \u062d\u0630\u0641 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba \u062a\u0627\u06a9\u06c1 Liquibase \u0627\u0633\u06d2 \u0645\u0646\u0627\u0633\u0628 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0628\u0646\u0627 \u0633\u06a9\u06d2\u060c \u06cc\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u06cc\u06ba: <code><preconditions\/><\/code> \u0627\u0646\u0688\u06cc\u06a9\u0633 \u0628\u0646\u0627\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2\u060c Liquibase \u0645\u06cc\u06ba \u0679\u06cc\u06af \u0634\u0627\u0645\u0644 \u06a9\u0631\u06a9\u06d2 \u06cc\u0642\u06cc\u0646\u06cc \u0628\u0646\u0627\u0626\u06cc\u06ba \u06a9\u06c1 \u0627\u0646\u0688\u06cc\u06a9\u0633 \u0645\u0648\u062c\u0648\u062f \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-3-ignoring-the-from-scratch-build\">3. \u0639\u0645\u0627\u0631\u062a \u06a9\u0648 &quot;\u0634\u0631\u0648\u0639 \u0633\u06d2&#8221; \u0646\u0638\u0631 \u0627\u0646\u062f\u0627\u0632 \u06a9\u0631\u06cc\u06ba<\/h3>\n<p>\u0627\u06af\u0631 \u0622\u067e \u06a9\u0633\u06cc \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u067e\u0631 \u06a9\u0626\u06cc \u0645\u06c1\u06cc\u0646\u0648\u06ba \u062a\u06a9 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u0627\u067e\u0646\u06d2 \u0645\u0642\u0627\u0645\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u0628\u06c1\u062a \u0633\u0627\u0631\u06d2 \u0631\u06cc\u06a9\u0627\u0631\u0688 \u062c\u0645\u0639 \u06a9\u0631 \u0644\u06cc\u06ba \u06af\u06d2\u06d4 \u0622\u067e \u06cc\u06c1 \u0641\u0631\u0636 \u06a9\u0631\u062a\u06d2 \u06c1\u0648\u0626\u06d2 \u0627\u06cc\u06a9 \u06c1\u062c\u0631\u062a \u0644\u06a9\u06be\u062a\u06d2 \u06c1\u06cc\u06ba \u06a9\u06c1 \u06a9\u0686\u06be \u0645\u06cc\u0632\u06cc\u06ba \u06cc\u0627 \u0679\u06cc\u0633\u0679 \u0688\u06cc\u0679\u0627 \u067e\u06c1\u0644\u06d2 \u0633\u06d2 \u0645\u0648\u062c\u0648\u062f \u06c1\u06d2\u06d4<\/p>\n<p>\u067e\u06be\u0631 \u0627\u06cc\u06a9 \u0646\u06cc\u0627 \u0688\u0648\u06cc\u0644\u067e\u0631 \u0679\u06cc\u0645 \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4 \u062c\u0628 \u0645\u06cc\u06ba \u06a9\u0648\u0688 \u062f\u0631\u0622\u0645\u062f \u06a9\u0631\u062a\u0627 \u06c1\u0648\u06ba\u060c \u062e\u0627\u0644\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u06af\u06be\u0645\u0627\u062a\u0627 \u06c1\u0648\u06ba\u060c \u0627\u0648\u0631 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0634\u0631\u0648\u0639 \u06a9\u0631\u062a\u0627 \u06c1\u0648\u06ba\u060c \u06c1\u062c\u0631\u062a \u062f\u0631\u0645\u06cc\u0627\u0646 \u0645\u06cc\u06ba \u067e\u06be\u0646\u0633 \u062c\u0627\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u06cc\u0633\u0627 \u0627\u0633 \u0644\u06cc\u06d2 \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u06a9\u06cc\u0648\u0646\u06a9\u06c1 \u0646\u0642\u0644 \u0645\u06a9\u0627\u0646\u06cc \u0636\u0645\u0627\u0646\u062a \u0634\u062f\u06c1 \u0631\u06cc\u0627\u0633\u062a\u0648\u06ba \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2 \u0641\u0631\u0636 \u0634\u062f\u06c1 \u0631\u06cc\u0627\u0633\u062a\u0648\u06ba \u067e\u0631 \u0627\u0646\u062d\u0635\u0627\u0631 \u06a9\u0631\u062a\u06cc \u06c1\u06d2 (\u062c\u06cc\u0633\u06d2 \u06a9\u06c1 \u063a\u06cc\u0631 \u0645\u0644\u06a9\u06cc \u06a9\u0644\u06cc\u062f \u0628\u0646\u0627\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u06a9\u0686\u06be \u0642\u0637\u0627\u0631\u0648\u06ba \u06a9\u06cc \u0645\u0648\u062c\u0648\u062f\u06af\u06cc \u06a9\u06cc \u062a\u0648\u0642\u0639 \u06a9\u0631\u0646\u0627)\u06d4<\/p>\n<p><strong>\u0627\u0635\u0644\u0627\u062d\u0627\u062a:<\/strong> \u0622\u067e \u06a9\u0648 \u0627\u067e\u0646\u06cc \u06c1\u062c\u0631\u062a \u06a9\u0648 \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u062e\u0627\u0644\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u062e\u0644\u0627\u0641 \u0628\u0627\u0642\u0627\u0639\u062f\u06af\u06cc \u0633\u06d2 \u062c\u0627\u0646\u0686\u0646\u0627 \u0686\u0627\u06c1\u06cc\u06d2\u06d4 \u0627\u06af\u0631 \u0622\u067e Docker \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u062a\u0648\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0646\u0679\u06cc\u0646\u0631 \u06a9\u0648 \u067e\u06be\u0627\u0691 \u062f\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0633\u06d2 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0628\u0646\u0627\u0626\u06cc\u06ba\u06d4 \u0627\u06af\u0631 \u0622\u067e \u0641\u0627\u0626\u0644 \u067e\u0631 \u0645\u0628\u0646\u06cc H2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631 \u0631\u06c1\u06d2 \u06c1\u06cc\u06ba\u060c \u062c\u06cc\u0633\u0627 \u06a9\u06c1 \u06c1\u0645 \u0646\u06d2 \u067e\u06c1\u0644\u06d2 \u062a\u0631\u062a\u06cc\u0628 \u062f\u06cc\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0627\u0633\u06d2 \u0635\u0631\u0641 \u062d\u0630\u0641 \u06a9\u0631 \u062f\u06cc\u06ba\u06d4 <code>.\/data\/employeedb.mv.db<\/code> \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u0641\u0648\u0644\u0688\u0631 \u0633\u06d2 \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u062d\u0630\u0641 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u06a9\u0648 \u062f\u0648\u0628\u0627\u0631\u06c1 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba\u06d4 \u0627\u06af\u0631 \u0622\u067e \u0645\u06a9\u0645\u0644 \u0637\u0648\u0631 \u067e\u0631 \u062e\u0627\u0644\u06cc \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u06a9\u0627\u0645\u06cc\u0627\u0628\u06cc \u0633\u06d2 \u0628\u0648\u0679 \u0646\u06c1\u06cc\u06ba \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u06a9\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u06cc \u062a\u0627\u0631\u06cc\u062e \u062e\u0631\u0627\u0628 \u06c1\u0648 \u06af\u0626\u06cc \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-4-hardcoding-environment-details\">4. \u06c1\u0627\u0631\u0688 \u06a9\u0648\u0688\u0646\u06af \u0645\u0627\u062d\u0648\u0644 \u06a9\u06cc \u062a\u0641\u0635\u06cc\u0644\u0627\u062a<\/h3>\n<p>\u0627\u0628\u062a\u062f\u0627\u0626\u06cc \u0627\u0641\u0631\u0627\u062f \u0628\u0631\u0627\u06c1 \u0631\u0627\u0633\u062a XML \u0641\u0627\u0626\u0644\u0648\u06ba \u0645\u06cc\u06ba \u0645\u0627\u062d\u0648\u0644 \u0633\u06d2 \u0645\u062a\u0639\u0644\u0642 \u0645\u062e\u0635\u0648\u0635 \u062a\u0641\u0635\u06cc\u0644\u0627\u062a \u06a9\u0648 \u06c1\u0627\u0631\u0688 \u06a9\u0648\u0688 \u06a9\u0631\u0646\u0627 \u0686\u0627\u06c1\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4 \u0645\u062b\u0627\u0644 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631\u060c \u0622\u067e \u0627\u06cc\u06a9 \u0645\u062e\u0635\u0648\u0635 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u0646\u0627\u0645 (schemaName=&#8221;dev_schema&#8221;) \u06a9\u0648 \u06c1\u0627\u0631\u0688 \u06a9\u0648\u0688 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba \u06cc\u0627 \u06a9\u0633\u06cc \u0645\u062e\u0635\u0648\u0635 \u0645\u0642\u0627\u0645\u06cc \u0635\u0627\u0631\u0641 \u06a9\u0648 \u0627\u062c\u0627\u0632\u062a \u062f\u06d2 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba (\u0645\u0627\u0626\u06cc_\u0644\u0648\u06a9\u0644_\u0635\u0627\u0631\u0641 \u06a9\u0648 \u062a\u0645\u0627\u0645 \u0645\u0644\u0627\u0632\u0645\u06cc\u0646 \u067e\u0631 \u06af\u0631\u0627\u0646\u0679 \u06a9\u0631\u06cc\u06ba)\u06d4<\/p>\n<p>\u062c\u0628 \u06cc\u06c1 \u06a9\u0648\u0688 \u0627\u0633\u0679\u06cc\u062c\u0646\u06af \u0645\u0631\u062d\u0644\u06d2 \u0645\u06cc\u06ba \u0645\u0646\u062a\u0642\u0644 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u062a\u0648 \u0627\u0633\u0679\u06cc\u062c\u0646\u06af \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u062e\u062a\u0644\u0641 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u0627 \u0646\u0627\u0645 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648\u062c\u0627\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>\u062d\u0644: \u0646\u0642\u0644 \u0645\u06a9\u0627\u0646\u06cc \u06a9\u0648 \u062e\u0644\u0627\u0635\u06c1 \u0631\u06a9\u06be\u06cc\u06ba\u06d4 Spring Boot \u06a9\u0648 application.properties \u06a9\u06d2 \u0630\u0631\u06cc\u0639\u06d2 \u06a9\u0646\u06a9\u0634\u0646 \u06a9\u06cc \u062a\u0641\u0635\u06cc\u0644\u0627\u062a \u06c1\u06cc\u0646\u0688\u0644 \u06a9\u0631\u0646\u06d2 \u062f\u06cc\u06ba\u06d4 \u0627\u06af\u0631 \u0622\u067e \u06a9\u0648 \u0627\u067e\u0646\u06cc Liquibase \u0641\u0627\u0626\u0644 \u06a9\u06d2 \u0627\u0646\u062f\u0631 \u0645\u062a\u062d\u0631\u06a9 \u0627\u0642\u062f\u0627\u0631 \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u0646\u0627 \u0636\u0631\u0648\u0631\u06cc \u06c1\u06d2\u060c \u062a\u0648 \u062c\u0627\u0626\u06cc\u062f\u0627\u062f \u06a9\u0627 \u0645\u062a\u0628\u0627\u062f\u0644 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u06cc\u06ba\u06d4 \u0622\u067e Liquibase \u0645\u06cc\u06ba \u0645\u062a\u063a\u06cc\u0631\u0627\u062a \u06a9\u06cc \u0648\u0636\u0627\u062d\u062a \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u0622\u063a\u0627\u0632 \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646 \u0627\u0646\u06c1\u06cc\u06ba Spring Boot \u0645\u06cc\u06ba \u0645\u0646\u062a\u0642\u0644 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<h3 id=\"heading-5-messing-up-migration-ordering\">5. \u06c1\u062c\u0631\u062a \u06a9\u06d2 \u0622\u0631\u0688\u0631 \u06a9\u0648 \u062e\u0631\u0627\u0628 \u06a9\u0631\u06cc\u06ba\u06d4<\/h3>\n<p>Liquibase \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u0627\u0633 \u062a\u0631\u062a\u06cc\u0628 \u0633\u06d2 \u0686\u0644\u0627\u062a\u0627 \u06c1\u06d2 \u062c\u0633 \u062a\u0631\u062a\u06cc\u0628 \u0633\u06d2 \u0648\u06c1 \u062f\u0631\u062c \u06c1\u06cc\u06ba\u06d4 <code>db.changelog-master.xml<\/code> \u0641\u0627\u0626\u0644<\/p>\n<p>\u0688\u0648\u06cc\u0644\u067e\u0631 \u0627\u06d2 <code>departments<\/code> \u0679\u06cc\u0628\u0644 \u0627\u06cc\u06a9 \u0628\u0631\u0627\u0646\u0686 \u0645\u06cc\u06ba \u06c1\u06d2 \u0627\u0648\u0631 \u0688\u0648\u06cc\u0644\u067e\u0631 B \u0627\u06cc\u06a9 \u063a\u06cc\u0631 \u0645\u0644\u06a9\u06cc \u06a9\u0644\u06cc\u062f \u0628\u0646\u0627\u062a\u0627 \u06c1\u06d2 \u062c\u0648 \u0644\u0646\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2: <code>departments<\/code> \u062f\u0648\u0633\u0631\u06cc \u0634\u0627\u062e\u0648\u06ba \u0645\u06cc\u06ba\u060c \u062c\u0648 \u0628\u06be\u06cc \u06a9\u0648\u0688 \u06a9\u0648 \u0636\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u0648\u06c1 \u067e\u06c1\u0644\u06d2 \u062a\u0631\u062a\u06cc\u0628 \u06a9\u0627 \u062a\u0639\u06cc\u0646 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u062c\u0628 \u0688\u0648\u06cc\u0644\u067e\u0631 \u0628\u06cc \u06a9\u0627 \u06a9\u0648\u0688 \u0645\u0627\u0633\u0679\u0631 \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4 <em>\u067e\u06c1\u0644\u06d2<\/em> \u0688\u0648\u06cc\u0644\u067e\u0631 A \u06a9\u06d2 \u06a9\u0648\u0688 \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u0648\u0626\u06d2\u060c Liquibase \u0679\u0627\u0631\u06af\u0679 \u0679\u06cc\u0628\u0644 \u06a9\u06d2 \u0645\u0648\u062c\u0648\u062f \u06c1\u0648\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u063a\u06cc\u0631 \u0645\u0644\u06a9\u06cc \u06a9\u06cc\u0632 \u0628\u0646\u0627\u0646\u06d2 \u06a9\u06cc \u06a9\u0648\u0634\u0634 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p><strong>\u0627\u0635\u0644\u0627\u062d\u0627\u062a:<\/strong> \u0645\u0627\u0633\u0679\u0631 \u062a\u0628\u062f\u06cc\u0644\u06cc \u0644\u0627\u06af \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0627 \u062d\u062a\u0645\u06cc \u06af\u06cc\u0679 \u0648\u06d2 \u06c1\u06d2\u06d4 \u06a9\u0648\u0688 \u06a9\u0627 \u062c\u0627\u0626\u0632\u06c1 \u0644\u06cc\u0646\u06d2 \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646\u060c \u06c1\u0645\u06cc\u0634\u06c1 \u062f\u0631\u062c \u0630\u06cc\u0644 \u06a9\u0648 \u0686\u06cc\u06a9 \u06a9\u0631\u06cc\u06ba: <code><include\/><\/code> \u0628\u06cc\u0627\u0646\u0627\u062a \u06a9\u0648 \u062a\u0627\u0631\u06cc\u062e \u06a9\u06d2 \u0645\u0637\u0627\u0628\u0642 \u062a\u0631\u062a\u06cc\u0628 \u062f\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0627\u0646\u062d\u0635\u0627\u0631 \u0628\u0627\u0645\u0639\u0646\u06cc \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<h2 id=\"heading-liquibase-vs-flyway-vs-manual-sql-scripts\">Liquibase \u0628\u0645\u0642\u0627\u0628\u0644\u06c1 Flyway \u0628\u0645\u0642\u0627\u0628\u0644\u06c1 \u062f\u0633\u062a\u06cc \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u0627\u0633\u06a9\u0631\u067e\u0679<\/h2>\n<p>\u062c\u0628 \u0622\u067e \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0648\u0631\u0698\u0646 \u06a9\u0646\u0679\u0631\u0648\u0644 \u06a9\u0648 \u0646\u0627\u0641\u0630 \u06a9\u0631\u0646\u06d2 \u06a9\u0627 \u0641\u06cc\u0635\u0644\u06c1 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u06a9\u0648 \u0641\u0648\u0631\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0627\u06cc\u06a9 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0627 \u0633\u0627\u0645\u0646\u0627 \u06a9\u0631\u0646\u0627 \u067e\u0691\u062a\u0627 \u06c1\u06d2\u06d4 Liquibase \u062c\u0627\u0648\u0627 \u0627\u06cc\u06a9\u0648 \u0633\u0633\u0679\u0645 \u0645\u06cc\u06ba \u0648\u0627\u062d\u062f \u0679\u0648\u0644 \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4 \u0633\u06a9\u06cc\u0645\u0627 \u0627\u0631\u062a\u0642\u0627\u0621 \u06a9\u0648 \u0645\u0646\u0638\u0645 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u062a\u06cc\u0646 \u0633\u0628 \u0633\u06d2 \u0639\u0627\u0645 \u0637\u0631\u06cc\u0642\u06d2 \u06c1\u06cc\u06ba Liquibase\u060c Flyway\u060c \u0627\u0648\u0631 \u062f\u0633\u062a\u06cc SQL \u0627\u0633\u06a9\u0631\u067e\u0679\u0633\u06d4<\/p>\n<p>\u0622\u067e \u06a9\u0648 \u06c1\u0631 \u0627\u06cc\u06a9 \u06a9\u06d2 \u0639\u0645\u0644\u06cc \u0641\u0648\u0627\u0626\u062f \u0627\u0648\u0631 \u0646\u0642\u0635\u0627\u0646\u0627\u062a \u06a9\u0648 \u0633\u0645\u062c\u06be\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2 \u062a\u0627\u06a9\u06c1 \u0622\u067e \u0627\u067e\u0646\u06cc \u0645\u062e\u0635\u0648\u0635 \u0679\u06cc\u0645 \u0627\u0648\u0631 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0635\u062d\u06cc\u062d \u0679\u0648\u0644 \u06a9\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0631 \u0633\u06a9\u06cc\u06ba\u06d4<\/p>\n<h3 id=\"heading-1-manual-sql-scripts-the-baseline\">1. \u062f\u0633\u062a\u06cc \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u0627\u0633\u06a9\u0631\u067e\u0679 (\u0628\u06cc\u0633 \u0644\u0627\u0626\u0646)<\/h3>\n<p>\u06cc\u06c1 \u0633\u0628 \u0633\u06d2 \u0632\u06cc\u0627\u062f\u06c1 beginners \u06a9\u06d2 \u0644\u0626\u06d2 \u067e\u06c1\u0644\u06d2 \u0633\u06d2 \u0637\u06d2 \u0634\u062f\u06c1 \u0646\u0642\u0637\u06c1 \u0646\u0638\u0631 \u06c1\u06d2. \u0627\u06cc\u06a9 script.sql \u0641\u0627\u0626\u0644 \u0628\u0646\u0627\u0626\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0633\u06d2 \u0628\u0631\u0627\u06c1 \u0631\u0627\u0633\u062a \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06d2 \u062e\u0644\u0627\u0641 \u06a9\u0633\u06cc \u0679\u0648\u0644 \u062c\u06cc\u0633\u06d2 DBeaver\u060c pgAdmin\u060c \u06cc\u0627 DataGrip \u06a9\u06d2 \u0630\u0631\u06cc\u0639\u06d2 \u0686\u0644\u0627\u0626\u06cc\u06ba\u06d4<\/p>\n<ul wp_automatic_readability=\"3\">\n<li wp_automatic_readability=\"1\">\n<p><strong>\u0637\u0627\u0642\u062a:<\/strong> \u06a9\u0648\u0626\u06cc \u0633\u06cc\u0679 \u0627\u067e \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4 \u0622\u067e \u06a9\u0627 \u0635\u062d\u06cc\u062d \u0646\u062d\u0648 \u067e\u0631 \u0645\u06a9\u0645\u0644 \u06a9\u0646\u0679\u0631\u0648\u0644 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u062a\u0645\u0627\u0645 \u0628\u06cc\u06a9 \u0627\u06cc\u0646\u0688 \u0688\u0648\u06cc\u0644\u067e\u0631 \u067e\u06c1\u0644\u06d2 \u06c1\u06cc \u062c\u0627\u0646\u062a\u06d2 \u06c1\u06cc\u06ba \u06a9\u06c1 SQL \u06a9\u06cc\u0633\u06d2 \u0644\u06a9\u06be\u0646\u0627 \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"1\">\n<p><strong>\u06a9\u0645\u0632\u0648\u0631\u06cc:<\/strong> \u067e\u06be\u0627\u0646\u0633\u06cc \u06a9\u0627 \u06a9\u0648\u0626\u06cc \u0633\u0631\u0627\u063a \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4 \u06cc\u06c1 \u0646\u0642\u0637\u06c1 \u0646\u0638\u0631 \u0639\u0645\u0644\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u06d2 \u0628\u0691\u06be\u0646\u06d2 \u06a9\u06cc \u0636\u0645\u0627\u0646\u062a \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u06d4 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc\u0627\u06ba \u062f\u0628\u0627\u0624 \u06a9\u0627 \u0634\u06a9\u0627\u0631 \u06c1\u0648\u062a\u06cc \u06c1\u06cc\u06ba \u06a9\u06cc\u0648\u0646\u06a9\u06c1 \u0627\u0646 \u06a9\u0627 \u0627\u0646\u062d\u0635\u0627\u0631 \u0627\u0646 \u0644\u0648\u06af\u0648\u06ba \u067e\u0631 \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u062c\u0648 \u0635\u062d\u06cc\u062d \u062a\u0631\u062a\u06cc\u0628 \u0645\u06cc\u06ba \u0635\u062d\u06cc\u062d \u0627\u0633\u06a9\u0631\u067e\u0679 \u06a9\u0648 \u0686\u0644\u0627\u0646\u0627 \u06cc\u0627\u062f \u0631\u06a9\u06be\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"1\">\n<p><strong>\u0641\u06cc\u0635\u0644\u06c1:<\/strong> \u0645\u06cc\u0646\u0648\u0626\u0644 \u0627\u0633\u06a9\u0631\u067e\u0679\u0633 \u0633\u0648\u0644\u0648 \u0648\u06cc\u06a9 \u0627\u06cc\u0646\u0688 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679\u0633 \u06cc\u0627 \u062a\u06cc\u0632 \u0631\u0641\u062a\u0627\u0631 \u067e\u0631\u0648\u0679\u0648 \u0679\u0627\u0626\u067e\u0646\u06af \u06a9\u06d2 \u0644\u06cc\u06d2 \u0628\u0627\u0644\u06a9\u0644 \u0645\u0648\u0632\u0648\u06ba \u06c1\u06cc\u06ba \u062c\u06c1\u0627\u06ba \u0622\u067e \u06a9\u0648 \u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u062a\u0628\u0627\u06c1 \u06a9\u0631\u0646\u06d2 \u0645\u06cc\u06ba \u06a9\u0648\u0626\u06cc \u0627\u0639\u062a\u0631\u0627\u0636 \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4 \u0644\u06cc\u06a9\u0646 \u062c\u0633 \u0644\u0645\u062d\u06d2 \u06a9\u0648\u0626\u06cc \u062f\u0648\u0633\u0631\u0627 \u0688\u0648\u06cc\u0644\u067e\u0631 \u0679\u06cc\u0645 \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06c1\u0648\u062a\u0627 \u06c1\u06d2 \u06cc\u0627 \u0627\u0633\u0679\u06cc\u062c\u0646\u06af \u0645\u0627\u062d\u0648\u0644 \u067e\u06cc\u062f\u0627 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u060c \u06cc\u06c1 \u0627\u06cc\u06a9 \u0628\u06c1\u062a \u0628\u0691\u06cc \u0630\u0645\u06c1 \u062f\u0627\u0631\u06cc \u0628\u0646 \u062c\u0627\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-2-flyway-the-sql-purist\">2. \u0641\u0644\u0627\u0626\u06cc \u0648\u06d2 (\u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u067e\u06cc\u0648\u0631\u06cc\u0633\u0679)<\/h3>\n<p>Flyway Liquibase \u06a9\u0627 \u0633\u0628 \u0633\u06d2 \u0645\u0642\u0628\u0648\u0644 \u0645\u062a\u0628\u0627\u062f\u0644 \u06c1\u06d2\u06d4 Flyway XML \u06cc\u0627 YAML \u062e\u0644\u0627\u0635\u06c1 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u06d2 \u0628\u062c\u0627\u0626\u06d2 \u062e\u0627\u0645 SQL \u0642\u0628\u0648\u0644 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0633\u062e\u062a \u0646\u0627\u0645 \u062f\u06cc\u0646\u06d2 \u06a9\u06d2 \u06a9\u0646\u0648\u0646\u0634\u0646 (\u062c\u06cc\u0633\u06d2 V1__Create_employee_table.sql) \u06a9\u0627 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u0648\u0626\u06d2 \u0627\u06cc\u06a9 \u062e\u0627\u0644\u0635 SQL \u0641\u0627\u0626\u0644 \u0628\u0646\u0627\u0626\u06cc\u06ba\u06d4<\/p>\n<ul wp_automatic_readability=\"6.5\">\n<li wp_automatic_readability=\"3\">\n<p><strong>\u0637\u0627\u0642\u062a:<\/strong> \u0633\u06cc\u06a9\u06be\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06a9\u0648\u0626\u06cc \u0646\u0626\u06d2 \u062c\u0645\u0644\u06d2 \u0646\u06c1\u06cc\u06ba \u06c1\u06cc\u06ba\u06d4 \u0627\u06af\u0631 \u0622\u067e \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u062c\u0627\u0646\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u067e\u06c1\u0644\u06d2 \u06c1\u06cc \u062c\u0627\u0646\u062a\u06d2 \u06c1\u06cc\u06ba \u06a9\u06c1 \u0641\u0644\u0627\u0626\u06cc \u0648\u06d2 \u06a9\u0648 \u06a9\u06cc\u0633\u06d2 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u0646\u0627 \u06c1\u06d2\u06d4 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0628\u063a\u06cc\u0631 \u06a9\u0633\u06cc \u0631\u06a9\u0627\u0648\u0679 \u06a9\u06d2 \u0633\u06cc\u0679 \u0627\u067e\u060c \u067e\u0631 \u0632\u0648\u0631\u060c \u0627\u0648\u0631 \u0627\u0646\u0636\u0645\u0627\u0645 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06cc\u06c1 \u0646\u0627\u0642\u0627\u0628\u0644 \u06cc\u0642\u06cc\u0646 \u062d\u062f \u062a\u06a9 \u062a\u06cc\u0632 \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"5\">\n<p><strong>\u06a9\u0645\u0632\u0648\u0631\u06cc:<\/strong> \u0686\u0648\u0646\u06a9\u06c1 \u0622\u067e \u062e\u0627\u0645 SQL \u0644\u06a9\u06be \u0631\u06c1\u06d2 \u06c1\u06cc\u06ba\u060c \u0645\u0646\u062a\u0642\u0644\u06cc \u0622\u067e \u06a9\u06d2 \u0645\u062e\u0635\u0648\u0635 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0628\u0648\u0644\u06cc \u06a9\u06d2 \u0633\u0627\u062a\u06be \u0645\u0636\u0628\u0648\u0637\u06cc \u0633\u06d2 \u062c\u0648\u0691 \u062f\u06cc \u062c\u0627\u062a\u06cc \u06c1\u06d2\u06d4 \u0627\u06af\u0631 \u0622\u067e MySQL \u06a9\u06d2 \u0644\u06cc\u06d2 Flyway \u0633\u06a9\u0631\u067e\u0679 \u0644\u06a9\u06be\u062a\u06d2 \u06c1\u06cc\u06ba \u0627\u0648\u0631 \u0628\u0639\u062f \u0645\u06cc\u06ba \u0627\u067e\u0646\u06d2 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u06a9\u0648 PostgreSQL \u0645\u06cc\u06ba \u0645\u0646\u062a\u0642\u0644 \u06a9\u0631\u0646\u06d2 \u06a9\u0627 \u0641\u06cc\u0635\u0644\u06c1 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u06a9\u0648 \u0627\u067e\u0646\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u06cc \u062a\u0627\u0631\u06cc\u062e \u06a9\u0648 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 \u062f\u0648\u0628\u0627\u0631\u06c1 \u062a\u062e\u0644\u06cc\u0642 \u06a9\u0631\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u0648\u06af\u06cc\u06d4 \u0645\u0632\u06cc\u062f \u0628\u0631\u0622\u06ba\u060c \u0633\u06cc\u0645\u0644\u06cc\u0633 \u0622\u0679\u0648\u0645\u06cc\u0679\u06a9 \u0631\u0648\u0644 \u0628\u06cc\u06a9 \u0641\u0644\u0627\u0626\u06cc \u0648\u06d2 \u06a9\u06d2 \u062a\u062c\u0627\u0631\u062a\u06cc \u062f\u0631\u062c\u06d2 \u06a9\u06cc \u0627\u06cc\u06a9 \u0627\u062f\u0627 \u0634\u062f\u06c1 \u062e\u0635\u0648\u0635\u06cc\u062a \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"2\">\n<p><strong>\u0641\u06cc\u0635\u0644\u06c1:<\/strong> \u0641\u0644\u0627\u0626\u06cc \u0648\u06d2 \u0627\u0646 \u0679\u06cc\u0645\u0648\u06ba \u06a9\u06d2 \u0644\u06cc\u06d2 \u0645\u062b\u0627\u0644\u06cc \u06c1\u06d2 \u062c\u0648 SQL \u0645\u06cc\u06ba \u0627\u0646\u062a\u06c1\u0627\u0626\u06cc \u06c1\u0646\u0631 \u0645\u0646\u062f \u06c1\u06cc\u06ba\u060c \u0645\u0633\u062a\u0642\u0644 \u0637\u0648\u0631 \u067e\u0631 \u0627\u06cc\u06a9 \u0688\u06cc\u0679\u0627\u0628\u06cc\u0633 \u0648\u06cc\u0646\u0688\u0631 \u06a9\u06d2 \u0644\u06cc\u06d2 \u067e\u0627\u0628\u0646\u062f \u06c1\u06cc\u06ba\u060c \u0627\u0648\u0631 \u0644\u0686\u06a9\u062f\u0627\u0631 \u062a\u0631\u062a\u06cc\u0628 \u067e\u0631 \u0633\u062e\u062a \u0642\u0648\u0627\u0646\u06cc\u0646 \u06a9\u0648 \u062a\u0631\u062c\u06cc\u062d \u062f\u06cc\u062a\u06cc \u06c1\u06cc\u06ba\u06d4<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-3-liquibase-the-abstraction-layer\">3. Liquibase ( \u062a\u062c\u0631\u06cc\u062f\u06cc \u062a\u06c1\u06c1)<\/h3>\n<p>\u062c\u06cc\u0633\u0627 \u06a9\u06c1 \u06c1\u0645 \u0646\u06d2 \u0627\u0633 \u067e\u0648\u0631\u06d2 \u0679\u06cc\u0648\u0679\u0648\u0631\u06cc\u0644 \u0645\u06cc\u06ba \u062f\u06cc\u06a9\u06be\u0627 \u06c1\u06d2\u060c Liquibase \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 XML\u060c YAML\u060c \u06cc\u0627 JSON \u0645\u06cc\u06ba \u062e\u0644\u0627\u0635\u06c1 \u06a9\u0631\u06a9\u06d2 \u0627\u06cc\u06a9 \u0645\u062e\u062a\u0644\u0641 \u0637\u0631\u06cc\u0642\u06c1 \u0627\u062e\u062a\u06cc\u0627\u0631 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<ol wp_automatic_readability=\"7.5\">\n<li wp_automatic_readability=\"7\">\n<p><strong>\u0637\u0627\u0642\u062a:<\/strong> \u06cc\u06c1 \u0648\u0627\u0642\u0639\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u062c\u0646\u0627\u0633\u0679\u06a9 \u06c1\u06d2\u06d4 \u0627\u06cc\u06a9 \u0628\u0627\u0631 \u062c\u0628 \u0622\u067e \u0627\u067e\u0646\u06d2 \u0645\u0646\u0637\u0642\u06cc \u0688\u06be\u0627\u0646\u0686\u06d2 \u06a9\u06cc \u0648\u0636\u0627\u062d\u062a \u06a9\u0631 \u0644\u06cc\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 Liquibase \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0627\u0633\u06d2 H2\u060c PostgreSQL\u060c \u06cc\u0627 Oracle \u06a9\u06d2 \u0644\u06cc\u06d2 \u062f\u0631\u0633\u062a SQL \u0628\u0648\u0644\u06cc \u0645\u06cc\u06ba \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631 \u062f\u06cc\u062a\u0627 \u06c1\u06d2\u06d4 \u0637\u0627\u0642\u062a\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0631\u0648\u0644 \u0628\u06cc\u06a9\u0633\u060c \u0634\u0631\u0627\u0626\u0637\u060c \u0633\u06cc\u0627\u0642 \u0648 \u0633\u0628\u0627\u0642\u060c \u0627\u0648\u0631 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u0644\u06cc\u0628\u0644\u0632 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0645\u0641\u062a \u0633\u067e\u0648\u0631\u0679\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"1\">\n<p><strong>\u06a9\u0645\u0632\u0648\u0631\u06cc:<\/strong> \u0627\u0633 \u0645\u06cc\u06ba \u0641\u0644\u0627\u0626\u06cc \u0648\u06d2 \u0633\u06d2 \u0632\u06cc\u0627\u062f\u06c1 \u062a\u06cc\u0632 \u0633\u06cc\u06a9\u06be\u0646\u06d2 \u06a9\u0627 \u0648\u06a9\u0631 \u06c1\u06d2\u06d4 XML \u0646\u062d\u0648 \u0628\u0644\u0627 \u0634\u0628\u06c1 \u0644\u0641\u0638\u06cc \u06c1\u06d2 \u0627\u0648\u0631 \u0628\u06c1\u062a \u0622\u0633\u0627\u0646 \u0633\u0646\u06af\u0644 \u0679\u06cc\u0628\u0644 \u0627\u06cc\u067e\u0644\u06cc \u06a9\u06cc\u0634\u0646\u0632 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0628\u06be\u0627\u0631\u06cc \u0644\u06af \u0633\u06a9\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<li wp_automatic_readability=\"4\">\n<p><strong>\u0641\u06cc\u0635\u0644\u06c1:<\/strong> Liquibase \u0627\u0646\u0679\u0631\u067e\u0631\u0627\u0626\u0632 \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u0686\u0645\u06a9\u062a\u0627 \u06c1\u06d2 \u062c\u0633 \u0645\u06cc\u06ba \u067e\u06cc\u0686\u06cc\u062f\u06c1 \u0627\u06cc\u067e\u0644\u06cc \u06a9\u06cc\u0634\u0646\u0632\u060c \u0645\u0644\u0679\u06cc \u0679\u06cc\u0646\u0646\u0679 \u0633\u0633\u0679\u0645\u0632\u060c \u0645\u062a\u0639\u062f\u062f \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0648\u06cc\u0646\u0688\u0631\u0632 \u06a9\u0648 \u0633\u067e\u0648\u0631\u0679 \u06a9\u0631\u0646\u06d2 \u0648\u0627\u0644\u06d2 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679\u0633\u060c \u0627\u0648\u0631 CI\/CD \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646\u0648\u06ba \u067e\u0631 \u062f\u0627\u0646\u06d2 \u062f\u0627\u0631 \u06a9\u0646\u0679\u0631\u0648\u0644 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<\/li>\n<\/ol>\n<h2 id=\"heading-liquibase-best-practices\">Liquibase \u0628\u06c1\u062a\u0631\u06cc\u0646 \u0637\u0631\u0632 \u0639\u0645\u0644<\/h2>\n<p>\u0627\u0628 \u062c\u0628 \u06a9\u06c1 \u0622\u067e Liquibase \u06a9\u06d2 \u0645\u06cc\u06a9\u0627\u0646\u06a9\u0633 \u06a9\u0648 \u0633\u0645\u062c\u06be \u0686\u06a9\u06d2 \u06c1\u06cc\u06ba\u060c \u0622\u067e \u06a9\u0648 \u06cc\u06c1 \u062c\u0627\u0646\u0646\u06d2 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2 \u06a9\u06c1 \u0627\u0633\u06d2 \u067e\u06cc\u0634\u06c1 \u0648\u0631\u0627\u0646\u06c1 \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u06a9\u06cc\u0633\u06d2 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u06cc\u0627 \u062c\u0627\u0626\u06d2\u06d4 \u0622\u067e \u06a9\u06cc \u0645\u0642\u0627\u0645\u06cc \u0645\u0634\u06cc\u0646 \u067e\u0631 \u06a9\u0627\u0645 \u06a9\u0631\u0646\u06d2 \u0648\u0627\u0644\u06cc \u0646\u0642\u0644 \u0645\u06a9\u0627\u0646\u06cc \u06a9\u0648 \u0644\u06a9\u06be\u0646\u0627 \u0635\u0631\u0641 \u0622\u062f\u06be\u06cc \u062c\u0646\u06af \u06c1\u06d2\u06d4 \u06c1\u062c\u0631\u062a\u06cc\u06ba \u0644\u06a9\u06be\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u067e\u0648\u0631\u06cc \u0679\u06cc\u0645 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0646\u0638\u0645 \u0648 \u0636\u0628\u0637 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u0648\u062a\u06cc \u06c1\u06d2 \u062c\u0633\u06d2 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0645\u06cc\u06ba \u0645\u062d\u0641\u0648\u0638 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u06cc\u0627 \u062c\u0627 \u0633\u06a9\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<p>\u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0627 \u0627\u0646\u062a\u0638\u0627\u0645 \u06a9\u0631\u062a\u06d2 \u0648\u0642\u062a \u0627\u067e\u0646\u0627\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u0646\u062c\u06cc\u0646\u0626\u0631\u0646\u06af \u06a9\u06d2 \u0628\u06c1\u062a\u0631\u06cc\u0646 \u0637\u0631\u06cc\u0642\u0648\u06ba \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06c1\u06cc\u06ba:<\/p>\n<h3 id=\"heading-1-one-logical-change-per-changeset-the-atomic-rule\">1. \u0627\u06cc\u06a9 \u0645\u0646\u0637\u0642\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc \u0641\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc \u0633\u06cc\u0679 (\u0627\u06cc\u0679\u0645\u06cc \u0627\u0635\u0648\u0644)<\/h3>\n<p>\u06c1\u0645 \u0646\u06d2 \u0639\u0627\u0645 \u063a\u0644\u0637\u06cc\u0648\u06ba \u06a9\u06d2 \u0633\u06cc\u06a9\u0634\u0646 \u0645\u06cc\u06ba \u0627\u0633 \u067e\u0631 \u062a\u0628\u0627\u062f\u0644\u06c1 \u062e\u06cc\u0627\u0644 \u06a9\u06cc\u0627 \u06c1\u06d2\u060c \u0644\u06cc\u06a9\u0646 \u0627\u0633 \u06a9\u0648 \u062f\u06c1\u0631\u0627\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u06a9\u0627\u0641\u06cc \u0636\u0631\u0648\u0631\u06cc \u06c1\u06d2\u06d4 \u0679\u06cc\u0628\u0644 \u06a9\u06cc \u062a\u062e\u0644\u06cc\u0642\u060c \u0627\u0646\u0688\u06cc\u06a9\u0633 \u06a9\u06cc \u062a\u062e\u0644\u06cc\u0642\u060c \u0627\u0648\u0631 \u0688\u06cc\u0679\u0627 \u06a9\u06d2 \u0627\u0646\u062f\u0631\u0627\u062c \u06a9\u0648 \u0627\u06cc\u06a9 \u06c1\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc \u06a9\u06d2 \u0633\u06cc\u0679 \u0645\u06cc\u06ba \u0646\u06c1 \u0628\u0627\u0646\u062f\u06be\u06cc\u06ba\u06d4<\/p>\n<p>\u0627\u06af\u0631 \u0622\u067e \u062a\u0646\u062e\u0648\u0627\u06c1 \u06a9\u0627 \u06a9\u0627\u0644\u0645 \u0627\u0648\u0631 idx_employee_salary \u0627\u0646\u0688\u06cc\u06a9\u0633 \u0634\u0627\u0645\u0644 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u062a\u0648 \u0627\u0646\u06c1\u06cc\u06ba \u0627\u06cc\u06a9 \u06c1\u06cc \u0641\u0627\u0626\u0644 \u0645\u06cc\u06ba \u062f\u0648 \u0627\u0644\u06af \u0627\u0644\u06af ChangeSets \u0645\u06cc\u06ba \u0688\u0627\u0644\u06cc\u06ba\u06d4 \u0627\u0633 \u0637\u0631\u062d\u060c \u06cc\u06c1\u0627\u06ba \u062a\u06a9 \u06a9\u06c1 \u0627\u06af\u0631 \u0627\u0646\u0688\u06cc\u06a9\u0633 \u06a9\u06cc \u062a\u062e\u0644\u06cc\u0642 \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648\u062c\u0627\u062a\u06cc \u06c1\u06d2\u060c \u06a9\u0627\u0644\u0645 \u06a9\u06cc \u062a\u062e\u0644\u06cc\u0642 \u0645\u062d\u0641\u0648\u0638 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u0644\u0627\u06af \u0627\u0646 \u06c1\u0648\u062c\u0627\u062a\u06cc \u06c1\u06d2 \u0627\u0648\u0631 \u06a9\u0648\u0626\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06cc\u062a\u06cc\u0645 \u062d\u0627\u0644\u062a \u0646\u06c1\u06cc\u06ba \u06c1\u0648\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-2-meaningful-file-organization-and-naming\">2. \u0641\u0627\u0626\u0644\u0648\u06ba \u06a9\u0648 \u0628\u0627\u0645\u0639\u0646\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0645\u0646\u0638\u0645 \u0627\u0648\u0631 \u0646\u0627\u0645 \u062f\u06cc\u06ba\u06d4<\/h3>\n<p>\u0641\u0627\u0626\u0644 \u06a9\u0627 \u0646\u0627\u0645 \u0645\u062a\u0639\u06cc\u0646 \u0646\u06c1 \u06a9\u0631\u06cc\u06ba\u06d4 <code>update1.xml<\/code> \u06cc\u0627 <code>new_changes.xml<\/code>. \u0641\u0627\u0626\u0644 \u06a9\u0627 \u0646\u0627\u0645 \u06cc\u06c1 \u0628\u062a\u0627\u062a\u0627 \u06c1\u06d2 \u06a9\u06c1 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc\u0633\u06d2 \u062a\u06cc\u0627\u0631 \u06c1\u0648\u0627\u06d4<\/p>\n<p>\u0627\u06cc\u06a9 \u0633\u062e\u062a \u0633\u0627\u0628\u0642\u06c1 \u200b\u200b\u0646\u0638\u0627\u0645 \u06a9\u0648 \u0627\u067e\u0646\u0627\u0626\u06cc\u06ba. \u06c1\u0645\u0627\u0631\u06d2 \u0645\u0646\u0635\u0648\u0628\u06d2 \u0645\u06cc\u06ba \u06c1\u0645 <code>01-create-employees.xml<\/code> \u0627\u0648\u0631 <code>02-add-employee-email.xml<\/code>. \u0627\u0635\u0644\u06cc \u0679\u06cc\u0645\u06cc\u06ba \u062c\u06cc\u0631\u0627 \u0679\u06a9\u0679 \u0646\u0645\u0628\u0631 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631 \u0633\u06a9\u062a\u06cc \u06c1\u06cc\u06ba \u06cc\u0627 \u0648\u0631\u0698\u0646 \u062c\u0627\u0631\u06cc \u06a9\u0631 \u0633\u06a9\u062a\u06cc \u06c1\u06cc\u06ba\u060c \u062c\u06cc\u0633\u06d2 <code>v1.2.0_ticket-482_add_email.xml<\/code>)\u06d4 \u0622\u067e \u062c\u0648 \u0628\u06be\u06cc \u0627\u0635\u0648\u0644 \u0645\u0646\u062a\u062e\u0628 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u06a9\u0648\u0688 \u06a9\u06d2 \u062c\u0627\u0626\u0632\u0648\u06ba \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646 \u0627\u0646\u06c1\u06cc\u06ba \u0633\u062e\u062a\u06cc \u0633\u06d2 \u0646\u0627\u0641\u0630 \u06a9\u0631\u06cc\u06ba\u06d4<\/p>\n<h3 id=\"heading-3-treat-database-changes-like-application-code\">3. \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648\u0688 \u06a9\u06cc \u0637\u0631\u062d \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u06c1\u06cc\u0646\u0688\u0644 \u06a9\u0631\u06cc\u06ba\u06d4<\/h3>\n<p>\u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u062c\u0627\u0648\u0627 \u06a9\u0648\u0688 \u06a9\u06d2 \u0628\u0627\u0644\u06a9\u0644 \u0622\u06af\u06d2 \u0633\u0648\u0631\u0633 \u06a9\u0646\u0679\u0631\u0648\u0644 \u0645\u06cc\u06ba \u06c1\u06d2\u06d4 \u0627\u0646\u06c1\u06cc\u06ba \u0628\u0627\u0644\u06a9\u0644 \u0627\u0633\u06cc \u0633\u0637\u062d \u06a9\u06cc \u062c\u0627\u0646\u0686 \u067e\u0691\u062a\u0627\u0644 \u06a9\u06d2 \u0633\u0627\u062a\u06be \u062c\u0627\u0646\u0686\u0627 \u062c\u0627\u0646\u0627 \u0686\u0627\u06c1\u0626\u06d2\u06d4<\/p>\n<p>Liquibase \u0641\u0627\u0626\u0644\u0648\u06ba \u067e\u0631 \u0645\u0634\u062a\u0645\u0644 \u067e\u0644 \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0627 \u062c\u0627\u0626\u0632\u06c1 \u0644\u06cc\u062a\u06d2 \u0648\u0642\u062a\u060c \u0627\u0646\u062c\u06cc\u0646\u0626\u0631\u0632 \u06a9\u0648 \u067e\u0648\u0686\u06be\u0646\u0627 \u0686\u0627\u06c1\u0626\u06d2:<\/p>\n<ul wp_automatic_readability=\"0.5\">\n<li wp_automatic_readability=\"-1\">\n<p>\u06a9\u06cc\u0627 \u0645\u062c\u06be\u06d2 \u0627\u0633 \u06a9\u0627\u0644\u0645 \u067e\u0631 \u0627\u0646\u0688\u06cc\u06a9\u0633 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u061f<\/p>\n<\/li>\n<li wp_automatic_readability=\"0\">\n<p>\u06a9\u06cc\u0627 \u06cc\u06c1 \u0627\u06cc\u06a9 \u062a\u0628\u0627\u06c1 \u06a9\u0646 \u062a\u0628\u062f\u06cc\u0644\u06cc \u06c1\u06d2 (\u0645\u062b\u0644\u0627\u064b \u06a9\u0627\u0644\u0645 \u06a9\u0627 \u0646\u0627\u0645 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u0646\u0627) \u062c\u0648 \u0627\u0633 \u0648\u0642\u062a \u0686\u0644 \u0631\u06c1\u06cc \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u062a\u0648\u0691 \u062f\u06cc\u062a\u06cc \u06c1\u06d2\u061f<\/p>\n<\/li>\n<li wp_automatic_readability=\"-1\">\n<p>\u06a9\u06cc\u0627 \u0645\u0635\u0646\u0641 \u0646\u06d2 \u062d\u0633\u0628 \u0636\u0631\u0648\u0631\u062a SQL \u06a9\u06d2 \u0644\u06cc\u06d2 \u0648\u0627\u0636\u062d \u0631\u0648\u0644 \u0628\u06cc\u06a9 \u06c1\u062f\u0627\u06cc\u0627\u062a \u0634\u0627\u0645\u0644 \u06a9\u06cc \u06c1\u06cc\u06ba\u061f<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-4-integrate-migrations-into-cicd\">4. \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0648 CI\/CD \u0645\u06cc\u06ba \u0636\u0645 \u06a9\u0631\u06cc\u06ba\u06d4<\/h3>\n<p>\u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u06cc \u0645\u0646\u062a\u0642\u0644\u06cc \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0633\u0631\u0648\u0631\u0632 \u06a9\u06d2 \u062e\u0644\u0627\u0641 \u062f\u0633\u062a\u06cc \u0637\u0648\u0631 \u067e\u0631 \u0646\u06c1\u06cc\u06ba \u06a9\u06cc \u062c\u0627\u0646\u06cc \u0686\u0627\u06c1\u06cc\u06d2\u06d4 \u0622\u067e \u06a9\u06cc \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 \u06a9\u0648 \u0627\u0633\u06d2 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u06c1\u06cc\u0646\u0688\u0644 \u06a9\u0631\u0646\u0627 \u0686\u0627\u06c1\u06cc\u06d2\u06d4<\/p>\n<p>\u0627\u06cc\u06a9 \u0628\u0627\u0631 \u062c\u0628 \u0622\u067e \u0627\u067e\u0646\u06d2 \u06a9\u0648\u0688 \u06a9\u0648 \u0645\u06cc\u0646 \u0628\u0631\u0627\u0646\u0686 \u0645\u06cc\u06ba \u0636\u0645 \u06a9\u0631 \u0644\u06cc\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 \u0622\u067e \u06a9\u06cc CI\/CD \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 (\u062c\u06cc\u0633\u06d2 GitHub \u0627\u06cc\u06a9\u0634\u0646\u0632 \u06cc\u0627 GitLab CI) \u06a9\u0648 \u0622\u067e \u06a9\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u06cc \u062a\u0639\u0645\u06cc\u0631 \u0627\u0648\u0631 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u06a9\u0631\u0646\u06cc \u0686\u0627\u06c1\u06cc\u06d2\u06d4 \u0686\u0648\u0646\u06a9\u06c1 \u06c1\u0645 \u0646\u06d2 Liquibase \u06a9\u0648 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u06a9\u06d2 \u0622\u063a\u0627\u0632 \u06a9\u06d2 \u0633\u0644\u0633\u0644\u06d2 \u0645\u06cc\u06ba \u0628\u0646\u0688\u0644 \u06a9\u06cc\u0627 \u06c1\u06d2\u060c \u0627\u0633 \u0644\u06cc\u06d2 \u06c1\u0645\u0627\u0631\u06cc \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u06c1\u0645\u0627\u0631\u06d2 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0648\u06cc\u0628 \u0679\u0631\u06cc\u0641\u06a9 \u0645\u0648\u0635\u0648\u0644 \u06c1\u0648\u0646\u06d2 \u0633\u06d2 \u067e\u06c1\u0644\u06d2 \u0645\u0646\u062a\u0642\u0644 \u06a9\u0631 \u062f\u06cc\u062a\u06cc \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u06cc\u06a9 \u0645\u062d\u0641\u0648\u0638\u060c \u062e\u0648\u062f\u06a9\u0627\u0631 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 \u0645\u06cc\u06ba \u0634\u0627\u0645\u0644 \u06c1\u06cc\u06ba:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/umang.pk\/wp-content\/uploads\/2026\/06\/1780990582_940_Liquibase-\u0627\u0648\u0631-Spring-Boot-\u06a9\u06d2-\u0633\u0627\u062a\u06be-\u0688\u06cc\u0679\u0627-\u0628\u06cc\u0633-\u0648\u0631\u0698\u0646-\u06a9\u0646\u0679\u0631\u0648\u0644.png\" alt=\"CI\/CD \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 \u0622\u0631\u06a9\u06cc\u0679\u06cc\u06a9\u0686\u0631 \u062c\u0633 \u0645\u06cc\u06ba \u06a9\u0648\u0688 \u06a9\u0648 Git \u0633\u06d2 \u0679\u06cc\u0633\u0679\u0646\u06af \u06a9\u06cc \u0637\u0631\u0641 \u0644\u06d2 \u062c\u0627\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u060c Liquibase \u06a9\u0648 \u0686\u0644\u0627\u0646\u06d2 \u0648\u0627\u0644\u06d2 \u0627\u0633\u0679\u06cc\u062c\u0646\u06af \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u067e\u06be\u0631 \u0627\u0633\u06d2 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0645\u06cc\u06ba \u0641\u0631\u0648\u063a \u062f\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2\u06d4\" style=\"display:block;margin:0 auto\" width=\"600\" height=\"400\" loading=\"lazy\" title=\"\"><\/p>\n<p>\u0627\u06cc\u06a9 \u067e\u062e\u062a\u06c1 \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 \u0645\u06cc\u06ba\u060c \u0627\u0646\u0633\u0627\u0646\u06cc \u06c1\u0627\u062a\u06be \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u06a9\u0628\u06be\u06cc \u0646\u06c1\u06cc\u06ba \u0686\u06be\u0648\u062a\u06d2\u06d4 \u062c\u0628 \u0622\u067e \u067e\u0644 \u06a9\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0648 \u0636\u0645 \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba\u060c \u062a\u0648 CI\/CD \u067e\u0627\u0626\u067e \u0644\u0627\u0626\u0646 \u0622\u067e \u06a9\u0627 \u06a9\u0648\u0688 \u0628\u0646\u0627\u062a\u06cc \u06c1\u06d2 \u0627\u0648\u0631 \u06cc\u0648\u0646\u0679 \u0679\u06cc\u0633\u0679 \u0686\u0644\u0627\u062a\u06cc \u06c1\u06d2\u06d4 \u0627\u067e\u0646\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u0648 \u0627\u0633\u0679\u06cc\u062c\u0646\u06af \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u062a\u0639\u06cc\u0646\u0627\u062a \u06a9\u0631\u06cc\u06ba \u062c\u06c1\u0627\u06ba Liquibase \u062e\u0648\u062f \u0628\u062e\u0648\u062f \u0644\u0627\u06a9 \u062d\u0627\u0635\u0644 \u06a9\u0631 \u0644\u06cc\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0633\u0679\u0627\u0631\u0679 \u0627\u067e \u06a9\u06d2 \u062f\u0648\u0631\u0627\u0646 \u06c1\u062c\u0631\u062a \u0686\u0644\u0627\u062a\u0627 \u06c1\u06d2\u06d4 \u0627\u06cc\u06a9 \u0628\u0627\u0631 \u062a\u0648\u062b\u06cc\u0642 \u06c1\u0648\u062c\u0627\u0646\u06d2 \u06a9\u06d2 \u0628\u0639\u062f\u060c \u0627\u0633\u06cc \u0622\u0631\u0679\u0641\u06cc\u06a9\u0679 \u06a9\u0648 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646 \u0645\u06cc\u06ba \u0641\u0631\u0648\u063a \u062f\u06cc\u0627 \u062c\u0627\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0648\u06c1\u06cc \u062e\u0648\u062f\u06a9\u0627\u0631 \u0645\u0646\u062a\u0642\u0644\u06cc \u06a9\u0627 \u0639\u0645\u0644 \u0634\u0631\u0648\u0639 \u06c1\u0648\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<h3 id=\"heading-5-never-fix-forward-by-deleting-history\">5. \u0645\u0633\u062a\u0642\u0628\u0644 \u0645\u06cc\u06ba \u062a\u0631\u0645\u06cc\u0645 \u0633\u06d2 \u0628\u0686\u0646\u06d2 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u067e\u0646\u06d2 \u0631\u06cc\u06a9\u0627\u0631\u0688\u0632 \u06a9\u0648 \u062d\u0630\u0641 \u06a9\u0631\u06cc\u06ba\u06d4<\/h3>\n<p>\u0627\u06af\u0631 \u0645\u0646\u062a\u0642\u0644\u06cc \u0648\u0627\u0644\u062f\u06cc\u0646 \u06a9\u06d2 \u0645\u0627\u062d\u0648\u0644 \u0645\u06cc\u06ba \u0646\u0627\u06a9\u0627\u0645 \u06c1\u0648 \u062c\u0627\u062a\u06cc \u06c1\u06d2 (\u062c\u06cc\u0633\u06d2 \u0633\u0679\u06cc\u062c\u0646\u06af \u06cc\u0627 \u067e\u0631\u0648\u0688\u06a9\u0634\u0646)\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0645\u06cc\u06ba \u0644\u0627\u06af \u0627\u0646 \u06a9\u0631\u06cc\u06ba \u0627\u0648\u0631 <code>DATABASECHANGELOG<\/code> \u0622\u067e \u062f\u0648\u0628\u0627\u0631\u06c1 \u06a9\u0648\u0634\u0634 \u06a9\u0631 \u0633\u06a9\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u062a\u0628\u062f\u06cc\u0644\u06cc \u0644\u0627\u06af \u06a9\u06cc \u0639\u062f\u0645 \u062a\u063a\u06cc\u0631 \u06a9\u0627 \u0627\u062d\u062a\u0631\u0627\u0645 \u06a9\u06cc\u0627 \u062c\u0627\u0646\u0627 \u0686\u0627\u06c1\u06cc\u06d2\u06d4 \u0627\u06af\u0631 \u0622\u067e \u063a\u0644\u0637\u06cc \u06a9\u0631\u062a\u06d2 \u06c1\u06cc\u06ba \u062a\u0648 \u0679\u0648\u0679\u06d2 \u06c1\u0648\u0626\u06d2 \u0679\u06cc\u0628\u0644 \u06a9\u0648 \u062d\u0630\u0641 \u06a9\u0631\u06cc\u06ba \u06cc\u0627 \u0627\u06cc\u06a9 \u0646\u06cc\u0627 ChangeSet \u0628\u0646\u0627\u0626\u06cc\u06ba \u062c\u0648 \u0688\u06cc\u0679\u0627 \u06a9\u06cc \u0642\u0633\u0645 \u06a9\u0648 \u0679\u06be\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2 \u0627\u0648\u0631 \u0627\u0633\u06d2 \u062c\u0627\u0648\u0627 \u0628\u06af \u0641\u06a9\u0633 \u06a9\u06cc \u0637\u0631\u062d Git \u0648\u0631\u06a9 \u0641\u0644\u0648 \u06a9\u06d2 \u0630\u0631\u06cc\u0639\u06d2 \u0622\u06af\u06d2 \u0628\u0691\u06be\u0627\u062a\u0627 \u06c1\u06d2\u06d4<\/p>\n<h2 id=\"heading-final-thoughts\">\u062d\u062a\u0645\u06cc \u062e\u06cc\u0627\u0644\u0627\u062a<\/h2>\n<p>\u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0627 \u0627\u0646\u062a\u0638\u0627\u0645 \u06a9\u0631\u0646\u0627 \u067e\u0631\u06cc\u0634\u0627\u0646\u06cc \u06a9\u0627 \u0628\u0627\u0639\u062b \u0646\u06c1\u06cc\u06ba \u06c1\u06d2\u06d4<\/p>\n<p>\u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u06a9\u0648 \u06a9\u0648\u0688 \u06a9\u06d2 \u0637\u0648\u0631 \u067e\u0631 \u0627\u0633\u062a\u0639\u0645\u0627\u0644 \u06a9\u0631\u0646\u06d2 \u0633\u06d2 \u062f\u0633\u062a\u06cc \u0627\u06cc\u0633 \u06a9\u06cc\u0648 \u0627\u06cc\u0644 \u0627\u0633\u06a9\u0631\u067e\u0679\u0633 \u06a9\u06cc \u0628\u06d2 \u062a\u0631\u062a\u06cc\u0628\u06cc \u062e\u062a\u0645 \u06c1\u0648\u062c\u0627\u062a\u06cc \u06c1\u06d2\u06d4 \u06cc\u06c1 \u062e\u0648\u0641\u0646\u0627\u06a9 &quot;\u0627\u0633\u06a9\u06cc\u0645\u0627 \u0688\u0631\u0641\u0679&#8221; \u06a9\u0648 \u0631\u0648\u06a9\u062a\u0627 \u06c1\u06d2\u060c \u062c\u06c1\u0627\u06ba \u06c1\u0631 \u0688\u0648\u06cc\u0644\u067e\u0631 \u06a9\u0627 \u0645\u0642\u0627\u0645\u06cc \u06a9\u0645\u067e\u06cc\u0648\u0679\u0631 \u0645\u062e\u062a\u0644\u0641 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u0628\u0631\u062a\u0627\u0624 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0633\u0628 \u0633\u06d2 \u0627\u06c1\u0645 \u0628\u0627\u062a \u06cc\u06c1 \u06c1\u06d2 \u06a9\u06c1 \u0622\u067e \u0627\u067e\u0646\u06cc \u062a\u0639\u06cc\u0646\u0627\u062a\u06cc \u06a9\u0648 \u0642\u0627\u0628\u0644 \u067e\u06cc\u0634\u0646 \u06af\u0648\u0626\u06cc \u0627\u0648\u0631 \u0628\u0648\u0631\u0646\u06af \u0628\u0646\u0627\u0626\u06cc\u06ba\u06d4 \u06cc\u06c1 \u0648\u06c1 \u062a\u0642\u0633\u06cc\u0645 \u06c1\u06d2 \u062c\u0648 \u0622\u067e \u0686\u0627\u06c1\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u0627\u0633 \u0679\u06cc\u0648\u0679\u0648\u0631\u06cc\u0644 \u0645\u06cc\u06ba\u060c \u06c1\u0645 \u0646\u06d2 \u0634\u0631\u0648\u0639 \u0633\u06d2 \u0627\u06cc\u06a9 \u0639\u0645\u0644\u06cc \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u0627\u06cc\u067e\u0644\u06cc \u06a9\u06cc\u0634\u0646 \u0628\u0646\u0627\u06cc\u0627 \u06c1\u06d2\u06d4 \u0622\u067e \u0646\u06d2 \u0633\u06cc\u06a9\u06be\u0627 \u06a9\u06c1 Liquibase \u06a9\u0633 \u0637\u0631\u062d \u0627\u06cc\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06a9\u06d2 \u0622\u063a\u0627\u0632 \u06a9\u0648 \u06c1\u0627\u0626\u06cc \u062c\u06cc\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0648 \u0644\u0627\u06a9 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u060c \u062e\u0641\u06cc\u06c1 \u0686\u06cc\u06a9\u0633\u0645 \u06a9\u0627 \u062d\u0633\u0627\u0628 \u0644\u06af\u0627\u062a\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u0645\u062d\u0641\u0648\u0638 \u0637\u0631\u06cc\u0642\u06d2 \u0633\u06d2 \u0628\u0691\u06be\u062a\u06cc \u06c1\u0648\u0626\u06cc \u062a\u0628\u062f\u06cc\u0644\u06cc\u0648\u06ba \u06a9\u0648 \u0644\u0627\u06af\u0648 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0622\u067e \u0646\u06d2 \u0627\u06cc\u06a9 \u062c\u062f\u0648\u0644 \u06a9\u0648 \u0627\u06cc\u06a9 \u0631\u0634\u062a\u06c1 \u062f\u0627\u0631 \u0627\u0633\u06a9\u06cc\u0645\u0627 \u0645\u06cc\u06ba \u062a\u06cc\u0627\u0631 \u06a9\u06cc\u0627 \u06c1\u06d2\u060c \u0628\u06cc\u062c \u06a9\u0627 \u0688\u06cc\u0679\u0627 \u0634\u0627\u0645\u0644 \u06a9\u06cc\u0627 \u06c1\u06d2\u060c \u0627\u0648\u0631 \u0633\u06cc\u06a9\u06be\u0627 \u06c1\u06d2 \u06a9\u06c1 \u06a9\u0633 \u0637\u0631\u062d \u0633\u0628 \u0633\u06d2 \u0639\u0627\u0645 \u062e\u0631\u0627\u0628\u06cc\u0648\u06ba \u0633\u06d2 \u0628\u0686\u0646\u0627 \u06c1\u06d2 \u062c\u0646 \u0645\u06cc\u06ba \u0627\u0628\u062a\u062f\u0627\u0626\u06cc \u0627\u0641\u0631\u0627\u062f \u067e\u0691\u062a\u06d2 \u06c1\u06cc\u06ba\u06d4<\/p>\n<p>\u0627\u06af\u0644\u06cc \u0628\u0627\u0631 \u062c\u0628 \u0622\u067e \u0627\u067e\u0646\u0627 \u0627\u0633\u067e\u0631\u0646\u06af \u0628\u0648\u0679 \u067e\u0631\u0648\u062c\u06cc\u06a9\u0679 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba \u062a\u0648 \u062f\u0633\u062a\u06cc SQL \u06a9\u0644\u0627\u0626\u0646\u0679 \u062a\u06a9 \u0631\u0633\u0627\u0626\u06cc \u0646\u06c1 \u06a9\u0631\u06cc\u06ba\u06d4 Liquibase \u0627\u0646\u062d\u0635\u0627\u0631 \u0634\u0627\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u060c \u0627\u06cc\u06a9 \u0645\u0627\u0633\u0679\u0631 \u062a\u0628\u062f\u06cc\u0644\u06cc \u0644\u0627\u06af \u0628\u0646\u0627\u0626\u06cc\u06ba\u060c \u0627\u0648\u0631 \u0627\u067e\u0646\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u0648\u0631\u0698\u0646 \u06a9\u0648 \u067e\u06c1\u0644\u06d2 \u062f\u0646 \u0633\u06d2 \u06a9\u0646\u0679\u0631\u0648\u0644 \u06a9\u0631\u0646\u0627 \u0634\u0631\u0648\u0639 \u06a9\u0631\u06cc\u06ba\u06d4 \u0622\u067e \u06a9\u0627 \u0645\u0633\u062a\u0642\u0628\u0644 \u062e\u0648\u062f (\u0627\u0648\u0631 \u0622\u067e \u06a9\u06cc \u0679\u06cc\u0645) \u0622\u067e \u06a9\u0627 \u0634\u06a9\u0631\u06cc\u06c1 \u0627\u062f\u0627 \u06a9\u0631\u06d2 \u06af\u0627\u06d4<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u062f\u0631\u062c \u0630\u06cc\u0644 \u0645\u0627\u0646\u0648\u0633 \u0645\u0646\u0638\u0631 \u0646\u0627\u0645\u06d2 \u067e\u0631 \u063a\u0648\u0631 \u06a9\u0631\u06cc\u06ba: \u0645\u06cc\u06ba \u0627\u06cc\u06a9 \u0646\u0626\u06cc \u062e\u0635\u0648\u0635\u06cc\u062a \u067e\u0631 \u06a9\u0627\u0645 \u06a9\u0631 \u0631\u06c1\u0627 \u06c1\u0648\u06ba \u062c\u0633 \u06a9\u06d2 \u0644\u06cc\u06d2 \u0627\u06cc\u06a9 \u0646\u0626\u06d2 \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0627\u0644\u0645 \u06a9\u06cc \u0636\u0631\u0648\u0631\u062a \u06c1\u06d2\u06d4 \u0627\u067e\u0646\u06d2 \u0645\u0642\u0627\u0645\u06cc \u0688\u06cc\u0679\u0627 \u0628\u06cc\u0633 \u06a9\u0644\u0627\u0626\u0646\u0679 \u06a9\u0648 \u06a9\u06be\u0648\u0644\u06cc\u06ba \u0627\u0648\u0631 ALTER TABLE \u0628\u06cc\u0627\u0646\u0627\u062a \u0644\u06a9\u06be\u06cc\u06ba \u0627\u0648\u0631 \u0627\u0646 \u067e\u0631 \u0639\u0645\u0644 \u06a9\u0631\u06cc\u06ba\u06d4 \u06a9\u0648\u0688 \u0628\u0627\u0644\u06a9\u0644 \u06a9\u0627\u0645 \u06a9\u0631\u062a\u0627 \u06c1\u06d2\u06d4 \u0622\u067e \u0627\u067e\u0646\u06d2 \u062c\u0627\u0648\u0627 \u06a9\u0648\u0688 \u06a9\u0627 [&hellip;]<\/p>\n","protected":false},"author":7,"featured_media":25116,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"site-sidebar-layout":"default","site-content-layout":"","ast-site-content-layout":"default","site-content-style":"default","site-sidebar-style":"default","ast-global-header-display":"","ast-banner-title-visibility":"","ast-main-header-display":"","ast-hfb-above-header-display":"","ast-hfb-below-header-display":"","ast-hfb-mobile-header-display":"","site-post-title":"","ast-breadcrumbs-content":"","ast-featured-img":"","footer-sml-layout":"","ast-disable-related-posts":"","theme-transparent-header-meta":"","adv-header-id-meta":"","stick-header-meta":"","header-above-stick-meta":"","header-main-stick-meta":"","header-below-stick-meta":"","astra-migrate-meta-layouts":"default","ast-page-background-enabled":"default","ast-page-background-meta":{"desktop":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"ast-content-background-meta":{"desktop":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"footnotes":""},"categories":[1],"tags":[],"class_list":["post-25115","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-blog"],"_links":{"self":[{"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/posts\/25115","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/users\/7"}],"replies":[{"embeddable":true,"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/comments?post=25115"}],"version-history":[{"count":1,"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/posts\/25115\/revisions"}],"predecessor-version":[{"id":25117,"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/posts\/25115\/revisions\/25117"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/media\/25116"}],"wp:attachment":[{"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/media?parent=25115"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/categories?post=25115"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/umang.pk\/ur\/wp-json\/wp\/v2\/tags?post=25115"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}