我以前是 Winforms 程序员;我总是将我编写的程序分为两部分,前端(Winforms)和中间层(由 Remoting/WCF 促进)
在这种方法中,前端代码无法访问 Linq 或 System.Data.SqlClient。但这还有一个额外的优势,即中间层是即时 SOA 公民(面向服务的架构),可用于 B2B 场景,与数据库无关,并且支持互联网,即使它只是一个 Winforms 应用程序。
现在我正在学习网络技能。使用 Pro ASP.NET MVC 一书中的 SportsStore 项目,我不可避免地会比较我的旧(?)方法(中间层)和那本书上的存储库方法。存储库方法直接在前端(SportsStore.WubUI)上公开数据访问机制(Linq to SQL)。使用存储库方法,SportsStore.WebUI 仍然可以直接连接到数据库。
问题是,在 Web 程序上,我是否应该希望前端只与中间层接口(因此前端可以与数据库无关,而中间层是即时 SOA 公民),还是我应该在前端直接使用数据库(通过存储库方法、ORM 或类似方法)?