مقایسه توابع REPLACE و TRANSLATE در SQL Server و بهینه‌سازی داده

توابع قدرتمند SQL Server: تفاوت‌ها و کاربرد REPLACE و TRANSLATE در بهینه‌سازی داده‌ها

در محیط‌های پایگاه داده SQL Server، تغییر و دستکاری رشته‌ها (strings) یک عملیات رایج است. دو تابع بسیار مفید برای این منظور، `REPLACE` و `TRANSLATE` هستند. این توابع به شما امکان می‌دهند تا کاراکترها یا زیررشته‌های مشخصی را در یک رشته جایگزین کنید و نقش مهمی در تمیز کردن داده‌ها، فرمت‌بندی و استانداردسازی اطلاعات ایفا می‌کنند. آشنایی با نحوه عملکرد و تفاوت‌های کلیدی آن‌ها برای هر توسعه‌دهنده SQL Server ضروری است.

تابع REPLACE در SQL Server

تابع `REPLACE` برای جایگزینی یک زیررشته مشخص با زیررشته‌ای دیگر در یک رشته استفاده می‌شود. این تابع بسیار ساده و کاربردی است و یک الگوی مشخص را در کل رشته جستجو کرده و با مقدار جدید جایگزین می‌کند.

نحوه استفاده از تابع `REPLACE` به شکل زیر است:

REPLACE (string_expression, string_pattern, string_replacement)

* `string_expression`: این رشته‌ای است که می‌خواهید عملیات جایگزینی روی آن انجام شود.
* `string_pattern`: این زیررشته‌ای است که می‌خواهید آن را در `string_expression` پیدا کنید.
* `string_replacement`: این زیررشته‌ای است که می‌خواهید `string_pattern` را با آن جایگزین کنید.

در اینجا چند مثال برای درک بهتر نحوه عملکرد تابع `REPLACE` آورده شده است:

اولین مثال نشان می‌دهد چگونه یک کاراکتر واحد را جایگزین کنیم:


SELECT REPLACE('SQL SERVER', 'R', 'K') AS Result;

نتیجه این کوئری `SQL SEVEK` خواهد بود.

مثال دوم جایگزینی یک زیررشته را نشان می‌دهد:


SELECT REPLACE('SQL SERVER', 'SERVER', 'Database') AS Result;

نتیجه این کوئری `SQL Database` خواهد بود.

می‌توانید از تابع `REPLACE` به صورت تودرتو (nested) نیز استفاده کنید تا چندین جایگزینی را در یک عبارت انجام دهید. این روش زمانی مفید است که نیاز به جایگزینی چندین الگوی مختلف دارید:


SELECT REPLACE(REPLACE(REPLACE('SQL SERVER 2022', 'SQL', 'Microsoft SQL'), 'SERVER', 'Server'), '2022', 'Standard') AS Result;

خروجی این دستور `Microsoft SQL Server Standard` خواهد بود.

تابع TRANSLATE در SQL Server

تابع `TRANSLATE` که از SQL Server 2017 معرفی شد، برای جایگزینی چندین کاراکتر واحد به صورت همزمان استفاده می‌شود. این تابع به عنوان یک راه حل کارآمدتر برای جایگزینی‌های تودرتوی `REPLACE`، به خصوص زمانی که می‌خواهید هر کاراکتر از یک مجموعه را با کاراکتر متناظرش در مجموعه دیگری جایگزین کنید، عمل می‌کند.

نحوه استفاده از تابع `TRANSLATE` به شکل زیر است:

TRANSLATE (inputString, characters, translations)

* `inputString`: این رشته‌ای است که می‌خواهید عملیات جایگزینی کاراکتر روی آن انجام شود.
* `characters`: این مجموعه‌ای از کاراکترها است که می‌خواهید در `inputString` پیدا کنید.
* `translations`: این مجموعه‌ای از کاراکترها است که می‌خواهید کاراکترهای متناظر در `characters` را با آن‌ها جایگزین کنید. تعداد کاراکترها در `characters` و `translations` باید برابر باشد.

در اینجا مثالی از نحوه عملکرد تابع `TRANSLATE` آورده شده است:
فرض کنید می‌خواهید همه حروف بزرگ و کوچک A، B، C را به ترتیب به X، Y، Z تبدیل کنید:


SELECT TRANSLATE('ABCabc', 'ABCabc', 'XYZxyz') AS Result;

خروجی این دستور `XYZxyz` خواهد بود.

این مثال نشان می‌دهد که چگونه `TRANSLATE` می‌تواند چندین جایگزینی تک‌کاراکتری را در یک عملیات انجام دهد:


SELECT TRANSLATE('SQL SERVER', 'AEIOU', '*****') AS Result;

این کوئری تمام حروف صدادار را با ستاره جایگزین می‌کند و نتیجه `SQL S*****R` خواهد بود.

تفاوت‌های کلیدی بین REPLACE و TRANSLATE

درک تفاوت‌های اصلی بین `REPLACE` و `TRANSLATE` برای انتخاب تابع صحیح در سناریوهای مختلف حیاتی است:

1. **هدف جایگزینی:**
* `REPLACE` یک زیررشته کامل را با یک زیررشته دیگر جایگزین می‌کند. به عبارت دیگر، یک الگوی مشخص را در متن جستجو کرده و آن را با الگوی جایگزین می‌کند.
* `TRANSLATE` یک عملیات نگاشت کاراکتر به کاراکتر انجام می‌دهد. هر کاراکتر در مجموعه `characters` را با کاراکتر متناظرش در مجموعه `translations` جایگزین می‌کند.

2. **ورودی‌ها:**
* `REPLACE` سه پارامتر دریافت می‌کند: رشته اصلی، زیررشته‌ای که باید پیدا شود، و زیررشته جایگزین.
* `TRANSLATE` سه پارامتر دریافت می‌کند: رشته اصلی، مجموعه‌ای از کاراکترهای منبع، و مجموعه‌ای از کاراکترهای هدف. طول مجموعه‌های کاراکتر منبع و هدف باید یکسان باشد.

3. **کارایی:**
* برای جایگزینی یک زیررشته واحد، `REPLACE` بهترین گزینه است.
* برای جایگزینی چندین کاراکتر واحد، `TRANSLATE` معمولاً کارآمدتر از استفاده تودرتو از `REPLACE` است، زیرا `TRANSLATE` عملیات را بهینه‌تر انجام می‌دهد.

مثالی که تفاوت در رفتار را به خوبی نشان می‌دهد:
فرض کنید می‌خواهید “a” را به “x”، “b” را به “y” و “c” را به “z” تبدیل کنید.

با استفاده از `REPLACE` (نیاز به تودرتو):


SELECT REPLACE(REPLACE(REPLACE('abc', 'a', 'x'), 'b', 'y'), 'c', 'z') AS Result;

با استفاده از `TRANSLATE`:


SELECT TRANSLATE('abc', 'abc', 'xyz') AS Result;

هر دو کوئری نتیجه `xyz` را برمی‌گردانند، اما `TRANSLATE` سینتکس تمیزتر و کارآمدتری دارد.

ملاحظات عملکردی

در حالی که `TRANSLATE` اغلب برای جایگزینی‌های چندکاراکتری توصیه می‌شود، برای سناریوهای خاص، ممکن است تفاوت‌های عملکردی قابل توجهی وجود داشته باشد. تست عملکرد همیشه بهترین راه برای اطمینان از انتخاب بهینه است.
یک تست ساده برای مقایسه عملکرد `TRANSLATE` و `REPLACE` تودرتو می‌تواند به شما کمک کند تا در مورد بهترین تابع برای بار کاری خاص خود تصمیم بگیرید:

اول، یک جدول موقت ایجاد کنید و داده‌های نمونه را وارد کنید:


CREATE TABLE #TestStrings (ID INT IDENTITY(1,1), StringValue NVARCHAR(MAX));
GO

-- Insert a large number of rows
INSERT INTO #TestStrings (StringValue)
SELECT TOP 100000 NEWID()
FROM sys.all_objects a CROSS JOIN sys.all_objects b;
GO

-- Add some common characters to replace
UPDATE #TestStrings
SET StringValue = REPLACE(StringValue, 'a', 'x')
WHERE ID % 2 = 0;

UPDATE #TestStrings
SET StringValue = REPLACE(StringValue, 'b', 'y')
WHERE ID % 3 = 0;

UPDATE #TestStrings
SET StringValue = REPLACE(StringValue, 'c', 'z')
WHERE ID % 5 = 0;
GO

سپس، عملکرد هر دو تابع را با استفاده از `SET STATISTICS TIME ON` مقایسه کنید:


SET STATISTICS TIME ON;
GO

-- Test with TRANSLATE
SELECT StringValue, TRANSLATE(StringValue, 'abc', 'xyz') AS TranslatedString
FROM #TestStrings;
GO

-- Test with nested REPLACE
SELECT StringValue, REPLACE(REPLACE(REPLACE(StringValue, 'a', 'x'), 'b', 'y'), 'c', 'z') AS ReplacedString
FROM #TestStrings;
GO

SET STATISTICS TIME OFF;
GO

-- Clean up
DROP TABLE #TestStrings;
GO

با اجرای این کد، می‌توانید زمان صرف شده برای CPU و زمان سپری شده هر عملیات را مشاهده کنید که به شما در تصمیم‌گیری کمک می‌کند. در بیشتر موارد، `TRANSLATE` برای جایگزینی‌های چندکاراکتری سریع‌تر خواهد بود.

TRANSLATE
Comments (0)
Add Comment