تابع STUFF SQL Server ویرایش و جایگزینی رشته ها

کاربرد تابع SQL STUFF: جایگزینی و ویرایش رشته‌ها در SQL Server

تابع `STUFF` در SQL Server برای درج یک رشته در یک رشته دیگر استفاده می‌شود. این تابع کاراکترهای یک رشته را در موقعیت مشخصی حذف کرده و سپس رشته دیگری را در همان موقعیت جایگزین می‌کند. این تابع برای ویرایش و دستکاری رشته‌ها در SQL بسیار قدرتمند است و می‌توان از آن برای سناریوهای مختلفی مانند جایگزینی، حذف و حتی الحاق رشته‌ها استفاده کرد.

ساختار یا سینتکس تابع `STUFF` به شکل زیر است:

`STUFF ( character_expression , start , length , replaceWith_expression )`

در این سینتکس، هر بخش دارای معنی خاصی است:
* `character_expression`: این بخش رشته اصلی است که قرار است ویرایش شود. این می‌تواند یک ستون از نوع کاراکتری یا یک لیترال رشته‌ای باشد.
* `start`: این پارامتر یک مقدار عددی صحیح است که نشان‌دهنده موقعیت شروع برای حذف کاراکترها است. اولین کاراکتر در رشته اصلی دارای موقعیت ۱ است.
* `length`: این پارامتر نیز یک مقدار عددی صحیح است که تعداد کاراکترهایی را مشخص می‌کند که باید از رشته اصلی حذف شوند. اگر این مقدار صفر باشد، هیچ کاراکتری حذف نمی‌شود اما رشته `replaceWith_expression` در موقعیت مشخص شده درج خواهد شد.
* `replaceWith_expression`: این رشته‌ای است که قرار است جایگزین یا درج شود. طول این رشته می‌تواند با تعداد کاراکترهای حذف شده متفاوت باشد.

بیایید با چند مثال کاربرد تابع `STUFF` را بررسی کنیم.

**مثال پایه استفاده از STUFF**
این مثال ساده نحوه عملکرد `STUFF` را نشان می‌دهد. در اینجا، تابع `STUFF` یک رشته جدید را در موقعیت مشخصی در رشته اصلی درج می‌کند، در حالی که تعداد مشخصی از کاراکترها را حذف می‌کند.


SELECT STUFF('SQL STUFF Function', 5, 0, 'New ');

در این حالت، از موقعیت پنجم (بعد از “SQL “)، صفر کاراکتر حذف می‌شود و رشته ‘New ‘ در آنجا درج می‌گردد، که نتیجه ‘SQL New STUFF Function’ خواهد بود.

**جایگزینی یک کاراکتر**
در این مثال، کاراکتر ‘U’ در ‘STUFF’ با ‘O’ جایگزین می‌شود.


SELECT STUFF('SQL STUFF Function', 8, 1, 'O');

نتیجه این دستور ‘SQL STOFF Function’ خواهد بود زیرا از موقعیت ۸ (کاراکتر ‘U’)، یک کاراکتر حذف شده و ‘O’ جایگزین آن شده است.

**حذف کاراکترها با جایگزینی با رشته خالی**
با تنظیم `replaceWith_expression` به یک رشته خالی، می‌توانیم از `STUFF` برای حذف کاراکترها بدون درج چیزی استفاده کنیم.


SELECT STUFF('SQL STUFF Function', 5, 6, '');

این دستور از موقعیت ۵ به بعد، ۶ کاراکتر (‘ STUFF’) را حذف می‌کند و هیچ چیز جایگزین نمی‌کند، در نتیجه ‘SQL Function’ به دست می‌آید.

**جایگزینی کاراکترها با استفاده از مقادیر متفاوت برای شروع و طول**
این مثال نشان می‌دهد که چگونه می‌توان از تابع `STUFF` برای جایگزینی بخش‌های مختلفی از یک رشته با توجه به مقادیر شروع و طول استفاده کرد.


SELECT STUFF('MSSQLTIPS.COM', 3, 2, ' ');

در اینجا، از موقعیت ۳، دو کاراکتر (‘SQ’) حذف شده و یک فاصله خالی ‘ ‘ جایگزین می‌شود، که منجر به رشته ‘MS SQLTIPS.COM’ می‌گردد.

**مقایسه STUFF و REPLACE**
مهم است که تفاوت بین تابع `STUFF` و `REPLACE` را درک کنید. `REPLACE` تمام وقوع‌های یک زیررشته را در یک رشته پیدا کرده و آن‌ها را جایگزین می‌کند. `STUFF` در یک موقعیت مشخص شروع به کار می‌کند و تعداد مشخصی از کاراکترها را حذف می‌کند، سپس رشته جایگزین را درج می‌کند.


SELECT STUFF('MSSQLTIPS.COM', 3, 2, ' ');
SELECT REPLACE('MSSQLTIPS.COM', 'SQ', ' ');

هر دو دستور بالا نتیجه ‘MS SQLTIPS.COM’ را برمی‌گردانند، اما روش کار آن‌ها متفاوت است. `STUFF` بر اساس موقعیت و طول کار می‌کند، در حالی که `REPLACE` بر اساس مقدار زیررشته.

**استفاده از STUFF با Common Table Expression (CTE)**
تابع `STUFF` را می‌توان با CTEها ترکیب کرد تا عملیات‌های پیچیده‌تری روی داده‌ها انجام داد. این مثال نشان می‌دهد چگونه می‌توان با استفاده از CTE و `STUFF` یک مقدار خاص را در یک ستون تغییر داد.


WITH EmployeeData AS (
    SELECT 'John Doe' AS FullName, '123-456-7890' AS PhoneNumber
)
SELECT FullName, STUFF(PhoneNumber, 5, 3, 'XXX') AS MaskedPhoneNumber
FROM EmployeeData;

در این مثال، شماره تلفن ‘123-456-7890’ به ‘123-XXX-7890’ تغییر می‌یابد. این مثال یک مورد رایج برای ماسک کردن یا پنهان کردن اطلاعات حساس در یک رشته است.

**استفاده از STUFF برای الحاق رشته‌ها با متد XML PATH**
یکی از کاربردهای بسیار مفید `STUFF`، ترکیب آن با متد `FOR XML PATH(”)` برای الحاق مقادیر از چندین ردیف به یک رشته واحد است. این روش برای تجمیع رشته‌ها (string aggregation) بسیار کارآمد است.


SELECT STUFF(
    (SELECT ', ' + Name FROM sys.databases ORDER BY Name FOR XML PATH('')), 
    1, 2, ''
);

این کوئری تمام نام‌های دیتابیس‌ها را از `sys.databases` انتخاب کرده، آن‌ها را با کاما و فاصله ‘, ‘ از هم جدا می‌کند و سپس با استفاده از `STUFF` دو کاراکتر اول (که ‘, ‘ اضافه شده توسط `FOR XML PATH` است) را حذف می‌کند. نتیجه یک رشته واحد شامل تمام نام‌های دیتابیس‌ها خواهد بود که با کاما از هم جدا شده‌اند، مانند ‘master, model, msdb, tempdb, ReportServer, …’.

**حذف کاراکترهای ابتدایی یا انتهایی با STUFF**
`STUFF` می‌تواند برای حذف کاراکترهای اضافی در ابتدا یا انتهای یک رشته استفاده شود، به ویژه زمانی که کاراکترهای خاصی برای حذف مد نظر باشد.


SELECT STUFF(',SQL STUFF Function', 1, 1, '');

این دستور کاما ‘,’ را از ابتدای رشته ‘,SQL STUFF Function’ حذف می‌کند و نتیجه ‘SQL STUFF Function’ را برمی‌گرداند.

**کار با مقادیر NULL و STUFF**
وقتی هر یک از آرگومان‌های ورودی به تابع `STUFF` نال (NULL) باشد، خروجی تابع نیز نال خواهد بود. این رفتار برای اطمینان از صحت داده‌ها در عملیات‌های رشته‌ای مهم است.


SELECT STUFF(NULL, 1, 1, 'Test');
SELECT STUFF('Hello', NULL, 1, 'Test');
SELECT STUFF('Hello', 1, NULL, 'Test');
SELECT STUFF('Hello', 1, 1, NULL);

تمام این دستورات نتیجه NULL را برمی‌گردانند، زیرا حداقل یکی از پارامترهای تابع `STUFF` مقدار NULL دارد. در هنگام کار با داده‌هایی که ممکن است شامل NULL باشند، باید این نکته را در نظر داشت و از توابعی مانند `ISNULL` یا `COALESCE` برای مدیریت آن استفاده کرد.

sql serverstuffاسکریپتاموزش SqlServer
Comments (0)
Add Comment