using System; using System.Collections.Generic; using Dapper; using DataModel.Helpers; using DataModel.Models; using Oracle.ManagedDataAccess.Client; namespace DataModel.Process { /// /// Work order routing transaction tracking functionality for JDE interface /// public partial class JDE { /// /// Fetches updates for work order routings /// /// Timestamp of last imported data /// Streaming work order routings for lots public static IEnumerable GetWorkOrderRoutings(DateTime? lastUpdateDT = null) { using (OracleConnection connection = GetConnection()) { var results = lastUpdateDT.HasValue ? connection.Query(queries["SQL_GET_WORKORDER_ROUTING_FILTERED"], new { dateUpdated = lastUpdateDT.Value.ToJDEDate(), timeUpdated = lastUpdateDT.Value.ToJDETime() }, buffered: false, commandTimeout: Config.QueryTimeout) : connection.Query(queries["SQL_GET_WORKORDER_ROUTING"], buffered: false, commandTimeout: Config.QueryTimeout); foreach (var result in results) { if (result.LastUpdateDT.Year < 1900 || result.LastUpdateDT.Year > 2500) { continue; } if (result.TransactionDate.Year < 1900 || result.TransactionDate.Year > 2500) { continue; } yield return result; } } } } }