Nano Hash - криптовалюты, майнинг, программирование

Acumatica 2020R1 - FirstOrDefault выбирает другую строку

Я много использовал FirstOrDefault в своем коде (это привычка, я много использовал linq2sql в прошлом) и использую его в Acumatica. В рамках поддержки разработки его следует использовать только в том случае, если вы ожидаете одного результата.

У меня есть код на SOOrderEntry, который получает элемент в текущей строке, нажав кнопку и проверив несколько вещей. Это в моем расширении Graph.

Этот код работал до обновления:

SOLine Line = Base.Transactions.Current;
InventoryItem Item = SelectFrom<InventoryItem>.Where<InventoryItem.inventoryID.IsEqual<@P.AsInt>>.View.Select(Base, Line.InventoryID).FirstOrDefault();                
InventoryItemExt ItemExt = Item.GetExtension<InventoryItemExt>();

Результат не такой, как ожидалось. Line.InventoryID возвращает 10045, что является правильным элементом. Item.InventoryID: 10046

06.04.2020

Ответы:


1

После отладки я обнаружил, что новый аргумент, который можно легко использовать, - это новое свойство TopFirst. Это возвращает первый результат.

Следующий код работает должным образом (и как он работал в 2019 R2 и ранее!).

SOLine Line = Base.Transactions.Current;
InventoryItem Item = SelectFrom<InventoryItem>.Where<InventoryItem.inventoryID.IsEqual<@P.AsInt>>.View.Select(Base, Line.InventoryID).TopFirst;                
InventoryItemExt ItemExt = Item.GetExtension<InventoryItemExt>();
06.04.2020
  • Проблема в том, что FirstOrDefault не является частью Acumatica и поэтому не имеет понятия о порядке сортировки базы данных. Его контракт заключается в том, чтобы вернуть первый действительный элемент в коллекции dotnet, а не первую упорядоченную запись из базы данных. 06.04.2020
  • Это правильно. В предыдущем случае, который я открыл из-за этой проблемы в прошлом, FirstOrDefault обычно используется в случае, когда ожидается только одна запись. Те случаи, которые ожидали только одной записи, больше не нужны, чем было необходимо это исправление. 06.04.2020
  • Кроме того, он по-прежнему используется в репозитории кода, PX.Objects.PM.PMQuoteMaintExt, VisibilityHandler: CR.Standalone.CROpportunityRevision revisionInDb = PXSelectReadonly ‹CR.Standalone.CROpportunityRevision, где CR.StandaloneRevision ‹CRO CR.Standalone.CROpportunityRevision.noteID ››››. Выберите (База, row.QuoteID) .FirstOrDefault (); 06.04.2020
  • Я думаю, что здесь применяется то же правило, оно может вызвать проблемы только тогда, когда важен порядок сортировки. Использование Top учитывает сортировку на уровне БД, которая имеет другое поведение. 06.04.2020
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

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

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..