专栏首页技术博客一步一步学Linq to sql(九):其它补充

一步一步学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());

撤销提交

            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);

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Dynamic 动态类型 和双问号??的使用

    1.dynamic关键字用于声明一个动态对象,然后通过该动态对象去调用方法或读写属性。以前我们都是在运行时通过反射,Emit,CodeDom等技术来完成。创建一...

    aehyok
  • Entity Framework CodeFirst尝试

    Code First模式我们称之为“代码优先”模式,是从EF4.1开始新建加入的功能。使用Code First模式进行EF开发时开发人员只需要编写对应的数据类(...

    aehyok
  • 设计模式之四(抽象工厂模式第一回合)

    首先关于抽象工厂模式的学习,我们需要慢慢的,由浅入深的进入。不能单刀直入,否则可能达不到预期学明白的目标。

    aehyok
  • 滴滴如何用八十万成为百亿美金公司?

    大数据文摘
  • Rust Search Extension两周年,发布1.0版!

    大家好, Rust Search Extension是我从2018年开始开发的浏览器插件,方便Rust开发者在浏览器地址栏快速搜索官方文档、内置属性、crate...

    MikeLoveRust
  • Ruby执行shell命令的六种方法

    在Ruby中,执行shell命令是一件不奇怪的事情,Ruby提供了大概6种方法供开发者进行实现。这些方法都很简单,本文将具体介绍一下如何在Ruby脚本中进行调用...

    技术小黑屋
  • Spring MVC表单防重复提交

    利用Spring MVC的过滤器及token传递验证来实现表单防重复提交。 创建注解 @Target(ElementType.METHOD) @Retentio...

    Java技术栈
  • Leetcode Golang 105. Construct Binary Tree from Preorder and Inorder Traversal.go

    版权声明:原创勿转 https://blog.csdn.net/anakinsun/article/details/88935501

    anakinsun
  • 这道上台阶的编程题你会不会?(递归和迭代思想)

    one保存最后走1步,two保存最后走2步。循环迭代就是不断修改这两个(one,two)变量的值。

    Wizey
  • P1147 连续自然数和

    题目描述 对一个给定的自然数M,求出所有的连续的自然数段,这些连续的自然数段中的全部数之和为M。 例子:1998+1999+2000+2001+2002 = 1...

    attack

扫码关注云+社区

领取腾讯云代金券