前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >一步一步学Linq to sql(九):其它补充

一步一步学Linq to sql(九):其它补充

作者头像
aehyok
发布2018-09-11 12:26:33
2920
发布2018-09-11 12:26:33
举报
文章被收录于专栏:技术博客技术博客

外部映射文件

我们可以使用sqlmetal命令行工具来生成外部映射文件,使用方法如下:

1. 开始菜单 -》 VS2008 -》VS工具 -》VS2010命令行提示

2、输入命令:

代码语言:javascript
复制
sqlmetal  /conn:server=.;database=pubs;uid=sa;pwd=saa /map:c:\pub.map  /code:c:\pubs.cs

3.这样,我们就可以在C盘下得到一个xml映射文件和C#的实体类代码

4.把.cs文件添加到项目中来,然后使用下面的代码加载映射文件:

代码语言:javascript
复制
            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设计器上删除表、存储过程然后再重新添加也是很麻烦的事情。

处理空值

代码语言:javascript
复制
            var count = (from c in ctx.Authors where c.City == null select c).Count();
            Console.WriteLine(count.ToString());
            Console.ReadLine();

已编译查询

代码语言:javascript
复制
            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());

撤销提交

代码语言:javascript
复制
            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操作:

代码语言:javascript
复制
            var query1 = from c in ctx.Authors select c;

            ctx.Authors.DeleteAllOnSubmit(query1);

            ctx.SubmitChanges();

应该使用sql语句进行批操作:

代码语言:javascript
复制
            string sql = String.Format("delete from {0}", ctx.Mapping.GetTable(typeof(Authors)).TableName);

            ctx.ExecuteCommand(sql);

  对于批量更新操作也是同样道理。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2013-04-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
命令行工具
腾讯云命令行工具 TCCLI 是管理腾讯云资源的统一工具。使用腾讯云命令行工具,您可以快速调用腾讯云 API 来管理您的腾讯云资源。此外,您还可以基于腾讯云的命令行工具来做自动化和脚本处理,以更多样的方式进行组合和重用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档