一步一步学Linq to sql(九):其它补充
外部映射文件
我们可以使用sqlmetal命令行工具来生成外部映射文件,使用方法如下:
1. 开始菜单 -》 VS2008 -》VS工具 -》VS2010命令行提示
2、输入命令:
sqlmetal /conn:server=.;database=pubs;uid=sa;pwd=saa /map:c:\pub.map /code:c:\pubs.cs
3.这样,我们就可以在C盘下得到一个xml映射文件和C#的实体类代码
4.把.cs文件添加到项目中来,然后使用下面的代码加载映射文件:
string path = @"C:\pub.map"; XmlMappingSource xms = XmlMappingSource.FromXml(File.ReadAllText(path)); Pubs ctx = new Pubs("server=.;database=pubs;uid=sa;pwd=saa", xms);
5、现在就可以照常进行其它工作了。使用sqlmetal可以很方便的同步数据库与实体和映射文件。每次修改数据库结构,从dbml设计器上删除表、存储过程然后再重新添加也是很麻烦的事情。
处理空值
var count = (from c in ctx.Authors where c.City == null select c).Count(); Console.WriteLine(count.ToString()); Console.ReadLine();
已编译查询
var author = from au in ctx.Authors select au; Console.WriteLine("Provider类型:"+ctx.Mapping.ProviderType); Console.WriteLine("数据库:" + ctx.Mapping.DatabaseName); Console.WriteLine("表:" + ctx.Mapping.GetTable(typeof(Authors)).TableName); Console.WriteLine("表达式:" + author.Expression.ToString());
Console.WriteLine("sql:" + author.Provider.ToString());
撤销提交
var author1 = ctx.Authors.Single(c => c.Au_lname == "Bennet"); author1.City = "深圳"; author1.Address = "广东"; Console.WriteLine("省份" + author1.Address + "城市" + author1.City); author1 = ctx.Authors.GetOriginalEntityState(author1); Console.WriteLine("省份" + author1.Address + "城市" + author1.City);
批量操作
下面的代码会导致提交N次DELETE操作:
var query1 = from c in ctx.Authors select c; ctx.Authors.DeleteAllOnSubmit(query1); ctx.SubmitChanges();
应该使用sql语句进行批操作:
string sql = String.Format("delete from {0}", ctx.Mapping.GetTable(typeof(Authors)).TableName); ctx.ExecuteCommand(sql);
对于批量更新操作也是同样道理。
分类:
Linq
标签:
Linq To Sql
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构