{"id":17148,"date":"2025-11-15T12:22:07","date_gmt":"2025-11-15T08:52:07","guid":{"rendered":"https:\/\/www.itpiran.net\/blog\/?p=17148"},"modified":"2025-11-16T12:55:26","modified_gmt":"2025-11-16T09:25:26","slug":"complete-tutorial-on-roles-and-permissions-in-postgresql","status":"publish","type":"post","link":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/","title":{"rendered":"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL"},"content":{"rendered":"<h2 id=\"%d9%85%d9%82%d8%af%d9%85%d9%87\" data-start=\"375\" data-end=\"387\">\u0645\u0642\u062f\u0645\u0647<\/h2>\n<p data-start=\"388\" data-end=\"810\">PostgreSQL \u06cc\u06a9 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0648 Enterprise-Grade \u0627\u0633\u062a \u06a9\u0647 \u0633\u06cc\u0633\u062a\u0645 \u067e\u06cc\u0634\u0631\u0641\u062a\u0647\u200c\u0627\u06cc \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0648 \u0633\u0637\u062d \u062f\u0633\u062a\u0631\u0633\u06cc\u200c\u0647\u0627 \u062f\u0627\u0631\u062f. \u062f\u0631 PostgreSQL \u0686\u06cc\u0632\u06cc \u062a\u062d\u062a \u0639\u0646\u0648\u0627\u0646 &#8220;User&#8221; \u0628\u0647 \u0634\u06a9\u0644 \u0633\u0646\u062a\u06cc \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f\u061b \u0647\u0645\u0647 \u0686\u06cc\u0632 \u06cc\u06a9 <strong data-start=\"574\" data-end=\"582\">Role<\/strong> \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0631\u0641\u062a\u0627\u0631 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u06cc\u0627 \u06cc\u06a9 \u06af\u0631\u0648\u0647 \u0631\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<br data-start=\"639\" data-end=\"642\" \/>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0635\u062d\u06cc\u062d \u0627\u0632 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u062f\u0633\u062a\u0631\u0633\u06cc\u200c\u0647\u0627 \u0628\u0627\u0639\u062b \u0627\u0641\u0632\u0627\u06cc\u0634 \u0627\u0645\u0646\u06cc\u062a\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u0628\u0647\u062a\u0631 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633\u200c\u0647\u0627 \u0648 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062f\u0633\u062a\u0631\u0633\u06cc\u200c\u0647\u0627\u06cc \u0646\u0627\u062e\u0648\u0627\u0633\u062a\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f\u2014\u0628\u0647\u200c\u062e\u0635\u0648\u0635 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0627\u062c\u0631\u0627 \u0645\u06cc\u200c\u0634\u0648\u062f..<\/p>\n<hr data-start=\"972\" data-end=\"975\" \/>\n<h1 id=\"%db%b1-%d9%be%db%8c%d8%b4%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7%db%8c-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-roles-%d9%88-permissions\" data-start=\"977\" data-end=\"1024\">\u06f1. \u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions<\/h1>\n<p data-start=\"1025\" data-end=\"1065\">\u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u06a9\u0627\u0631 \u0628\u0627\u06cc\u062f \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u0641\u0631\u0627\u0647\u0645 \u0628\u0627\u0634\u062f:<\/p>\n<ul data-start=\"1067\" data-end=\"1188\">\n<li data-start=\"1067\" data-end=\"1111\">\n<p data-start=\"1069\" data-end=\"1111\">\u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc (\u0645\u062b\u0644 Ubuntu 20.04 \u06cc\u0627 22.04)<\/p>\n<\/li>\n<li data-start=\"1112\" data-end=\"1133\">\n<p data-start=\"1114\" data-end=\"1133\">\u0646\u0635\u0628 \u0628\u0648\u062f\u0646 PostgreSQL<\/p>\n<\/li>\n<li data-start=\"1134\" data-end=\"1161\">\n<p data-start=\"1136\" data-end=\"1161\">\u062f\u0633\u062a\u0631\u0633\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0631\u06cc\u0634\u0647 \u06cc\u0627 sudo<\/p>\n<\/li>\n<li data-start=\"1162\" data-end=\"1188\">\n<p data-start=\"1164\" data-end=\"1188\">\u0622\u0634\u0646\u0627\u06cc\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0628\u0627 \u062e\u0637 \u0641\u0631\u0645\u0627\u0646<\/p>\n<\/li>\n<\/ul>\n<p data-start=\"1190\" data-end=\"1212\">\u0648\u0631\u0648\u062f \u0628\u0647 \u062d\u0633\u0627\u0628 postgres:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>sudo -i -u postgres\r\npsql<\/code><\/pre>\n<hr \/>\n<h1 id=\"%db%b2-%d9%85%d8%b4%d8%a7%d9%87%d8%af%d9%87-%d9%86%d9%82%d8%b4%d9%87%d8%a7-%d8%af%d8%b1-postgresql\" data-start=\"1257\" data-end=\"1293\">\u06f2. \u0645\u0634\u0627\u0647\u062f\u0647 \u0646\u0642\u0634\u200c\u0647\u0627 \u062f\u0631 PostgreSQL<\/h1>\n<p data-start=\"1295\" data-end=\"1326\">\u0628\u0631\u0627\u06cc \u0645\u0634\u0627\u0647\u062f\u0647 \u062a\u0645\u0627\u0645 \u0646\u0642\u0634\u200c\u0647\u0627\u06cc \u0645\u0648\u062c\u0648\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>\\du<\/code><\/pre>\n<p data-start=\"1344\" data-end=\"1356\">\u0646\u0645\u0648\u0646\u0647 \u062e\u0631\u0648\u062c\u06cc:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>Role name | Attributes | Member of\r\n-----------+----------------------------------------------+-----------\r\npostgres | Superuser, Create role, Create DB, Replicate | {}<\/code><\/pre>\n<hr \/>\n<h1 id=\"%db%b3-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%d9%86%d9%82%d8%b4-role-%d8%ac%d8%af%db%8c%d8%af\" data-start=\"1575\" data-end=\"1605\">\u06f3. \u0627\u06cc\u062c\u0627\u062f \u0646\u0642\u0634 (Role) \u062c\u062f\u06cc\u062f<\/h1>\n<h2 id=\"%d8%b1%d9%88%d8%b4-%d8%a7%d9%88%d9%84-%d8%b3%d8%a7%d8%ae%d8%aa-%d9%86%d9%82%d8%b4-%d8%a7%d8%b2-%d8%af%d8%a7%d8%ae%d9%84-psql\" data-start=\"1607\" data-end=\"1644\">\u0631\u0648\u0634 \u0627\u0648\u0644: \u0633\u0627\u062e\u062a \u0646\u0642\u0634 \u0627\u0632 \u062f\u0627\u062e\u0644 psql<\/h2>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>CREATE ROLE user_demo;<\/code><\/pre>\n<p data-start=\"1680\" data-end=\"1735\">\u0627\u06cc\u0646 \u0646\u0642\u0634 \u0647\u0646\u0648\u0632 \u0627\u062c\u0627\u0632\u0647 \u0648\u0631\u0648\u062f \u0646\u062f\u0627\u0631\u062f (Login Permission \u0646\u062f\u0627\u0631\u062f).<\/p>\n<h2 id=\"%d8%b1%d9%88%d8%b4-%d8%af%d9%88%d9%85-%d8%b3%d8%a7%d8%ae%d8%aa-%d9%86%d9%82%d8%b4-%d8%a8%d8%a7-%d8%a7%d9%85%da%a9%d8%a7%d9%86%d8%a7%d8%aa-%d9%85%d8%b4%d8%ae%d8%b5\" data-start=\"1737\" data-end=\"1777\">\u0631\u0648\u0634 \u062f\u0648\u0645: \u0633\u0627\u062e\u062a \u0646\u0642\u0634 \u0628\u0627 \u0627\u0645\u06a9\u0627\u0646\u0627\u062a \u0645\u0634\u062e\u0635<\/h2>\n<p data-start=\"1778\" data-end=\"1809\">\u0645\u062b\u0627\u0644: \u0646\u0642\u0634 \u0642\u0627\u0628\u0644 \u0648\u0631\u0648\u062f \u0628\u0627 \u0631\u0645\u0632\u0639\u0628\u0648\u0631:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>CREATE ROLE user_demo WITH LOGIN PASSWORD 'StrongPass123';\r\n<\/code><\/pre>\n<h2 id=\"%d8%b1%d9%88%d8%b4-%d8%b3%d9%88%d9%85-%d8%b3%d8%a7%d8%ae%d8%aa-%d9%86%d9%82%d8%b4-%d8%a7%d8%b2-%d8%b7%d8%b1%db%8c%d9%82-cli\" data-start=\"1882\" data-end=\"1918\">\u0631\u0648\u0634 \u0633\u0648\u0645: \u0633\u0627\u062e\u062a \u0646\u0642\u0634 \u0627\u0632 \u0637\u0631\u06cc\u0642 CLI<\/h2>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>createuser --interactive<\/code><\/pre>\n<p data-start=\"1957\" data-end=\"1987\">\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0627\u0632 \u0634\u0645\u0627 \u0633\u0624\u0627\u0644 \u0645\u06cc\u200c\u0634\u0648\u062f:<\/p>\n<ul data-start=\"1989\" data-end=\"2081\">\n<li data-start=\"1989\" data-end=\"2010\">\n<p data-start=\"1991\" data-end=\"2010\">\u0622\u06cc\u0627 \u0633\u0648\u067e\u0631 \u06cc\u0648\u0632\u0631 \u0628\u0627\u0634\u062f\u061f<\/p>\n<\/li>\n<li data-start=\"2011\" data-end=\"2047\">\n<p data-start=\"2013\" data-end=\"2047\">\u0622\u06cc\u0627 \u0627\u062c\u0627\u0632\u0647 \u0633\u0627\u062e\u062a \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u061f<\/p>\n<\/li>\n<li data-start=\"2048\" data-end=\"2081\">\n<p data-start=\"2050\" data-end=\"2081\">\u0622\u06cc\u0627 \u0627\u062c\u0627\u0632\u0647 \u0633\u0627\u062e\u062a Role \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u061f<\/p>\n<\/li>\n<\/ul>\n<hr \/>\n<h2 id=\"%db%b4-%d8%ad%d8%b0%d9%81-%d9%86%d9%82%d8%b4-%d8%af%d8%b1-postgresql\" data-start=\"2088\" data-end=\"2118\">\u06f4. \u062d\u0630\u0641 \u0646\u0642\u0634 \u062f\u0631 PostgreSQL<\/h2>\n<p data-start=\"2120\" data-end=\"2133\">\u067e\u0627\u06a9 \u06a9\u0631\u062f\u0646 \u0646\u0642\u0634:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>DROP ROLE user_demo;<\/code><\/pre>\n<p data-start=\"2168\" data-end=\"2206\">\u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062e\u0637\u0627 \u062f\u0631 \u0635\u0648\u0631\u062a \u0646\u0628\u0648\u062f\u0646 \u0646\u0642\u0634:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>DROP ROLE IF EXISTS user_demo;<\/code><\/pre>\n<hr \/>\n<h2 id=\"%db%b5-%d8%aa%d9%86%d8%b8%db%8c%d9%85%d8%a7%d8%aa-%d9%87%d9%86%da%af%d8%a7%d9%85-%d8%b3%d8%a7%d8%ae%d8%aa-role\" data-start=\"2256\" data-end=\"2288\">\u06f5. \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0647\u0646\u06af\u0627\u0645 \u0633\u0627\u062e\u062a Role<\/h2>\n<p data-start=\"2290\" data-end=\"2358\">PostgreSQL \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u0647\u0646\u06af\u0627\u0645 \u0633\u0627\u062e\u062a Role \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc \u0645\u0647\u0645 \u0631\u0627 \u062a\u0639\u06cc\u06cc\u0646 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>CREATE ROLE app_user\r\nWITH LOGIN\r\nCREATEDB\r\nNOCREATEROLE\r\nPASSWORD 'ExamplePass';<\/code><\/pre>\n<p data-start=\"2450\" data-end=\"2472\">\u0645\u0647\u0645\u200c\u062a\u0631\u06cc\u0646 Attribute \u0647\u0627:<\/p>\n<div class=\"_tableContainer_1rjym_1\">\n<div class=\"group _tableWrapper_1rjym_13 flex w-fit flex-col-reverse\" tabindex=\"-1\">\n<table data-start=\"2474\" data-end=\"2736\" class=\"w-fit min-w-(--thread-content-width)\">\n<thead data-start=\"2474\" data-end=\"2491\">\n<tr data-start=\"2474\" data-end=\"2491\">\n<th data-start=\"2474\" data-end=\"2482\" data-col-size=\"sm\">\u0648\u06cc\u0698\u06af\u06cc<\/th>\n<th data-start=\"2482\" data-end=\"2491\" data-col-size=\"sm\">\u062a\u0648\u0636\u06cc\u062d<\/th>\n<\/tr>\n<\/thead>\n<tbody data-start=\"2510\" data-end=\"2736\">\n<tr data-start=\"2510\" data-end=\"2543\">\n<td data-start=\"2510\" data-end=\"2518\" data-col-size=\"sm\">LOGIN<\/td>\n<td data-start=\"2518\" data-end=\"2543\" data-col-size=\"sm\">\u0627\u062c\u0627\u0632\u0647 \u0648\u0631\u0648\u062f \u0628\u0647 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633<\/td>\n<\/tr>\n<tr data-start=\"2544\" data-end=\"2577\">\n<td data-start=\"2544\" data-end=\"2555\" data-col-size=\"sm\">CREATEDB<\/td>\n<td data-start=\"2555\" data-end=\"2577\" data-col-size=\"sm\">\u0627\u062c\u0627\u0632\u0647 \u0633\u0627\u062e\u062a \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633<\/td>\n<\/tr>\n<tr data-start=\"2578\" data-end=\"2609\">\n<td data-start=\"2578\" data-end=\"2591\" data-col-size=\"sm\">CREATEROLE<\/td>\n<td data-start=\"2591\" data-end=\"2609\" data-col-size=\"sm\">\u0627\u062c\u0627\u0632\u0647 \u0633\u0627\u062e\u062a \u0646\u0642\u0634<\/td>\n<\/tr>\n<tr data-start=\"2610\" data-end=\"2648\">\n<td data-start=\"2610\" data-end=\"2620\" data-col-size=\"sm\">INHERIT<\/td>\n<td data-start=\"2620\" data-end=\"2648\" data-col-size=\"sm\">\u0627\u0631\u062b\u200c\u0628\u0631\u06cc \u0645\u062c\u0648\u0632 \u0627\u0632 \u0646\u0642\u0634 \u0645\u0627\u062f\u0631<\/td>\n<\/tr>\n<tr data-start=\"2649\" data-end=\"2676\">\n<td data-start=\"2649\" data-end=\"2661\" data-col-size=\"sm\">SUPERUSER<\/td>\n<td data-start=\"2661\" data-end=\"2676\" data-col-size=\"sm\">\u062f\u0633\u062a\u0631\u0633\u06cc \u06a9\u0627\u0645\u0644<\/td>\n<\/tr>\n<tr data-start=\"2677\" data-end=\"2700\">\n<td data-start=\"2677\" data-end=\"2688\" data-col-size=\"sm\">PASSWORD<\/td>\n<td data-start=\"2688\" data-end=\"2700\" data-col-size=\"sm\">\u0631\u0645\u0632 \u0639\u0628\u0648\u0631<\/td>\n<\/tr>\n<tr data-start=\"2701\" data-end=\"2736\">\n<td data-start=\"2701\" data-end=\"2715\" data-col-size=\"sm\">VALID UNTIL<\/td>\n<td data-start=\"2715\" data-end=\"2736\" data-col-size=\"sm\">\u062a\u0646\u0638\u06cc\u0645 \u062a\u0627\u0631\u06cc\u062e \u0627\u0646\u0642\u0636\u0627<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<hr data-start=\"2738\" data-end=\"2741\" \/>\n<h2 id=\"%db%b6-%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d8%aa%d9%86%d8%b8%db%8c%d9%85%d8%a7%d8%aa-role-%d8%a8%d8%a7-alter-role\" data-start=\"2743\" data-end=\"2784\">\u06f6. \u062a\u063a\u06cc\u06cc\u0631 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a Role \u0628\u0627 ALTER ROLE<\/h2>\n<p data-start=\"2786\" data-end=\"2836\">\u0627\u06af\u0631 \u062e\u0648\u0627\u0633\u062a\u06cc\u062f \u0628\u0639\u062f\u0627\u064b \u062f\u0633\u062a\u0631\u0633\u06cc\u200c\u0647\u0627\u06cc \u06cc\u06a9 \u0646\u0642\u0634 \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u062f:<\/p>\n<h3 id=\"%d8%a7%d8%b6%d8%a7%d9%81%d9%87-%da%a9%d8%b1%d8%af%d9%86-%d8%a7%d9%85%da%a9%d8%a7%d9%86-login\" data-start=\"2838\" data-end=\"2865\">\u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0627\u0645\u06a9\u0627\u0646 Login:<\/h3>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>ALTER ROLE app_user WITH LOGIN;<\/code><\/pre>\n<h3 id=\"%d8%ad%d8%b0%d9%81-%d8%a7%d9%85%da%a9%d8%a7%d9%86-login\" data-start=\"2910\" data-end=\"2930\">\u062d\u0630\u0641 \u0627\u0645\u06a9\u0627\u0646 Login:<\/h3>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>ALTER ROLE app_user WITH NOLOGIN;<\/code><\/pre>\n<h3 id=\"%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d8%b1%d9%85%d8%b2\" data-start=\"2977\" data-end=\"2991\">\u062a\u063a\u06cc\u06cc\u0631 \u0631\u0645\u0632:<\/h3>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\" dir=\"ltr\"><code>ALTER ROLE app_user WITH PASSWORD 'NewPassword!';<\/code><\/pre>\n<hr \/>\n<h2 id=\"%db%b7-%d9%88%d8%b1%d9%88%d8%af-%d8%a8%d9%87-postgresql-%d8%a8%d8%a7-%db%8c%da%a9-%d9%86%d9%82%d8%b4-%d8%af%db%8c%da%af%d8%b1\" data-start=\"3059\" data-end=\"3101\">\u06f7. \u0648\u0631\u0648\u062f \u0628\u0647 PostgreSQL \u0628\u0627 \u06cc\u06a9 \u0646\u0642\u0634 \u062f\u06cc\u06af\u0631<\/h2>\n<h3 id=\"%db%b1-%d8%a7%d8%a8%d8%aa%d8%af%d8%a7-%d8%b1%d9%85%d8%b2-%d9%86%d9%82%d8%b4-%d8%b1%d8%a7-%d8%aa%d9%86%d8%b8%db%8c%d9%85-%da%a9%d9%86%db%8c%d8%af\" data-start=\"3103\" data-end=\"3138\">\u06f1) \u0627\u0628\u062a\u062f\u0627 \u0631\u0645\u0632 \u0646\u0642\u0634 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>\\password app_user<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h3 id=\"%db%b2-%d8%ae%d8%b1%d9%88%d8%ac-%d8%a7%d8%b2-psql\" data-start=\"3170\" data-end=\"3190\">\u06f2) \u062e\u0631\u0648\u062c \u0627\u0632 psql:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>\\q<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h3 id=\"%db%b3-%d9%88%d8%b1%d9%88%d8%af-%d8%a8%d9%87-%d8%b9%d9%86%d9%88%d8%a7%d9%86-%d9%86%d9%82%d8%b4-%d8%ac%d8%af%db%8c%d8%af\" data-start=\"3203\" data-end=\"3233\">\u06f3) \u0648\u0631\u0648\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0646\u0642\u0634 \u062c\u062f\u06cc\u062f:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>psql -U app_user -d postgres -h 127.0.0.1 -W<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<hr data-start=\"3292\" data-end=\"3295\" \/>\n<h2 id=\"%db%b8-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%d8%ac%d8%af%d9%88%d9%84-%d8%ac%d9%87%d8%aa-%d8%aa%d8%b3%d8%aa-%d9%85%d8%ac%d9%88%d8%b2%d9%87%d8%a7\" data-start=\"3297\" data-end=\"3331\">\u06f8. \u0627\u06cc\u062c\u0627\u062f \u062c\u062f\u0648\u0644 \u062c\u0647\u062a \u062a\u0633\u062a \u0645\u062c\u0648\u0632\u0647\u0627<\/h2>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>CREATE TABLE employees ( id serial PRIMARY KEY, name varchar(50), created_at timestamp DEFAULT NOW() );<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<hr data-start=\"3461\" data-end=\"3464\" \/>\n<h2 id=\"%db%b9-%d8%a7%d8%b9%d8%b7%d8%a7%db%8c-%d9%85%d8%ac%d9%88%d8%b2-grant-%d8%af%d8%b1-postgresql\" data-start=\"3466\" data-end=\"3507\">\u06f9. \u0627\u0639\u0637\u0627\u06cc \u0645\u062c\u0648\u0632 (GRANT) \u062f\u0631 PostgreSQL<\/h2>\n<h2 id=\"%d8%af%d8%a7%d8%af%d9%86-%db%8c%da%a9-%d9%85%d8%ac%d9%88%d8%b2-%d8%ae%d8%a7%d8%b5\" data-start=\"3509\" data-end=\"3529\">\u062f\u0627\u062f\u0646 \u06cc\u06a9 \u0645\u062c\u0648\u0632 \u062e\u0627\u0635:<\/h2>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>GRANT SELECT ON employees TO app_user;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h2 id=\"%d8%a7%d8%ac%d8%a7%d8%b2%d9%87-insert\" data-start=\"3582\" data-end=\"3598\">\u0627\u062c\u0627\u0632\u0647 INSERT:<\/h2>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>GRANT INSERT ON employees TO app_user;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h2 id=\"%d8%af%d8%a7%d8%af%d9%86-all-privileges\" data-start=\"3651\" data-end=\"3674\">\u062f\u0627\u062f\u0646 ALL Privileges:<\/h2>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>GRANT ALL ON employees TO app_user;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h2 id=\"%d8%af%d8%a7%d8%af%d9%86-%d8%af%d8%b3%d8%aa%d8%b1%d8%b3%db%8c-%d8%a8%d9%87-%d9%87%d9%85%d9%87-%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%d8%a7%d9%86-public\" data-start=\"3724\" data-end=\"3763\">\u062f\u0627\u062f\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0647\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 (Public):<\/h2>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>GRANT SELECT ON employees TO PUBLIC;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<hr data-start=\"3814\" data-end=\"3817\" \/>\n<h2 id=\"%db%b1%db%b0-%d9%85%d8%b4%d8%a7%d9%87%d8%af%d9%87-%d9%85%d8%ac%d9%88%d8%b2%d9%87%d8%a7%db%8c-%d9%87%d8%b1-%d8%ac%d8%af%d9%88%d9%84\" data-start=\"3819\" data-end=\"3851\">\u06f1\u06f0. \u0645\u0634\u0627\u0647\u062f\u0647 \u0645\u062c\u0648\u0632\u0647\u0627\u06cc \u0647\u0631 \u062c\u062f\u0648\u0644<\/h2>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>\\z employees<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<hr data-start=\"3878\" data-end=\"3881\" \/>\n<h2 id=\"%db%b1%db%b1-%d9%be%d8%b3%da%af%d8%b1%d9%81%d8%aa%d9%86-%d9%85%d8%ac%d9%88%d8%b2%d9%87%d8%a7-revoke\" data-start=\"3883\" data-end=\"3917\">\u06f1\u06f1. \u067e\u0633\u200c\u06af\u0631\u0641\u062a\u0646 \u0645\u062c\u0648\u0632\u0647\u0627 (REVOKE)<\/h2>\n<p data-start=\"3919\" data-end=\"3951\">\u067e\u0633 \u06af\u0631\u0641\u062a\u0646 \u0645\u062c\u0648\u0632 Insert \u0627\u0632 \u0646\u0642\u0634 \u062e\u0627\u0635:<\/p>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>REVOKE INSERT ON employees FROM app_user;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<p data-start=\"4007\" data-end=\"4028\">\u067e\u0633 \u06af\u0631\u0641\u062a\u0646 \u062a\u0645\u0627\u0645 \u0645\u062c\u0648\u0632\u0647\u0627:<\/p>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>REVOKE ALL ON employees FROM app_user;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<p data-start=\"4081\" data-end=\"4096\">\u062d\u0630\u0641 \u0645\u062c\u0648\u0632 \u0639\u0645\u0648\u0645\u06cc:<\/p>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>REVOKE SELECT ON employees FROM PUBLIC;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<hr data-start=\"4150\" data-end=\"4153\" \/>\n<h2 id=\"%db%b1%db%b2-%d9%86%d9%82%d8%b4-%da%af%d8%b1%d9%88%d9%87%db%8c-group-role-%d8%af%d8%b1-postgresql\" data-start=\"4155\" data-end=\"4201\">\u06f1\u06f2. \u0646\u0642\u0634 \u06af\u0631\u0648\u0647\u06cc (Group Role) \u062f\u0631 PostgreSQL<\/h2>\n<p data-start=\"4203\" data-end=\"4276\">\u0646\u0642\u0634 \u06af\u0631\u0648\u0647\u06cc \u06cc\u0639\u0646\u06cc \u06cc\u06a9 Role \u06a9\u0647 \u0633\u0627\u06cc\u0631 Role \u0647\u0627 \u0639\u0636\u0648 \u0622\u0646 \u0647\u0633\u062a\u0646\u062f\u2014\u0645\u062b\u0644 \u06af\u0631\u0648\u0647\u200c\u0647\u0627\u06cc \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc.<\/p>\n<h3 id=\"%db%b1-%d8%b3%d8%a7%d8%ae%d8%aa-role-%da%af%d8%b1%d9%88%d9%87\" data-start=\"4278\" data-end=\"4300\">\u06f1) \u0633\u0627\u062e\u062a Role \u06af\u0631\u0648\u0647:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>CREATE ROLE dev_team;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h3 id=\"%db%b2-%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86-%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%d8%a7%d9%86-%d8%a8%d9%87-%da%af%d8%b1%d9%88%d9%87\" data-start=\"4335\" data-end=\"4365\">\u06f2) \u0627\u0641\u0632\u0648\u062f\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u0647 \u06af\u0631\u0648\u0647:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>GRANT dev_team TO app_user; GRANT dev_team TO backend_user;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h3 id=\"%db%b3-%d8%a8%d8%b1%d8%b1%d8%b3%db%8c-%d8%b9%d8%b6%d9%88%db%8c%d8%aa\" data-start=\"4439\" data-end=\"4458\">\u06f3) \u0628\u0631\u0631\u0633\u06cc \u0639\u0636\u0648\u06cc\u062a:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>\\du<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h3 id=\"%db%b4-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d9%86%d9%82%d8%b4-%da%af%d8%b1%d9%88%d9%87\" data-start=\"4475\" data-end=\"4502\">\u06f4) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0646\u0642\u0634 \u06af\u0631\u0648\u0647:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>SET ROLE dev_team;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<p data-start=\"4534\" data-end=\"4589\">\u0627\u0632 \u0627\u06cc\u0646 \u0644\u062d\u0638\u0647 \u062a\u0645\u0627\u0645 \u0645\u062c\u0648\u0632\u0647\u0627\u06cc\u06cc \u06a9\u0647 dev_team \u062f\u0627\u0631\u062f \u0641\u0639\u0627\u0644 \u0645\u06cc\u200c\u0634\u0648\u062f.<\/p>\n<h3 id=\"%db%b5-%d8%a7%d8%b1%d8%ab%d8%a8%d8%b1%db%8c-%d8%ae%d9%88%d8%af%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-inherit\" data-start=\"4591\" data-end=\"4623\">\u06f5) \u0627\u0631\u062b\u200c\u0628\u0631\u06cc \u062e\u0648\u062f\u06a9\u0627\u0631 \u0628\u0627 INHERIT<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>ALTER ROLE app_user WITH INHERIT;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<hr data-start=\"4670\" data-end=\"4673\" \/>\n<h2 id=\"%db%b1%db%b3-%d8%a7%d9%86%d8%aa%d9%82%d8%a7%d9%84-%d9%85%d8%a7%d9%84%da%a9%db%8c%d8%aa-%d8%a7%d8%b4%db%8c%d8%a7-%d9%82%d8%a8%d9%84-%d8%a7%d8%b2-%d8%ad%d8%b0%d9%81-role\" data-start=\"4675\" data-end=\"4719\">\u06f1\u06f3. \u0627\u0646\u062a\u0642\u0627\u0644 \u0645\u0627\u0644\u06a9\u06cc\u062a \u0627\u0634\u06cc\u0627 \u0642\u0628\u0644 \u0627\u0632 \u062d\u0630\u0641 Role<\/h2>\n<p data-start=\"4721\" data-end=\"4790\">\u0627\u06af\u0631 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u06cc\u06a9 \u0646\u0642\u0634 \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u06cc\u062f \u0648\u0644\u06cc \u062c\u062f\u0648\u0644 \u06cc\u0627 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0645\u062a\u0639\u0644\u0642 \u0628\u0647 \u0622\u0646 \u0627\u0633\u062a:<\/p>\n<h3 id=\"%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%a7%d9%84%da%a9-%d8%ac%d8%af%d9%88%d9%84\" data-start=\"4792\" data-end=\"4812\">\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0627\u0644\u06a9 \u062c\u062f\u0648\u0644:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>ALTER TABLE employees OWNER TO postgres;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<h3 id=\"%d8%b3%d9%be%d8%b3-%d8%ad%d8%b0%d9%81-%d9%86%d9%82%d8%b4\" data-start=\"4866\" data-end=\"4882\">\u0633\u067e\u0633 \u062d\u0630\u0641 \u0646\u0642\u0634:<\/h3>\n<div class=\"contain-inline-size rounded-2xl relative bg-token-sidebar-surface-primary\">\n<div class=\"sticky top-9\">\n<div class=\"absolute end-0 bottom-0 flex h-9 items-center pe-2\">\n<div class=\"bg-token-bg-elevated-secondary text-token-text-secondary flex items-center gap-4 rounded-sm px-2 font-sans text-xs\"><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>DROP ROLE dev_team;<\/code><\/pre>\n<\/div>\n<\/div>\n<\/div>\n<hr data-start=\"4915\" data-end=\"4918\" \/>\n<h2 id=\"%db%b1%db%b4-%d9%86%da%a9%d8%a7%d8%aa-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d9%85%d9%87%d9%85-%d9%87%d9%86%da%af%d8%a7%d9%85-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-roles-%d8%af%d8%b1\" data-start=\"4920\" data-end=\"4975\">\u06f1\u06f4. \u0646\u06a9\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0645\u0647\u0645 \u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Roles \u062f\u0631 VPS<\/h2>\n<ul data-start=\"4977\" data-end=\"5219\">\n<li data-start=\"4977\" data-end=\"5044\">\n<p data-start=\"4979\" data-end=\"5044\">\u0647\u0631 \u0633\u0631\u0648\u06cc\u0633 (Backend\u060c Cronjob\u060c Worker) \u0628\u0627\u06cc\u062f Role \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<\/p>\n<\/li>\n<li data-start=\"5045\" data-end=\"5084\">\n<p data-start=\"5047\" data-end=\"5084\">\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0646\u06a9\u062a\u0647 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0632 \u0646\u0642\u0634\u200c\u0647\u0627\u06cc \u0628\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u06a9\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li data-start=\"5085\" data-end=\"5126\">\n<p data-start=\"5087\" data-end=\"5126\">\u062f\u0631 \u0645\u0639\u0645\u0627\u0631\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0628\u0647 \u0647\u06cc\u0686 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646\u06cc \u0646\u0642\u0634 <code data-start=\"5108\" data-end=\"5119\">superuser<\/code> \u0646\u062f\u0647\u06cc\u062f.<\/p>\n<\/li>\n<li data-start=\"5127\" data-end=\"5167\">\n<p data-start=\"5129\" data-end=\"5167\">\u0631\u0645\u0632 \u0646\u0642\u0634\u200c\u0647\u0627 \u0628\u0627\u06cc\u062f \u0642\u0648\u06cc \u0648 expire-\u062f\u0627\u0631 \u0628\u0627\u0634\u062f.<\/p>\n<\/li>\n<li data-start=\"5168\" data-end=\"5219\">\n<p data-start=\"5170\" data-end=\"5219\">\u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644 \u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 \u06af\u0631\u0648\u0647\u200c\u0647\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0633\u062a\u0631\u0633\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<\/ul>\n<hr data-start=\"5221\" data-end=\"5224\" \/>\n<h2 id=\"%d8%ac%d9%85%d8%b9%d8%a8%d9%86%d8%af%db%8c\" data-start=\"5226\" data-end=\"5240\">\u062c\u0645\u0639\u200c\u0628\u0646\u062f\u06cc<\/h2>\n<p data-start=\"5242\" data-end=\"5491\">\u0628\u0647 \u0635\u0648\u0631\u062a \u0639\u0645\u0644\u06cc \u062f\u0631 PostgreSQL \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0628\u0631 \u067e\u0627\u06cc\u0647 Role \u0627\u0633\u062a. \u0634\u0645\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u06a9\u0627\u0631\u0628\u0631\u0627\u0646\u060c \u06af\u0631\u0648\u0647\u200c\u0647\u0627\u060c \u0646\u0642\u0634\u200c\u0647\u0627\u06cc \u0633\u06cc\u0633\u062a\u0645\u06cc \u0648 \u0646\u0642\u0634\u200c\u0647\u0627\u06cc \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646\u06cc \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u0645\u062f\u0644 \u0645\u062f\u06cc\u0631\u06cc\u062a\u06cc \u0648\u0627\u062d\u062f \u0628\u0633\u0627\u0632\u06cc\u062f. \u0647\u0645\u0686\u0646\u06cc\u0646 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc <code data-start=\"5399\" data-end=\"5406\">GRANT<\/code> \u0648 <code data-start=\"5409\" data-end=\"5417\">REVOKE<\/code> \u06a9\u0646\u062a\u0631\u0644 \u06a9\u0627\u0645\u0644 \u0631\u0648\u06cc \u062c\u062f\u0648\u0644\u200c\u0647\u0627\u060c \u0627\u0633\u06a9\u06cc\u0645\u0627\u0647\u0627\u060c \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633\u200c\u0647\u0627 \u0648 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627 \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f.<\/p>\n<p data-start=\"5493\" data-end=\"5620\">\u0645\u062f\u06cc\u0631\u06cc\u062a \u0635\u062d\u06cc\u062d Role \u0647\u0627 \u062f\u0631 PostgreSQL \u0645\u062e\u0635\u0648\u0635\u0627\u064b \u0631\u0648\u06cc VPS \u0628\u0633\u06cc\u0627\u0631 \u0627\u0647\u0645\u06cc\u062a \u062f\u0627\u0631\u062f\u060c \u0632\u06cc\u0631\u0627 \u0627\u0645\u0646\u06cc\u062a \u0648 \u067e\u0627\u06cc\u062f\u0627\u0631\u06cc \u06a9\u0644 \u0633\u06cc\u0633\u062a\u0645 \u062f\u06cc\u062a\u0627\u0628\u06cc\u0633 \u0634\u0645\u0627 \u0628\u0647 \u0622\u0646 \u0648\u0627\u0628\u0633\u062a\u0647 \u0627\u0633\u062a.<\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0628\u0647\u200c\u0635\u0648\u0631\u062a \u06a9\u0627\u0645\u0644 \u0648 \u0639\u0645\u0644\u06cc \u06cc\u0627\u062f \u0645\u06cc\u200c\u06af\u06cc\u0631\u06cc\u062f \u0686\u06af\u0648\u0646\u0647 \u0631\u0648\u06cc PostgreSQL \u0646\u0642\u0634 \u0628\u0633\u0627\u0632\u06cc\u062f\u060c \u0645\u062c\u0648\u0632 \u0628\u062f\u0647\u06cc\u062f\u060c \u0645\u062c\u0648\u0632\u0647\u0627 \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u06cc\u062f\u060c \u0646\u0642\u0634 \u06af\u0631\u0648\u0647\u06cc \u0628\u0633\u0627\u0632\u06cc\u062f \u0648 \u062f\u0633\u062a\u0631\u0633\u06cc\u200c\u0647\u0627 \u0631\u0627 \u06a9\u0646\u062a\u0631\u0644 \u06a9\u0646\u06cc\u062f.\n","protected":false},"author":1,"featured_media":17153,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_yoast_wpseo_focuskw":"PostgreSQL","_yoast_wpseo_title":"","_yoast_wpseo_metadesc":"\u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions \u062f\u0631 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc \u0622\u0634\u0646\u0627 \u0645\u06cc\u200c\u0634\u0648\u06cc\u062f","_yoast_wpseo_canonical":"","_yoast_wpseo_opengraph-description":"","_yoast_wpseo_opengraph-image":"","_yoast_wpseo_twitter-description":"","_yoast_wpseo_twitter-image":"","_yoast_wpseo_focuskeywords":"[]","_yoast_wpseo_primary_category":"349","footnotes":""},"categories":[516,349],"tags":[517,518],"class_list":{"0":"post-17148","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-postgresql","8":"category-database","9":"tag-postgresql","10":"tag-518"},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.3 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL - \u0628\u0644\u0627\u06af ITPiran<\/title>\n<meta name=\"description\" content=\"\u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions \u062f\u0631 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc \u0622\u0634\u0646\u0627 \u0645\u06cc\u200c\u0634\u0648\u06cc\u062f\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/\" \/>\n<meta property=\"og:locale\" content=\"fa_IR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL - \u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"og:description\" content=\"\u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions \u062f\u0631 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc \u0622\u0634\u0646\u0627 \u0645\u06cc\u200c\u0634\u0648\u06cc\u062f\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"article:published_time\" content=\"2025-11-15T08:52:07+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-11-16T09:25:26+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.itpiran.net\/2025\/11\/15121143\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1793\" \/>\n\t<meta property=\"og:image:height\" content=\"1110\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 \u062f\u0642\u06cc\u0642\u0647\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/\"},\"author\":{\"name\":\"admin\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\"},\"headline\":\"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL\",\"datePublished\":\"2025-11-15T08:52:07+00:00\",\"dateModified\":\"2025-11-16T09:25:26+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/\"},\"wordCount\":72,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2025\\\/11\\\/15121143\\\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg\",\"keywords\":[\"PostgreSQL\",\"\u062f\u06cc\u062a\u0627\u0628\u06cc\u0633\"],\"articleSection\":[\"PostgreSQL\",\"\u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647\"],\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/\",\"name\":\"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL - \u0628\u0644\u0627\u06af ITPiran\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2025\\\/11\\\/15121143\\\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg\",\"datePublished\":\"2025-11-15T08:52:07+00:00\",\"dateModified\":\"2025-11-16T09:25:26+00:00\",\"description\":\"\u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions \u062f\u0631 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc \u0622\u0634\u0646\u0627 \u0645\u06cc\u200c\u0634\u0648\u06cc\u062f\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#breadcrumb\"},\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#primaryimage\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2025\\\/11\\\/15121143\\\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2025\\\/11\\\/15121143\\\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg\",\"width\":1793,\"height\":1110,\"caption\":\"complete-tutorial-on-roles-and-permissions-in-postgresql\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/database\\\/complete-tutorial-on-roles-and-permissions-in-postgresql\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/category\\\/database\\\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"name\":\"\u0628\u0644\u0627\u06af ITPiran\",\"description\":\"\u0627\u062e\u0628\u0627\u0631 \u0648 \u0645\u0642\u0627\u0644\u0627\u062a \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"fa-IR\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\",\"name\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"alternateName\":\"ITPIran Blog\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"width\":512,\"height\":512,\"caption\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\",\"name\":\"admin\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/author\\\/admin\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL - \u0628\u0644\u0627\u06af ITPiran","description":"\u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions \u062f\u0631 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc \u0622\u0634\u0646\u0627 \u0645\u06cc\u200c\u0634\u0648\u06cc\u062f","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/","og_locale":"fa_IR","og_type":"article","og_title":"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL - \u0628\u0644\u0627\u06af ITPiran","og_description":"\u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions \u062f\u0631 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc \u0622\u0634\u0646\u0627 \u0645\u06cc\u200c\u0634\u0648\u06cc\u062f","og_url":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/","og_site_name":"\u0628\u0644\u0627\u06af ITPiran","article_published_time":"2025-11-15T08:52:07+00:00","article_modified_time":"2025-11-16T09:25:26+00:00","og_image":[{"width":1793,"height":1110,"url":"https:\/\/cdn.itpiran.net\/2025\/11\/15121143\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg","type":"image\/jpeg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a":"admin","\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646":"4 \u062f\u0642\u06cc\u0642\u0647"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#article","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/"},"author":{"name":"admin","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81"},"headline":"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL","datePublished":"2025-11-15T08:52:07+00:00","dateModified":"2025-11-16T09:25:26+00:00","mainEntityOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/"},"wordCount":72,"commentCount":0,"publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2025\/11\/15121143\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg","keywords":["PostgreSQL","\u062f\u06cc\u062a\u0627\u0628\u06cc\u0633"],"articleSection":["PostgreSQL","\u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647"],"inLanguage":"fa-IR","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/","url":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/","name":"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL - \u0628\u0644\u0627\u06af ITPiran","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#primaryimage"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2025\/11\/15121143\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg","datePublished":"2025-11-15T08:52:07+00:00","dateModified":"2025-11-16T09:25:26+00:00","description":"\u067e\u06cc\u0634\u200c\u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 Roles \u0648 Permissions \u062f\u0631 PostgreSQL \u0631\u0648\u06cc \u06cc\u06a9 VPS \u0644\u06cc\u0646\u0648\u06a9\u0633\u06cc \u0622\u0634\u0646\u0627 \u0645\u06cc\u200c\u0634\u0648\u06cc\u062f","breadcrumb":{"@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#breadcrumb"},"inLanguage":"fa-IR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/"]}]},{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#primaryimage","url":"https:\/\/cdn.itpiran.net\/2025\/11\/15121143\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg","contentUrl":"https:\/\/cdn.itpiran.net\/2025\/11\/15121143\/complete-tutorial-on-roles-and-permissions-in-postgresql1.jpg","width":1793,"height":1110,"caption":"complete-tutorial-on-roles-and-permissions-in-postgresql"},{"@type":"BreadcrumbList","@id":"https:\/\/www.itpiran.net\/blog\/database\/complete-tutorial-on-roles-and-permissions-in-postgresql\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.itpiran.net\/blog\/"},{"@type":"ListItem","position":2,"name":"\u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647","item":"https:\/\/www.itpiran.net\/blog\/category\/database\/"},{"@type":"ListItem","position":3,"name":"\u0622\u0645\u0648\u0632\u0634 \u06a9\u0627\u0645\u0644 \u0646\u0642\u0634\u200c\u0647\u0627 \u0648 \u0645\u062c\u0648\u0632\u0647\u0627 \u062f\u0631 PostgreSQL"}]},{"@type":"WebSite","@id":"https:\/\/www.itpiran.net\/blog\/#website","url":"https:\/\/www.itpiran.net\/blog\/","name":"\u0628\u0644\u0627\u06af ITPiran","description":"\u0627\u062e\u0628\u0627\u0631 \u0648 \u0645\u0642\u0627\u0644\u0627\u062a \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646","publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.itpiran.net\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"fa-IR"},{"@type":"Organization","@id":"https:\/\/www.itpiran.net\/blog\/#organization","name":"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646","alternateName":"ITPIran Blog","url":"https:\/\/www.itpiran.net\/blog\/","logo":{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","contentUrl":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","width":512,"height":512,"caption":"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81","name":"admin","url":"https:\/\/www.itpiran.net\/blog\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts\/17148","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/comments?post=17148"}],"version-history":[{"count":2,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts\/17148\/revisions"}],"predecessor-version":[{"id":17154,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts\/17148\/revisions\/17154"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/media\/17153"}],"wp:attachment":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/media?parent=17148"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/categories?post=17148"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/tags?post=17148"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}