先筆記一下
1.nameof 表示式
2.字串插值
3.Null 條件運算子
請參考
https://www.huanlintalk.com/2015/01/csharp6-enhanced-expressions.html
https://docs.microsoft.com/zh-tw/dotnet/csharp/language-reference/keywords/nameof
https://docs.microsoft.com/zh-tw/dotnet/csharp/tutorials/string-interpolation
https://docs.microsoft.com/zh-tw/dotnet/csharp/language-reference/operators/null-conditional-operators
2018年10月26日 星期五
2018年10月23日 星期二
[AutoMapper]使用方式
1.使用Nuget 搜尋套件AutoMapper並安裝
2. namespace 加入 using AutoMapper;
3.以下為基本使用方式
var query = db.vw_SchoolStdTotal.ToList(); var config = new MapperConfiguration(cfg => cfg.CreateMap<vw_SchoolStdTotal, SchoolStdTotalDataModel>()); config.AssertConfigurationIsValid(); var mapper = config.CreateMapper(); result = mapper.Map<List<vw_SchoolStdTotal>, List<SchoolStdTotalDataModel>>(query);
var config = new MapperConfiguration( cfg => cfg.CreateMap<SchoolStdTotalDataModel, vw_SchoolStdTotalViewModel>() //忽略此欄對應 .ForMember(d => d.SchoolName, o => o.Ignore()) .ForMember(d => d.ProfessionGroupDetailName, o => o.MapFrom(s => s.ProfessionGroupDetailName == null ? "國中部" : s.ProfessionGroupDetailName)) //資料源使用function處理 .ForMember(d => d.Button, o => o.MapFrom(s => dataListButton.ForGetTotalNumberHighSchoolList(desFun.DESEncrypt(s.ID.ToString())))));更新資料寫法
不需要的欄位使用Ignore排除,關聯Key也要排除不然會出錯
var query = db.PersonalInfo.Where(f => f.ID == ID).FirstOrDefault(); if (query != null) { var config = new MapperConfiguration( cfg => cfg.CreateMap未完待續.......() .ForMember(d => d.x1, o => o.Ignore()) .ForMember(d => d.x2, o => o.Ignore()) .ForMember(d => d.ModifyDate, o => o.MapFrom(s => DateTime.Now))); config.AssertConfigurationIsValid(); var mapper = config.CreateMapper(); //PersonalInfo personalInfo = db.PersonalInfo.Find(21); mapper.Map(viewModel, query); db.SaveChanges(); }
參考來源
https://automapper.org/
訂閱:
文章 (Atom)
Visual Studio JS intellisense 失效解決方式
試了好久,發現到工具>選項>IntelliCode js項目設定啟用,重新開啟VS就正常了! 後來發現是TypeScript3.2版有問題停用,使用4.3版的TypeScript即可
-
開啟記事本將以下程式碼貼入存成.bat @ECHO OFF set x=%date:~0,4%%date:~5,2%%date:~8,2% CD C:\Windows\System32\winevt\Logs COPY Application.evtx D:\bak\...
-
登入驗證時使用ValidateAntiForgeryToken只要返回上頁重新登入頁面會出現提供的反仿冒語彙基元是針對使用者 "XXX",但是目前的使用者是 ""。 請在登入頁判斷有無驗證成功即可 public ActionResul...
-
使用truncate table 時會出現 無法截斷資料表 'xxx',因為該資料表正由 FOREIGN KEY 條件約束參考解決方式 先刪除再重建自動編號即可。 DELETE table; DBCC CHECKIDENT('table'...