9,高级技巧补充
概要:
外部映射,处理空值,已编译查询,获取信息,撤销提交,批量操作
此系列是我的学习笔记,仅供个人复习,原链接在第一篇中有。
内容:
外部映射文件
我们可以使用sqlmetal命令行工具来生成外部映射 文件,使用方法如下:
1、开始菜单 -》 VS2008 -》VS工具 -》VS2008命令行提示
2、输入命令:
D:\Program Files\Microsoft Visual Studio 9.0\VC>sqlmetal /conn:server=xxx; database=Northwind;uid=xxx;pwd=xxx /map:c:\northwind.map /code:c:\northwind.cs |
3、这样,我们就可以在C盘下得到一个xml映射文件和C#的实体类代码
4、把.cs文件添加到项目中来(放到App_Code目录),然后使用下面的代码加载映射文件:
String path = @"C:\Northwind.map"; XmlMappingSource xms = XmlMappingSource.FromXml(File.ReadAllText(path)); Northwind ctx = new Northwind("server=xxx;database=Northwind;uid=xxx;pwd=xxx", xms); |
5、现在就可以照常进行其它工作了。使用sqlmetal可以很方便的同步数据库与实体和映射文件。每次修改数据库结构,从dbml设计器上删除表、存储过程然后再重新添加也是很麻烦的事情。
处理空值
var count = (from c in ctx.Customers where c.Region == null select c).Count(); Response.Write(count + "<br/>"); var query = from emp in ctx.Employees select emp.ReportsTo; foreach (Nullable<int> r in query) { Response.Write(r.HasValue ? r.Value.ToString() + "<br/>" : "没有<br/>"); } |
已编译查询
对于一些在项目中经常 被用到的查询可以封装成已编译查询,这样就能提高执行效率:
static class Queries { public static Func<NorthwindDataContext, string, IQueryable<Customer>> CustomersByCity = CompiledQuery.Compile((NorthwindDataContext ctx, string city) => from c in ctx.Customers where c.City == city select c); } |
调用查询方式如下:
GridView1.DataSource = Queries.CustomersByCity(ctx, "London"); GridView1.DataBind(); |
获取一些信息
var query = from c in ctx.Customers select c; Response.Write("Provider类型:" + ctx.Mapping.ProviderType + "<br/>"); Response.Write("数据库:" + ctx.Mapping.DatabaseName + "<br/>"); Response.Write("表:" + ctx.Mapping.GetTable(typeof(Customer)).TableName + "<br/>"); Response.Write("表达式:" + query.Expression.ToString() + "<br/>"); Response.Write("sql:" + query.Provider.ToString() + "<br/>"); |
撤销提交
var customer = ctx.Customers.Single(c => c.CustomerID == "AROUT"); customer.ContactName = "zhuye"; customer.Country = "Shanghai"; Response.Write(string.Format("Name:{0},Country:{1}<br/>", customer.ContactName, customer.Country)); customer = ctx.Customers.GetOriginalEntityState(customer); Response.Write(string.Format("Name:{0},Country:{1}<br/>", customer.ContactName, customer.Country)); |
上面的代码执行效果如 下:
Name:zhuye,Country:Shanghai |
批量操作
下面的代码会导致提交N次DELETE操作:
var query = from c in ctx.Customers select c; ctx.Customers.RemoveAll(query); ctx.SubmitChanges(); |
应该使用sql语句进行批操作:
string sql = String.Format("delete from {0}", ctx.Mapping.GetTable(typeof(Customer)).TableName); ctx.ExecuteCommand(sql); |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述