آموزش کامل تابع RIGHT در SQL Server

قدرت تابع RIGHT در SQL Server: استخراج هوشمندانه اطلاعات از رشته‌ها

تابع RIGHT در SQL Server، ابزاری قدرتمند برای استخراج بخشی از یک رشته متنی از سمت راست آن است. این تابع با انتخاب تعداد مشخصی از کاراکترها از انتهای رشته، به شما امکان می‌دهد تا به سادگی به اطلاعات مورد نیاز دسترسی پیدا کنید. کاربرد این تابع در تجزیه و تحلیل داده‌های متنی، مانند استخراج پسوندهای فایل، کدهای پستی، یا بخش‌های خاص از آدرس‌ها و شناسه‌ها، بسیار گسترده است. این تابع بخشی از مجموعه توابع دستکاری رشته‌ها در T-SQL است که برای کار با انواع داده‌های متنی طراحی شده‌اند. سینتکس کلی تابع RIGHT به شرح زیر است:

RIGHT (character_expression, integer_expression)

در این سینتکس، `character_expression` رشته‌ای است که می‌خواهید بخشی از آن را استخراج کنید و `integer_expression` عددی است که تعداد کاراکترهایی را مشخص می‌کند که باید از سمت راست رشته برداشته شوند. این عدد باید یک عدد صحیح مثبت باشد.

مثال‌های عملی از تابع RIGHT در SQL Server

در ادامه، با بررسی مثال‌های متنوع، نحوه استفاده از تابع `RIGHT` و ترکیب آن با دیگر توابع T-SQL را برای استخراج داده‌های دقیق‌تر مشاهده خواهید کرد.

استفاده پایه از تابع RIGHT:

این مثال ساده‌ترین کاربرد تابع `RIGHT` را نشان می‌دهد و پنج کاراکتر آخر از رشته مشخص شده را بازمی‌گرداند.


SELECT RIGHT('SQL RIGHT Function',5) AS result;

استفاده از RIGHT با تابع CHARINDEX:

این مثال از `CHARINDEX` برای یافتن موقعیت اولین نقطه در رشته استفاده می‌کند. سپس، با کسر یک واحد از این موقعیت، تعداد کاراکترهایی را مشخص می‌کند که باید از سمت راست رشته اصلی استخراج شوند. نتیجه این عملیات، تمامی کاراکترها از سمت راست تا کاراکتر قبل از اولین نقطه (از سمت چپ) خواهد بود.


SELECT RIGHT('info@mssqltips.com', CHARINDEX('.', 'info@mssqltips.com') -1) AS Domain;

استفاده از RIGHT با تابع LEN:

این مثال، ابتدا با استفاده از تابع `LEN`، طول کلی رشته را محاسبه می‌کند. سپس، با کم کردن عدد ۵ از این طول، تعداد کاراکترهایی را که باید از سمت راست برداشته شوند، تعیین می‌نماید. نتیجه این عملیات، استخراج تمام کاراکترها از سمت راست به جز پنج کاراکتر اول از سمت چپ است.


SELECT RIGHT('SQL RIGHT Function', LEN('SQL RIGHT Function')-5) AS Result;

استفاده از RIGHT با تابع SUBSTRING:

این مثال، ابتدا بخشی از رشته را با استفاده از `SUBSTRING` استخراج می‌کند و سپس تابع `RIGHT` را روی نتیجه این عملیات اعمال می‌کند. `SUBSTRING` از کاراکتر پنجم به بعد، ده کاراکتر را جدا می‌کند و سپس `RIGHT` پنج کاراکتر آخر از آن زیررشته را برمی‌دارد.


SELECT RIGHT(SUBSTRING('SQL RIGHT Function',5,10), 5) AS result;

استفاده از RIGHT با تابع PATINDEX:

این مثال با استفاده از `PATINDEX`، موقعیت شروع یک الگو (در اینجا “Server”) را در رشته پیدا می‌کند. سپس، با یک محاسبه ساده بر اساس طول کلی رشته و موقعیت الگو، تعداد کاراکترهایی را تعیین می‌کند که باید از سمت راست استخراج شوند. نتیجه شامل الگو و تمامی کاراکترهای بعد از آن خواهد بود.


SELECT RIGHT('MSSQL Server-Tutorial', LEN('MSSQL Server-Tutorial') - PATINDEX('%Server%', 'MSSQL Server-Tutorial') + 1) AS result;

ترکیب RIGHT با CHARINDEX و REVERSE برای استخراج دامنه ایمیل:

این مثال روشی هوشمندانه برای استخراج بخش TLD (Top-Level Domain) مانند “com” یا “org” از یک آدرس ایمیل را نشان می‌دهد. ابتدا، رشته ایمیل برعکس می‌شود. سپس، `CHARINDEX` موقعیت اولین نقطه را در رشته برعکس شده پیدا می‌کند. با استفاده از این موقعیت (منها یک)، `RIGHT` دامنه را از رشته اصلی استخراج می‌کند.


SELECT RIGHT('info@mssqltips.com', CHARINDEX('.', REVERSE('info@mssqltips.com')) -1) AS Domain;

استفاده از RIGHT برای دستکاری رشته‌ها پس از حذف فاصله‌ها:

این مثال ابتدا با استفاده از `LTRIM`، فاصله‌های اضافی ابتدای رشته را حذف می‌کند. سپس، با استفاده از `LEN` طول رشته جدید را به دست می‌آورد و با کسر یک از آن، تابع `RIGHT` را اعمال می‌کند. این عمل باعث می‌شود که تمامی کاراکترها به جز اولین کاراکتر از رشته پس از اعمال `LTRIM` استخراج شوند.


SELECT RIGHT(LTRIM('  SQL RIGHT Function  '),LEN(LTRIM('  SQL RIGHT Function  '))-1);

استفاده از RIGHT درون یک تابع تعریف شده توسط کاربر (UDF):

این بخش نشان می‌دهد که چگونه می‌توان تابع `RIGHT` را در یک تابع تعریف شده توسط کاربر (UDF) گنجاند تا قابلیت استفاده مجدد برای استخراج کاراکترها از سمت راست رشته فراهم شود. ابتدا تابع UDF ایجاد شده و سپس نحوه فراخوانی و استفاده از آن نشان داده می‌شود.


CREATE FUNCTION GetRightChars(@InputString VARCHAR(MAX), @Length INT)
RETURNS VARCHAR(MAX)
AS
BEGIN
    RETURN RIGHT(@InputString, @Length)
END;

پس از تعریف تابع، می‌توانید آن را به سادگی فراخوانی کنید:


SELECT dbo.GetRightChars('SQL RIGHT Function', 8) AS result;

استفاده از RIGHT با توابع JSON در SQL Server:

با معرفی قابلیت‌های JSON در SQL Server، تابع `RIGHT` می‌تواند برای دستکاری خروجی توابع JSON نیز به کار رود. این مثال نشان می‌دهد که چگونه `RIGHT` می‌تواند بخشی از مقدار یک کلید JSON را پس از استخراج با `JSON_QUERY`، جدا کند.


DECLARE @json NVARCHAR(MAX) = '{"Name":"John Doe","City":"New York","Age":30}';
SELECT RIGHT(JSON_QUERY(@json, '$.City'), 8) AS CityEnd;

ملاحظات عملکردی تابع RIGHT:

استفاده از تابع `RIGHT` معمولاً تأثیر قابل توجهی بر عملکرد کوئری‌های SQL ندارد، به خصوص زمانی که روی حجم متوسطی از داده‌ها اعمال شود. با این حال، در سناریوهایی که نیاز به پردازش حجم بسیار زیادی از رشته‌ها باشد، یا زمانی که این تابع در یک شرط `WHERE` یا `JOIN` برای فیلتر کردن یا پیوستن داده‌ها استفاده می‌شود، ممکن است نیاز به بررسی بیشتری باشد. این توابع رشته‌ای به طور کلی برای اسکن کل رشته طراحی شده‌اند و در مقیاس بسیار بزرگ می‌توانند سربار ایجاد کنند. در چنین مواردی، ایندکس‌های مناسب یا استفاده از راه‌حل‌های جایگزین برای بهینه‌سازی عملکرد می‌تواند مفید باشد. همواره توصیه می‌شود برای کوئری‌های با کارایی بالا، طرح اجرای کوئری را بررسی کرده و در صورت نیاز، بهینه‌سازی‌های لازم را اعمال کنید.

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