MongoDB C# Запрос для фильтрации полей без цифр при фильтрацииC#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 MongoDB C# Запрос для фильтрации полей без цифр при фильтрации

Сообщение Anonymous »

У меня есть документы в MongoDB со строковым полем «SSN». Он может содержать только цифры или цифры через дефис, например:

"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
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C#»