Я хочу найти совпадающих пользователей из массива пользователей и подсчитать пользователей, сопоставленных с [duplicate]

Если у вас возникли проблемы с отправкой писем с помощью PHP, рассмотрите альтернативу, например PHPMailer или SwiftMailer .

Обычно я использую SwiftMailer всякий раз, когда мне нужно для отправки писем с PHP.


Основное использование:

require 'mail/swift_required.php';

$message = Swift_Message::newInstance()
    // The subject of your email
    ->setSubject('Jane Doe sends you a message')
    // The from address(es)
    ->setFrom(array('jane.doe@gmail.com' => 'Jane Doe'))
    // The to address(es)
    ->setTo(array('frank.stevens@gmail.com' => 'Frank Stevens'))
    // Here, you put the content of your email
    ->setBody('

New message

Here goes the rest of my message

', 'text/html'); if (Swift_Mailer::newInstance(Swift_MailTransport::newInstance())->send($message)) { echo json_encode([ "status" => "OK", "message" => 'Your message has been sent!' ], JSON_PRETTY_PRINT); } else { echo json_encode([ "status" => "error", "message" => 'Oops! Something went wrong!' ], JSON_PRETTY_PRINT); }

Подробнее о том, как использовать SwiftMailer, см. в официальной документации .

9
задан Blakes Seven 24 March 2016 в 05:52
поделиться

1 ответ

Ваша переменная ids будет построена из «строк», а не ObjectId значений.

Мангустировать «autocasts» строковые значения для ObjectId в их правильный тип в регулярных запросах, но это не происходит в конвейере агрегации , как описано в номере № 1399.

Вместо этого вы должны выполнить правильное литье, чтобы ввести вручную:

ids = ids.map(function(el) { return mongoose.Types.ObjectId(el) })

Затем вы можете использовать их в своем конвейере:

{ "$match": { "_id": { "$in": ids } } }

Причина в том, что конвейеры агрегации «обычно» изменяют структуру документа, и поэтому mongoose не делает никаких предположений о том, что «схема» применяется к документу на любой стадии конвейера.

Можно утверждать, что этап «первого» конвейера, когда это этап $match, должен сделать это, поскольку документ действительно не изменяется. Но сейчас это не так.

Любые значения, которые могут быть «строками» или, по крайней мере, не корректным типом BSON, должны быть вручную отобраны для соответствия.

20
ответ дан Blakes Seven 22 August 2018 в 09:49
поделиться
  • 1
    Вот и все, теперь работает. но обычно я бросаю id как строку в findOneAndUpdate или другой запрос, и он отлично работает, проблема только в совокупности? – Muhammad Fasalir Rahman 24 March 2016 в 05:59
  • 2
    @MuhammadFasalirRahman Это именно то, на что я ответил. A .find() может использовать Schema, который, конечно, имеет тип по умолчанию ObjectId для поля _id. Агрегационные конвейеры do not используют Schema, как я уже объяснил. – Blakes Seven 24 March 2016 в 06:06
  • 3
    Это не работает в мангусте 5 – Mina Luke 28 February 2018 в 02:28
  • 4
    Мне потребовалось три дня, чтобы добраться сюда; знак .. Я создал лямбда внутри моего статического метода схемы const castUserId = (userId) => mongoose.Types.ObjectId(userId) теперь я счастлив – timebandit 19 June 2018 в 17:23
Другие вопросы по тегам:

Похожие вопросы: