在向大家详细介绍Linq使用sqlmetal之前,首先让大家了解下外部映射文件,然后全面介绍Linq使用sqlmetal。
创新互联是一家专业提供乌兰察布企业网站建设,专注与成都网站设计、网站制作、html5、小程序制作等业务。10年已为乌兰察布众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。
外部映射文件
我们可以Linq使用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、现在就可以照常进行其它工作了。Linq使用sqlmetal可以很方便的同步数据库与实体和映射文件。每次修改数据库结构,从dbml设计器上删除表、存储过程然后再重新添加也是很麻烦的事情。
处理空值
- var count = (from c in ctx.Customers where c.Region == null select c).Count();
- Response.Write(count + "
");- var query = from emp in ctx.Employees select emp.ReportsTo;
- foreach (Nullable
r in query) - {
- Response.Write(r.HasValue ? r.Value.ToString() + "
" : "没有
");- }
代码执行后捕获到下面的SQL被执行:
- SELECT COUNT(*) AS [value]
- FROM [dbo].[Customers] AS [t0]
- WHERE [t0].[Region] IS NULL
- SELECT [t0].[ReportsTo]
- FROM [dbo].[Employees] AS [t0]
【编辑推荐】
标题名称:Linq使用sqlmetal剖析
分享地址:http://www.mswzjz.cn/qtweb/news37/1087.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能