Заметка
Доступ к этой странице требует авторизации. Вы можете попробовать войти в систему или изменить каталог.
Доступ к этой странице требует авторизации. Вы можете попробовать сменить директорию.
Применимо к: Sql Server 2025 (17.x)
База данных
SQL Azure Управляемого экземпляра
SQL Azure в Microsoft Fabric
Указывает, соответствует ли шаблон регулярного выражения строке.
REGEXP_LIKE
(
string_expression,
pattern_expression [ , flags ]
)
REGEXP_LIKE требуется уровень совместимости базы данных 170 и более поздней версии. Если уровень совместимости базы данных ниже 170, REGEXP_LIKE он недоступен. Другие скалярные функции регулярного выражения доступны на всех уровнях совместимости.
Уровень совместимости можно проверить в sys.databases представлении или в свойствах базы данных. Вы можете изменить уровень совместимости базы данных с помощью следующей команды:
ALTER DATABASE [DatabaseName]
SET COMPATIBILITY_LEVEL = 170;
Note
Регулярные выражения доступны в Управляемом экземпляре SQL Azure с помощью политики обновленияsql Server 2025 или Always-up-to-date.
Arguments
string_expression
Выражение символьной строки.
Может быть константой, переменной или столбцом символьной строки.
Типы данных: char, nchar nchar, varcharили nvarchar nvarchar.
Note
REGEXP_LIKE
REGEXP_COUNT Функции REGEXP_INSTRи функции поддерживают бизнес-типы (varchar(max) и nvarchar(max)) до 2 МБ для параметра string_expression.
pattern_expression
Шаблон регулярного выражения для сопоставления. Обычно текстовый литерал.
Типы данных: char, nchar nchar, varcharили nvarchar nvarchar. pattern_expression поддерживает максимальную длину символов в 8 000 байт.
flags
Один или несколько символов, указывающих модификаторы, используемые для поиска совпадений. Тип varchar или charс не более чем 30 символами.
Например, ims. Значение по умолчанию — c. Если указана пустая строка (' '), она будет рассматриваться как значение по умолчанию ('c'). Укажите c или любые другие символьные выражения. Если флаг содержит несколько противоречивых символов, SQL Server использует последний символ.
Например, если указать ic regex возвращает соответствие регистра.
Если значение содержит символ, отличный от указанных в поддерживаемых значений флагов, запрос возвращает ошибку, как показано в следующем примере:
Invalid flag provided. '<invalid character>' are not valid flags. Only {c,i,s,m} flags are valid.
Поддерживаемые значения флагов
| Flag | Description |
|---|---|
i |
Без учета регистра (по умолчанию false) |
m |
Многострочный режим: ^ и $ сопоставление начальной и конечной строки в дополнение к начальной и конечной строке (по умолчанию false) |
s |
Разрешить . совпадение \n (по умолчанию false) |
c |
Учет регистра (по умолчанию true) |
Возвращаемое значение
Логическое значение.
true или false.
Remarks
Оценка кратности
Для повышения точности оценки REGEXP_LIKEмощности функции используйте ASSUME_FIXED_MIN_SELECTIVITY_FOR_REGEXP подсказки и ASSUME_FIXED_MAX_SELECTIVITY_FOR_REGEXP запроса для корректировки значений селективности по умолчанию. Дополнительные сведения см. в подсказках к запросам.
Эти подсказки по запросам также интегрируются с обратной связью по оценке мощности (CE). Модель обратной связи CE автоматически выявляет запросы, использующие эту REGEXP_LIKE функцию, при которой существует значительная разница между оценочным и фактическим количеством строк. Затем применяется соответствующее указание селекторности на уровне запроса для повышения качества плана без необходимости ввода вручную.
Чтобы отключить автоматическое поведение обратной связи, включите флаг трассировки 16268.
Examples
Выберите Employees все записи из таблицы, где имя начинается и A заканчивается на Y:
SELECT *
FROM Employees
WHERE REGEXP_LIKE (FIRST_NAME, '^A.*Y$');
Выберите Employees все записи из таблицы, где имя начинается на A и заканчивается на Y, используя режим без регистра:
SELECT *
FROM Employees
WHERE REGEXP_LIKE (FIRST_NAME, '^A.*Y$', 'i');
Выберите все записи из Orders таблицы, где дата заказа находится в феврале 2020 г.:
SELECT *
FROM Orders
WHERE REGEXP_LIKE (ORDER_DATE, '2020-02-\d\d');
Выберите все записи из Products таблицы, в которой имя продукта содержит по крайней мере три последовательных гласных:
SELECT *
FROM Products
WHERE REGEXP_LIKE (PRODUCT_NAME, '[AEIOU]{3,}');
Создайте таблицу сотрудников с CHECK ограничениями для Email столбцов и Phone_Number и:
DROP TABLE IF EXISTS Employees;
CREATE TABLE Employees
(
ID INT IDENTITY (101, 1),
[Name] VARCHAR (150),
Email VARCHAR (320)
CHECK (REGEXP_LIKE (Email, '^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}$')),
Phone_Number NVARCHAR (20)
CHECK (REGEXP_LIKE (Phone_Number, '^(\d{3})-(\d{3})-(\d{4})$'))
);