"123456789"
"12-345 -6789"
"123-456789"
Параметр входящего фильтра может иметь только цифры, например . «123456789», «187641287» и т. д.
Как построить фильтрующий запрос для поиска этих записей? Я имею в виду, что нецифровые символы в «SSN» следует игнорировать и сравнивать с параметром фильтра следует только цифры.
Я посмотрел Builders.Filter.Where но похоже, что это не сработает, поскольку принимает выражение:
Код: Выделить всё
ssn ('123454784') // filter ssn value coming outside
Func ssnExpression() => doc =>
{
var ssnOnlyDigits = doc.SSN ?? null;
ssnOnlyDigits = string.IsNullOrEmpty(ssnOnlyDigits) ? null : Regex.Replace(ssnOnlyDigits, @"\D", string.Empty);
return ssnOnlyDigits != null && ssnOnlyDigits.Equals(ssn);
};
return Builders.Filter.Where(ssnExpression());
P.S. Я не могу хранить в БД номер SSN, содержащий только цифры.
Подробнее здесь: https://stackoverflow.com/questions/785 ... -filtering