Udostępnij za pośrednictwem


REGEXP_REPLACE (Transact-SQL) wersja zapoznawcza

Dotyczy: SQL Server 2025 (17.x) (wersja zapoznawcza) Azure SQL Database Azure SQLManaged InstanceSQL Database w wersji zapoznawczej usługi Microsoft Fabric

Note

Jako funkcja w wersji zapoznawczej technologia przedstawiona w tym artykule podlega uzupełniających warunków użytkowania dla wersji zapoznawczych platformy Microsoft Azure.

Zwraca zmodyfikowany ciąg źródłowy zastąpiony ciągiem zastępczym, w którym znaleziono wystąpienie wzorca wyrażenia regularnego. Jeśli nie znaleziono dopasowań, funkcja zwraca oryginalny ciąg.

REGEXP_REPLACE
     (
      string_expression,
      pattern_expression [, string_replacement [, start [, occurrence [, flags ] ] ] ]
     )

Note

Wyrażenia regularne są dostępne w usłudze Azure SQL Managed Instance skonfigurowanym przy użyciu zasad aktualizacji always-up-to-date .

Arguments

string_expression

Wyrażenie ciągu znaków.

Może być stałą, zmienną lub kolumną ciągu znaków.

Typy danych: char, nchar, varcharlub nvarchar.

Note

Funkcje REGEXP_LIKE, REGEXP_COUNTi REGEXP_INSTR obsługują typy LOB (varchar(max) i nvarchar(max)) do 2 MB dla parametru string_expression .

pattern_expression

Wzorzec wyrażenia regularnego do dopasowania. Zazwyczaj literał tekstu.

Typy danych: char, nchar, varcharlub nvarchar. pattern_expression obsługuje maksymalną długość znaków wynoszącą 8000 bajtów.

string_replacement

Wyrażenie ciągu określające ciąg zastępczy pasujących podciągów i zamienia podciągy dopasowane przez wzorzec. String_replacement mogą być typu char, varchar, nchar i nvarchar. Jeśli określono pusty ciąg (' '), funkcja usuwa wszystkie dopasowane wzorce i zwraca wynikowy ciąg. Domyślny ciąg zastępczy to pusty ciąg (' ').

String_replacement może zawierać \n, gdzie n wynosi od 1 do 9, aby wskazać, że podciąg źródłowy pasujący do n'th nadrzędnej grupy (podwyrażenie) wzorca należy wstawić i może zawierać & wskazać, że podciąg pasujący do całego wzorca powinien zostać wstawiony. Napisz \ jeśli musisz umieścić ukośnik odwrotny literału w tekście zastępczym.

For example

REGEXP_REPLACE('123-456-7890', '(\d{3})-(\d{3})-(\d{4})', '(\1) \2-\3')

Returns:

(123) 456-7890

Jeśli podana \n wartość jest string_replacement większa niż liczba grup w pattern_expression, funkcja ignoruje wartość.

For example:

REGEXP_REPLACE('123-456-7890', '(\d{3})-(\d{3})-(\d{4})', '(\1) (\4)-xxxx')

Returns:

(123) ()-xxxx

start

Określ pozycję początkową wyszukiwania w ciągu wyszukiwania. Optional. Typ to int lub bigint.

Numerowanie jest oparte na 1, co oznacza, że pierwszy znak w wyrażeniu jest 1, a wartość musi być >= 1. Jeśli wyrażenie początkowe jest mniejsze niż 1, zwraca błąd. Jeśli wyrażenie początkowe jest większe niż długość string_expression, funkcja zwraca string_expression. Wartość domyślna to 1.

occurrence

Wyrażenie (dodatnia liczba całkowita), które określa, które wystąpienie wyrażenia wzorca w ciągu źródłowym ma być wyszukiwane lub zastępowane. Wartość domyślna to 1. Wyszukuje pierwszy znak string_expression. W przypadku dodatniej liczby całkowitej nwyszukuje nth wystąpienie rozpoczynające się od pierwszego znaku po pierwszym wystąpieniu pattern_expression itd.

flags

Co najmniej jeden znak określający modyfikatory używane do wyszukiwania dopasowań. Typem jest varchar lub znak, z maksymalnie 30 znakami.

Na przykład ims. Wartość domyślna to c. Jeśli zostanie podany pusty ciąg (' '), będzie on traktowany jako wartość domyślna ('c'). Podaj c lub inne wyrażenia znaków. Jeśli flaga zawiera wiele sprzecznych znaków, program SQL Server używa ostatniego znaku.

Jeśli na przykład określisz ic regex zwraca dopasowanie uwzględniające wielkość liter.

Jeśli wartość zawiera znak inny niż wymienione na Obsługiwane wartości flagi, zapytanie zwraca błąd podobny do następującego przykładu:

Invalid flag provided. '<invalid character>' are not valid flags. Only {c,i,s,m} flags are valid.
Obsługiwane wartości flagi
Flag Description
i Bez uwzględniania wielkości liter (wartość domyślna false)
m Tryb wielowierszowy: ^ i $ dopasuj wiersz początkowy/końcowy oprócz tekstu rozpoczynającego/końcowego (wartość domyślna false)
s Dopasuj .\n (ustawienie domyślne false)
c Uwzględniana wielkość liter (wartość domyślna true)

Return value

Expression.

Examples

Zastąp wszystkie wystąpienia a lub eX w nazwach produktów.

SELECT REGEXP_REPLACE(PRODUCT_NAME, '[ae]', 'X', 1, 0, 'i')
FROM PRODUCTS;

Zastąp pierwsze wystąpienie cat lub dogpet w opisach produktów

SELECT REGEXP_REPLACE(PRODUCT_DESCRIPTION, 'cat|dog', 'pet', 1, 1, 'i')
FROM PRODUCTS;

Zastąp ostatnie cztery cyfry numerów telefonów gwiazdką

SELECT REGEXP_REPLACE(PHONE_NUMBER, '\d{4}$', '****')
FROM CUSTOMERS;