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

简介: 外部映射文件 我们可以使用sqlmetal命令行工具来生成外部映射文件,使用方法如下: 1. 开始菜单 -》 VS2008 -》VS工具 -》VS2010命令行提示 2、输入命令: sqlmetal /conn:server=.

外部映射文件

我们可以使用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);

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

目录
相关文章
|
7月前
|
SQL 开发框架 .NET
C# Linq SaveChanges()报错 You have an error in your SQL syntex
C# Linq SaveChanges()报错 You have an error in your SQL syntex
29 0
|
SQL 开发框架 .NET
SQL中in和not in在LINQ中的写法
SQL中in和not in在LINQ中的写法
|
SQL 开发框架 .NET
ef linq方式插入+sql操作数据注意事项
ef linq方式插入+sql操作数据注意事项
93 0
|
SQL 监控 HIVE
网站流量日志分析--统计分析--sql 补充扩展--如何编写 hive sql|学习笔记
快速学习网站流量日志分析--统计分析--sql 补充扩展--如何编写 hive sql
121 0
|
SQL 监控 NoSQL
网站流量日志分析--统计分析--sql补充扩展--group by 语法限制解析|学习笔记
快速学习网站流量日志分析--统计分析--sql补充扩展--group by 语法限制解析
178 0
|
SQL 关系型数据库 MySQL
【sql语句基础】——查(select)(单表查询顺序补充)
【sql语句基础】——查(select)(单表查询顺序补充)
|
SQL 分布式计算 资源调度
大数据进阶之路——Spark SQL补充
文章目录 手写 WordCount RDD、DAG、 Stage、 Task 、 Job Spark 作业提交流程 Spark 的 Local 和 Standalone 宽依赖、窄依赖 Spark SQL比 Hive 快在哪 打包的注意事项
186 0
大数据进阶之路——Spark SQL补充
|
SQL 存储 开发框架
Linq To SQl总结
Linq To SQl总结
180 0
Linq To SQl总结
|
SQL 开发框架 安全
Linq to SQL中的ColumnAttribute中的Expression
在Linq to SQL中,使用ColumnAttribute特性来关联数据库和实体类。这个Atrribute也有很多属性可以设置。其中让人比较迷糊的是Expression,也折磨了我好几天才弄明白(因为官方的例子给的也让人迷糊,基本运行都无法通过)。
529 0
Linq to SQL中的ColumnAttribute中的Expression
|
SQL .NET 开发框架
Linq SQL 动态个数where查询
Linq SQL 动态个数where查询,从parts表中查找工件类型ID为1、2或6...(个数不定)的所有part。
8452 0