這是一種家庭作業,所以有人可以指導我(而不是回答)如何組合這兩個 LINQ 查詢。這是問題通過使用 LINQ 將 List 映射到一個匿名對象列表來更新 PayrollSytem,其中每個對象都包含一個員工的姓名和收入。當遇到 BasePlusCommissionEmployee 時,在不修改原始 BasePlusCommissionEmployee 對象的情況下,將基本工資提高 10%。顯示姓名和收入。到目前為止我有這個var model1 = employees.OfType<BasePlusCommissionEmployee>().Select(x => new { x.FirstName, x.LastName, Increased_salary=x.BaseSalary*=1.10M });var model = employees.Select(x => new { x.FirstName, x.LastName, earning = x.Earnings() });foreach (var item in model) { Console.WriteLine(item); }類的UML圖是所以查詢單獨工作正常,但有什么方法可以使它成為一個查詢。如果需要任何其他代碼,我會提供。
1 回答

慕容708150
TA貢獻1831條經驗 獲得超4個贊
您可以使用匿名類中的三元運算符簡單地檢查員工是否是基礎加傭金員工。
employees.Select(x => new {
FirstName = x.FirstName,
LastName = x.LastName,
Salary = x is BasePlusCommissionEmployee ? (x as BasePlusCommissionEmployee).BaseSalary * 1.1M : x.Earnings()
}).ToList();
- 1 回答
- 0 關注
- 72 瀏覽
添加回答
舉報
0/150
提交
取消