{"id":24350,"date":"2023-05-22T22:43:24","date_gmt":"2023-05-22T19:13:24","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/dynamic-sql-pivot-94a\/"},"modified":"2023-05-22T22:43:24","modified_gmt":"2023-05-22T19:13:24","slug":"dynamic-sql-pivot-94a","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/dynamic-sql-pivot-94a\/","title":{"rendered":"\u0646\u062d\u0648\u0647 \u0686\u0631\u062e\u0634 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Dynamic SQL \u062f\u0631 SQL Server"},"content":{"rendered":"<div data-article-id=\"1476472\" id=\"article-body\">\n<p>SQL Server <code>PIVOT<\/code> \u0639\u0645\u0644\u06af\u0631 \u0632\u0645\u0627\u0646\u06cc \u0645\u0641\u06cc\u062f \u0627\u0633\u062a \u06a9\u0647 \u0647\u0645\u0647 \u0645\u0642\u0627\u062f\u06cc\u0631\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0633\u062a\u0648\u0646 \u062a\u0628\u062f\u06cc\u0644 \u0634\u0648\u0646\u062f \u0631\u0627 \u0628\u062f\u0627\u0646\u06cc\u062f.  \u0627\u0645\u0627 \u0627\u06af\u0631 \u0646\u0645\u06cc \u062f\u0627\u0646\u06cc\u062f \u062f\u0642\u06cc\u0642\u0627\u064b \u062f\u0631 \u062c\u062f\u0648\u0644 \u0686\u06cc\u0633\u062a.  \u0686\u06af\u0648\u0646\u0647 \u0633\u0637\u0631\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0633\u062a\u0648\u0646 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u06cc\u0645\u061f<\/p>\n<p>SQL \u067e\u0648\u06cc\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0622\u0646 \u06a9\u0645\u06a9 \u06a9\u0646\u062f.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0645\u062b\u0627\u0644 \u0633\u0627\u062f\u0647 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645.  \u06cc\u06a9 \u0645\u06cc\u0632 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f <code>Goods<\/code>.  \u062a\u0639\u062f\u0627\u062f \u0645\u0648\u0627\u062f \u063a\u0630\u0627\u06cc\u06cc \u0648 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0647\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0646\u0627\u0645\u062d\u062f\u0648\u062f \u0628\u0627\u0634\u062f.  \u0627\u06af\u0631 \u0647\u0645\u06cc\u0634\u0647 \u0641\u0642\u0637 3 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0648 3 \u0645\u0627\u062f\u0647 \u063a\u0630\u0627\u06cc\u06cc \u062f\u0627\u0634\u062a\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u0633\u062a\u06cc\u0645 \u0627\u0632 \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>PIVOT<\/code>.<\/p>\n<div class=\"table-wrapper-paragraph\">\n<table>\n<thead>\n<tr>\n<th>\u0641\u0631\u0648\u0634\u06af\u0627\u0647<\/th>\n<th>\u063a\u0630\u0627<\/th>\n<th>\u0645\u06cc\u0632\u0627\u0646<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 1<\/td>\n<td>\u0633\u06cc\u0628 \u0632\u0645\u06cc\u0646\u06cc<\/td>\n<td>50<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 5<\/td>\n<td>\u0633\u06cc\u0628 \u0632\u0645\u06cc\u0646\u06cc<\/td>\n<td>150<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 12<\/td>\n<td>\u0633\u06cc\u0628 \u0632\u0645\u06cc\u0646\u06cc<\/td>\n<td>300<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 1<\/td>\n<td>\u06af\u0648\u062c\u0647 \u0641\u0631\u0646\u06af\u06cc<\/td>\n<td>220<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 5<\/td>\n<td>\u06af\u0648\u062c\u0647 \u0641\u0631\u0646\u06af\u06cc<\/td>\n<td>180<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 12<\/td>\n<td>\u06af\u0648\u062c\u0647 \u0641\u0631\u0646\u06af\u06cc<\/td>\n<td>60<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 1<\/td>\n<td>\u062e\u06cc\u0627\u0631<\/td>\n<td>500<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 5<\/td>\n<td>\u062e\u06cc\u0627\u0631<\/td>\n<td>10<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 12<\/td>\n<td>\u062e\u06cc\u0627\u0631<\/td>\n<td>90<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u0627\u06cc\u062f \u0645\u0648\u0627\u062f \u063a\u0630\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0647 \u0633\u062a\u0648\u0646 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u06cc\u0645.  \u0646\u062a\u06cc\u062c\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u0628\u0627\u0634\u062f:<\/p>\n<div class=\"table-wrapper-paragraph\">\n<table>\n<thead>\n<tr>\n<th>\u0641\u0631\u0648\u0634\u06af\u0627\u0647<\/th>\n<th>\u0633\u06cc\u0628 \u0632\u0645\u06cc\u0646\u06cc<\/th>\n<th>\u06af\u0648\u062c\u0647 \u0641\u0631\u0646\u06af\u06cc<\/th>\n<th>\u062e\u06cc\u0627\u0631<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 1<\/td>\n<td>50<\/td>\n<td>220<\/td>\n<td>500<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 5<\/td>\n<td>150<\/td>\n<td>180<\/td>\n<td>10<\/td>\n<\/tr>\n<tr>\n<td>\u0641\u0631\u0648\u0634\u06af\u0627\u0647 12<\/td>\n<td>30<\/td>\n<td>60<\/td>\n<td>90<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u062c\u062f\u0648\u0644 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 \u0648 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u0645:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight sql\"><code><span class=\"k\">CREATE<\/span> <span class=\"k\">TABLE<\/span> <span class=\"n\">Goods<\/span><span class=\"p\">([<\/span><span class=\"n\">Store<\/span><span class=\"p\">]<\/span> <span class=\"nb\">VARCHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">255<\/span><span class=\"p\">),<\/span> <span class=\"p\">[<\/span><span class=\"n\">Food<\/span><span class=\"p\">]<\/span> <span class=\"nb\">VARCHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">255<\/span><span class=\"p\">),<\/span> <span class=\"p\">[<\/span><span class=\"n\">Amount<\/span><span class=\"p\">]<\/span> <span class=\"nb\">INT<\/span><span class=\"p\">);<\/span>\n\n<span class=\"k\">INSERT<\/span> <span class=\"k\">INTO<\/span> <span class=\"n\">Goods<\/span><span class=\"p\">(<\/span><span class=\"n\">Store<\/span><span class=\"p\">,<\/span> <span class=\"n\">Food<\/span><span class=\"p\">,<\/span> <span class=\"n\">Amount<\/span><span class=\"p\">)<\/span>\n<span class=\"k\">VALUES<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 1'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'potato'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">50<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 5'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'potato'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">150<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 12'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'potato'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">300<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 1'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'tomato'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">220<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 5'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'tomato'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">180<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 12'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'tomato'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">60<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 1'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'cucumber'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">500<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 5'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'cucumber'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">10<\/span><span class=\"p\">),<\/span>\n<span class=\"p\">(<\/span><span class=\"s1\">'Store 12'<\/span><span class=\"p\">,<\/span> <span class=\"s1\">'cucumber'<\/span><span class=\"p\">,<\/span> <span class=\"mi\">90<\/span><span class=\"p\">);<\/span>\n\n<span class=\"k\">GO<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0628\u0631\u0627\u06cc \u0645\u062d\u0627\u0633\u0628\u0627\u062a \u0628\u0647 \u062f\u0648 \u062c\u062f\u0648\u0644 \u0645\u0648\u0642\u062a \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight sql\"><code><span class=\"cm\">\/*for turning rows into columns*\/<\/span>\n<span class=\"n\">IF<\/span> <span class=\"n\">OBJECT_ID<\/span><span class=\"p\">(<\/span><span class=\"s1\">'tempdb..#tmp'<\/span><span class=\"p\">)<\/span> <span class=\"k\">IS<\/span> <span class=\"k\">NOT<\/span> <span class=\"k\">NULL<\/span>\n    <span class=\"k\">DROP<\/span> <span class=\"k\">TABLE<\/span> <span class=\"o\">#<\/span><span class=\"n\">tmp<\/span> \n<span class=\"k\">CREATE<\/span> <span class=\"k\">TABLE<\/span> <span class=\"o\">#<\/span><span class=\"n\">tmp<\/span><span class=\"p\">(<\/span><span class=\"n\">Store<\/span> <span class=\"nb\">VARCHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">255<\/span><span class=\"p\">),<\/span> <span class=\"n\">Food<\/span> <span class=\"nb\">VARCHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">255<\/span><span class=\"p\">))<\/span>\n<span class=\"k\">GO<\/span>\n<span class=\"cm\">\/*for final result*\/<\/span>\n<span class=\"n\">IF<\/span> <span class=\"n\">OBJECT_ID<\/span><span class=\"p\">(<\/span><span class=\"s1\">'tempdb..#result'<\/span><span class=\"p\">)<\/span> <span class=\"k\">IS<\/span> <span class=\"k\">NOT<\/span> <span class=\"k\">NULL<\/span>\n    <span class=\"k\">DROP<\/span> <span class=\"k\">TABLE<\/span> <span class=\"o\">#<\/span><span class=\"k\">result<\/span>\n<span class=\"k\">GO<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0633\u0647 \u0645\u062a\u063a\u06cc\u0631:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight sql\"><code><span class=\"k\">DECLARE<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"n\">NVARCHAR<\/span><span class=\"p\">(<\/span><span class=\"k\">MAX<\/span><span class=\"p\">)<\/span> <span class=\"o\">=<\/span> <span class=\"s1\">''<\/span> <span class=\"cm\">\/*dynamic string*\/<\/span>\n        <span class=\"p\">,<\/span> <span class=\"o\">@<\/span><span class=\"n\">columns<\/span> <span class=\"n\">NVARCHAR<\/span><span class=\"p\">(<\/span><span class=\"k\">MAX<\/span><span class=\"p\">)<\/span> <span class=\"o\">=<\/span> <span class=\"n\">STUFF<\/span><span class=\"p\">(<\/span><span class=\"k\">ISNULL<\/span><span class=\"p\">((<\/span><span class=\"k\">SELECT<\/span> <span class=\"k\">DISTINCT<\/span> <span class=\"s1\">', ['<\/span><span class=\"o\">+<\/span> <span class=\"n\">Food<\/span> <span class=\"o\">+<\/span><span class=\"s1\">'] INT'<\/span>\n                                                <span class=\"k\">FROM<\/span> <span class=\"n\">Goods<\/span>\n                                                <span class=\"k\">FOR<\/span> <span class=\"n\">XML<\/span> <span class=\"n\">PATH<\/span><span class=\"p\">(<\/span><span class=\"s1\">''<\/span><span class=\"p\">)),<\/span><span class=\"s1\">''<\/span><span class=\"p\">),<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span><span class=\"s1\">''<\/span><span class=\"p\">)<\/span> <span class=\"cm\">\/*column names for the final result table*\/<\/span>\n        <span class=\"p\">,<\/span> <span class=\"o\">@<\/span><span class=\"n\">summary<\/span> <span class=\"n\">NVARCHAR<\/span><span class=\"p\">(<\/span><span class=\"k\">MAX<\/span><span class=\"p\">)<\/span> <span class=\"o\">=<\/span> <span class=\"n\">STUFF<\/span><span class=\"p\">(<\/span><span class=\"k\">ISNULL<\/span><span class=\"p\">((<\/span><span class=\"k\">SELECT<\/span> <span class=\"k\">DISTINCT<\/span> <span class=\"s1\">', SUM(['<\/span><span class=\"o\">+<\/span> <span class=\"n\">Food<\/span> <span class=\"o\">+<\/span><span class=\"s1\">']) AS ['<\/span><span class=\"o\">+<\/span> <span class=\"n\">Food<\/span> <span class=\"o\">+<\/span><span class=\"s1\">']'<\/span>\n                                                <span class=\"k\">FROM<\/span> <span class=\"n\">Goods<\/span>\n                                                <span class=\"k\">FOR<\/span> <span class=\"n\">XML<\/span> <span class=\"n\">PATH<\/span><span class=\"p\">(<\/span><span class=\"s1\">''<\/span><span class=\"p\">)),<\/span><span class=\"s1\">''<\/span><span class=\"p\">),<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span><span class=\"s1\">''<\/span><span class=\"p\">)<\/span> <span class=\"cm\">\/*summing amount*\/<\/span>\n\n<span class=\"k\">SELECT<\/span> <span class=\"o\">@<\/span><span class=\"n\">columns<\/span> <span class=\"k\">AS<\/span> <span class=\"p\">[<\/span><span class=\"n\">columns<\/span><span class=\"p\">],<\/span> <span class=\"o\">@<\/span><span class=\"n\">summary<\/span> <span class=\"k\">AS<\/span> <span class=\"p\">[<\/span><span class=\"n\">summary<\/span><span class=\"p\">];<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><img decoding=\"async\" src=\"https:\/\/nabfollower.com\/blog\/wp-content\/uploads\/2023\/05\/\u0646\u062d\u0648\u0647-\u0686\u0631\u062e\u0634-\u062f\u0627\u062f\u0647-\u0647\u0627-\u0628\u0627-\u0627\u0633\u062a\u0641\u0627\u062f\u0647-\u0627\u0632-Dynamic-SQL-\u062f\u0631.png\" alt=\"\u0645\u062d\u062a\u0648\u0627\u06cc \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\" loading=\"lazy\" width=\"800\" height=\"76\" title=\"\"><\/p>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u0642\u0644\u0627\u0645 \u063a\u0630\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0647 \u0633\u062a\u0648\u0646 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u06cc\u0645 \u0648 \u0622\u0646 \u0631\u0627 \u0627\u06cc\u0645\u0646 \u06a9\u0646\u06cc\u0645 <code>#tmp<\/code> \u062c\u062f\u0648\u0644<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight sql\"><code><span class=\"k\">INSERT<\/span> <span class=\"k\">INTO<\/span> <span class=\"o\">#<\/span><span class=\"n\">tmp<\/span> \n<span class=\"k\">SELECT<\/span> <span class=\"k\">DISTINCT<\/span> <span class=\"n\">Store<\/span><span class=\"p\">,<\/span> \n<span class=\"k\">REPLACE<\/span><span class=\"p\">(<\/span><span class=\"n\">STUFF<\/span><span class=\"p\">(<\/span><span class=\"k\">ISNULL<\/span><span class=\"p\">((<\/span><span class=\"k\">SELECT<\/span> <span class=\"k\">DISTINCT<\/span> <span class=\"s1\">', 0 AS ['<\/span><span class=\"o\">+<\/span> <span class=\"n\">Food<\/span> <span class=\"o\">+<\/span><span class=\"s1\">']'<\/span>\n            <span class=\"k\">FROM<\/span> <span class=\"n\">Goods<\/span> <span class=\"n\">rw<\/span>\n            <span class=\"k\">FOR<\/span> <span class=\"n\">XML<\/span> <span class=\"n\">PATH<\/span><span class=\"p\">(<\/span><span class=\"s1\">''<\/span><span class=\"p\">)),<\/span><span class=\"s1\">''<\/span><span class=\"p\">),<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span><span class=\"s1\">''<\/span><span class=\"p\">),<\/span><span class=\"s1\">'0 AS ['<\/span><span class=\"o\">+<\/span> <span class=\"n\">Food<\/span> <span class=\"o\">+<\/span><span class=\"s1\">']'<\/span><span class=\"p\">,<\/span> <span class=\"k\">CAST<\/span><span class=\"p\">(<\/span><span class=\"n\">org<\/span><span class=\"p\">.<\/span><span class=\"n\">Amount<\/span> <span class=\"k\">AS<\/span> <span class=\"nb\">VARCHAR<\/span><span class=\"p\">)<\/span> <span class=\"o\">+<\/span> <span class=\"s1\">' AS ['<\/span><span class=\"o\">+<\/span><span class=\"n\">org<\/span><span class=\"p\">.<\/span><span class=\"n\">Food<\/span><span class=\"o\">+<\/span><span class=\"s1\">']'<\/span><span class=\"p\">)<\/span>\n<span class=\"k\">FROM<\/span> <span class=\"n\">Goods<\/span> <span class=\"n\">org<\/span><span class=\"p\">;<\/span>\n\n<span class=\"k\">SELECT<\/span> <span class=\"o\">*<\/span> <span class=\"k\">FROM<\/span> <span class=\"o\">#<\/span><span class=\"n\">tmp<\/span><span class=\"p\">;<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><img decoding=\"async\" src=\"https:\/\/nabfollower.com\/blog\/wp-content\/uploads\/2023\/05\/1684782804_550_\u0646\u062d\u0648\u0647-\u0686\u0631\u062e\u0634-\u062f\u0627\u062f\u0647-\u0647\u0627-\u0628\u0627-\u0627\u0633\u062a\u0641\u0627\u062f\u0647-\u0627\u0632-Dynamic-SQL-\u062f\u0631.png\" alt=\"#tmp\" loading=\"lazy\" width=\"552\" height=\"306\" title=\"\"><\/p>\n<p>\u0648 \u0627\u06a9\u0646\u0648\u0646 \u0628\u0627\u06cc\u062f \u0627\u0632 \u0633\u062a\u0648\u0646 Food \u062e\u0648\u062f \u0633\u062a\u0648\u0646 \u0647\u0627\u06cc\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0645\u0646\u0638\u0648\u0631 \u0627\u0632 SQL \u067e\u0648\u06cc\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight sql\"><code><span class=\"c1\">--create final table according to number of columns from @columns and insert data from #tmp<\/span>\n<span class=\"k\">SET<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">=<\/span> <span class=\"n\">N<\/span><span class=\"s1\">'create table #result(food varchar(255),'<\/span><span class=\"o\">+@<\/span><span class=\"n\">columns<\/span><span class=\"o\">+<\/span><span class=\"s1\">'); '<\/span><span class=\"o\">+<\/span><span class=\"nb\">CHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">10<\/span><span class=\"p\">)<\/span><span class=\"o\">+<\/span>\n            <span class=\"s1\">'insert into #result '<\/span><span class=\"o\">+<\/span><span class=\"nb\">CHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">10<\/span><span class=\"p\">);<\/span>\n\n<span class=\"k\">SELECT<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">=<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">+<\/span> <span class=\"n\">N<\/span><span class=\"s1\">'select <\/span><span class=\"se\">''<\/span><span class=\"s1\">'<\/span><span class=\"o\">+<\/span><span class=\"n\">Store<\/span><span class=\"o\">+<\/span><span class=\"s1\">'<\/span><span class=\"se\">''<\/span><span class=\"s1\"> as Store, '<\/span><span class=\"o\">+<\/span><span class=\"n\">Food<\/span><span class=\"o\">+<\/span><span class=\"s1\">' union all '<\/span><span class=\"o\">+<\/span><span class=\"nb\">CHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">10<\/span><span class=\"p\">)<\/span> <span class=\"k\">FROM<\/span> <span class=\"o\">#<\/span><span class=\"n\">tmp<\/span><span class=\"p\">;<\/span>\n\n<span class=\"c1\">--remove last 'union all'<\/span>\n<span class=\"k\">SET<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">=<\/span> <span class=\"n\">REVERSE<\/span><span class=\"p\">(<\/span><span class=\"n\">STUFF<\/span><span class=\"p\">(<\/span><span class=\"n\">REVERSE<\/span><span class=\"p\">(<\/span><span class=\"o\">@<\/span><span class=\"k\">sql<\/span><span class=\"p\">),<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span><span class=\"mi\">11<\/span><span class=\"p\">,<\/span><span class=\"s1\">''<\/span><span class=\"p\">));<\/span>\n\n<span class=\"k\">SET<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">=<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">+<\/span> <span class=\"n\">N<\/span><span class=\"s1\">'select food, '<\/span><span class=\"o\">+@<\/span><span class=\"n\">summary<\/span><span class=\"o\">+<\/span><span class=\"s1\">' from #result group by food'<\/span><span class=\"p\">;<\/span>\n\n<span class=\"k\">EXEC<\/span> <span class=\"n\">sp_executesql<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span><span class=\"p\">;<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0646\u062a\u06cc\u062c\u0647 \u06cc <code>sp_executesql<\/code> \u0631\u0648\u06cc\u0647 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/nabfollower.com\/blog\/wp-content\/uploads\/2023\/05\/1684782804_772_\u0646\u062d\u0648\u0647-\u0686\u0631\u062e\u0634-\u062f\u0627\u062f\u0647-\u0647\u0627-\u0628\u0627-\u0627\u0633\u062a\u0641\u0627\u062f\u0647-\u0627\u0632-Dynamic-SQL-\u062f\u0631.png\" alt=\"\u0646\u062a\u06cc\u062c\u0647 \u0646\u0647\u0627\u06cc\u06cc\" loading=\"lazy\" width=\"402\" height=\"137\" title=\"\"><\/p>\n<p>\u062f\u0631 \u0635\u0648\u0631\u062a \u0646\u06cc\u0627\u0632 \u0628\u0647 \u062d\u0641\u0638 \u0622\u0646\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u062c\u062f\u0648\u0644 \u0627\u0636\u0627\u0641\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u0648 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062f\u0631 \u0622\u0646 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f.  \u0645\u062b\u0644\u0627:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight sql\"><code><span class=\"k\">SET<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">=<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span> <span class=\"o\">+<\/span> <span class=\"n\">N<\/span><span class=\"s1\">'create table final_result(food varchar(255),'<\/span><span class=\"o\">+@<\/span><span class=\"n\">columns<\/span><span class=\"o\">+<\/span><span class=\"s1\">');'<\/span><span class=\"o\">+<\/span><span class=\"nb\">CHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">10<\/span><span class=\"p\">)<\/span><span class=\"o\">+<\/span>\n                    <span class=\"s1\">'insert into final_result'<\/span><span class=\"o\">+<\/span><span class=\"nb\">CHAR<\/span><span class=\"p\">(<\/span><span class=\"mi\">10<\/span><span class=\"p\">)<\/span><span class=\"o\">+<\/span>\n                    <span class=\"s1\">'select food, '<\/span><span class=\"o\">+@<\/span><span class=\"n\">summary<\/span><span class=\"o\">+<\/span><span class=\"s1\">' from #result group by food'<\/span><span class=\"p\">;<\/span>\n\n<span class=\"k\">EXEC<\/span> <span class=\"n\">sp_executesql<\/span> <span class=\"o\">@<\/span><span class=\"k\">sql<\/span><span class=\"p\">;<\/span>\n\n<span class=\"k\">SELECT<\/span><span class=\"o\">*<\/span> <span class=\"k\">FROM<\/span> <span class=\"n\">final_result<\/span><span class=\"p\">;<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><img decoding=\"async\" src=\"https:\/\/nabfollower.com\/blog\/wp-content\/uploads\/2023\/05\/1684782804_752_\u0646\u062d\u0648\u0647-\u0686\u0631\u062e\u0634-\u062f\u0627\u062f\u0647-\u0647\u0627-\u0628\u0627-\u0627\u0633\u062a\u0641\u0627\u062f\u0647-\u0627\u0632-Dynamic-SQL-\u062f\u0631.png\" alt=\"\u0646\u062a\u06cc\u062c\u0647 \u0646\u0647\u0627\u06cc\u06cc \u062f\u0631 \u062c\u062f\u0648\u0644\" loading=\"lazy\" width=\"391\" height=\"169\" title=\"\"><\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0646\u06af\u0627\u0645 \u0686\u0631\u062e\u0634 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u060c \u0633\u062a\u0648\u0646\u200c\u0647\u0627\u06cc \u0627\u0636\u0627\u0641\u06cc \u0645\u0627\u0646\u0646\u062f \u0645\u0642\u062f\u0627\u0631 \u06a9\u0644\u060c \u062a\u0639\u062f\u0627\u062f \u06a9\u0644 \u062f\u0631 \u0633\u062a\u0648\u0646\u200c\u0647\u0627 \u06cc\u0627 \u0631\u062f\u06cc\u0641\u200c\u0647\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.  \u0627\u06cc\u0646 \u06cc\u06a9 \u0631\u0648\u06cc\u06a9\u0631\u062f \u06a9\u0627\u0645\u0644\u0627 \u0627\u0646\u0639\u0637\u0627\u0641 \u067e\u0630\u06cc\u0631 \u0627\u0633\u062a.<\/p>\n<p><em>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f<\/em>: \u0627\u06af\u0631 \u0646\u0633\u062e\u0647 SQL \u0634\u0645\u0627 \u0628\u0627\u0644\u0627\u062a\u0631 \u0627\u0632 2017 \u0628\u0627\u0634\u062f\u060c \u0627\u0645\u06a9\u0627\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f <code>STRING_AGG()<\/code> \u062a\u0627\u0628\u0639 \u0628\u0631\u0627\u06cc \u0633\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 <code>STUFF\/XML<\/code> \u0628\u06cc\u0627\u0646\u06cc\u0647.<\/p>\n<p>\u0644\u0637\u0641\u0627\u064b \u0627\u06af\u0631 \u0627\u0632 \u0631\u0648\u0634 \u062f\u06cc\u06af\u0631\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u062f\u0631 \u0646\u0638\u0631\u0627\u062a \u0632\u06cc\u0631 \u0628\u0647 \u0645\u0646 \u0627\u0637\u0644\u0627\u0639 \u062f\u0647\u06cc\u062f.  \u062c\u0627\u0644\u0628 \u0627\u0633\u062a \u06a9\u0647 \u0686\u06cc\u0632 \u062c\u062f\u06cc\u062f\u06cc \u0631\u0627 \u0627\u0645\u062a\u062d\u0627\u0646 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>SQL Server PIVOT \u0639\u0645\u0644\u06af\u0631 \u0632\u0645\u0627\u0646\u06cc \u0645\u0641\u06cc\u062f \u0627\u0633\u062a \u06a9\u0647 \u0647\u0645\u0647 \u0645\u0642\u0627\u062f\u06cc\u0631\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0633\u062a\u0648\u0646 \u062a\u0628\u062f\u06cc\u0644 \u0634\u0648\u0646\u062f \u0631\u0627 \u0628\u062f\u0627\u0646\u06cc\u062f. \u0627\u0645\u0627 \u0627\u06af\u0631 \u0646\u0645\u06cc \u062f\u0627\u0646\u06cc\u062f \u062f\u0642\u06cc\u0642\u0627\u064b \u062f\u0631 \u062c\u062f\u0648\u0644 \u0686\u06cc\u0633\u062a. \u0686\u06af\u0648\u0646\u0647 \u0633\u0637\u0631\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0633\u062a\u0648\u0646 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u06cc\u0645\u061f SQL \u067e\u0648\u06cc\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0622\u0646 \u06a9\u0645\u06a9 \u06a9\u0646\u062f. \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0645\u062b\u0627\u0644 \u0633\u0627\u062f\u0647 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645. \u06cc\u06a9 \u0645\u06cc\u0632 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f Goods. &hellip;<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-24350","post","type-post","status-publish","format-standard","hentry","category-dev"],"_links":{"self":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/24350","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/comments?post=24350"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/24350\/revisions"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=24350"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=24350"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=24350"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}