天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

一步一步學(xué)Linq to sql(九):其它補(bǔ)充

系列文章導(dǎo)航:

一步一步學(xué)Linq to sql(一):預(yù)備知識(shí)

一步一步學(xué)Linq to sql(二):DataContext與實(shí)體

一步一步學(xué)Linq to sql(三):增刪改

一步一步學(xué)Linq to sql(四):查詢句法

一步一步學(xué)Linq to sql(五):存儲(chǔ)過程

一步一步學(xué)Linq to sql(六):探究特性

一步一步學(xué)Linq to sql(七):并發(fā)與事務(wù)

一步一步學(xué)Linq to sql(八):繼承與關(guān)系

一步一步學(xué)Linq to sql(九):其它補(bǔ)充

一步一步學(xué)Linq to sql(十):分層構(gòu)架的例子


 外部映射文件

       我們可以使用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盤下得到一個(gè)xml映射文件和C#的實(shí)體類代碼

4、把.cs文件添加到項(xiàng)目中來(放到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、現(xiàn)在就可以照常進(jìn)行其它工作了。使用sqlmetal可以很方便的同步數(shù)據(jù)庫與實(shí)體和映射文件。每次修改數(shù)據(jù)庫結(jié)構(gòu),從dbml設(shè)計(jì)器上刪除表、存儲(chǔ)過程然后再重新添加也是很麻煩的事情。

處理空值

          var count = (from c in ctx.Customers where c.Region == null select c).Count();

        Response.Write(count + "<br/>");

        var query = from emp in ctx.Employees select emp.ReportsTo;

        foreach (Nullable<int> r in query)

        {

            Response.Write(r.HasValue ? r.Value.ToString() + "<br/>" : "沒有<br/>");

        }

       代碼執(zhí)行后捕獲到下面的SQL被執(zhí)行:

SELECT COUNT(*) AS [value]

FROM [dbo].[Customers] AS [t0]

WHERE [t0].[Region] IS NULL

 

SELECT [t0].[ReportsTo]

FROM [dbo].[Employees] AS [t0]

 

系列文章導(dǎo)航:

一步一步學(xué)Linq to sql(一):預(yù)備知識(shí)

一步一步學(xué)Linq to sql(二):DataContext與實(shí)體

一步一步學(xué)Linq to sql(三):增刪改

一步一步學(xué)Linq to sql(四):查詢句法

一步一步學(xué)Linq to sql(五):存儲(chǔ)過程

一步一步學(xué)Linq to sql(六):探究特性

一步一步學(xué)Linq to sql(七):并發(fā)與事務(wù)

一步一步學(xué)Linq to sql(八):繼承與關(guān)系

一步一步學(xué)Linq to sql(九):其它補(bǔ)充

一步一步學(xué)Linq to sql(十):分層構(gòu)架的例子


已編譯查詢

       對(duì)于一些在項(xiàng)目中經(jīng)常被用到的查詢可以封裝成已編譯查詢,這樣就能提高執(zhí)行效率:

static class Queries

{

    public static Func<NorthwindDataContext, string, IQueryable<Customer>>

        CustomersByCity = CompiledQuery.Compile((NorthwindDataContext ctx, string city) => from c in ctx.Customers where c.City == city select c);

}

       調(diào)用查詢方式如下:   

        GridView1.DataSource = Queries.CustomersByCity(ctx, "London");

        GridView1.DataBind();

 
獲取一些信息

        var query = from c in ctx.Customers select c;

        Response.Write("Provider類型:" + ctx.Mapping.ProviderType + "<br/>");

        Response.Write("數(shù)據(jù)庫:" + ctx.Mapping.DatabaseName + "<br/>");

        Response.Write("表:" + ctx.Mapping.GetTable(typeof(Customer)).TableName + "<br/>");

        Response.Write("表達(dá)式:" + query.Expression.ToString() + "<br/>");

        Response.Write("sql" + query.Provider.ToString() + "<br/>");

       上面的代碼執(zhí)行結(jié)果如下:

Provider類型:System.Data.Linq.SqlClient.SqlProvider
數(shù)據(jù)庫:Northwind
表:dbo.Customers
表達(dá)式:Table(Customer).Select(c => c)
sql
SELECT [t0].[CustomerID], [t0].[CompanyName], [t0].[ContactName], [t0].[ContactTitle], [t0].[Address], [t0].[City], [t0].[Region], [t0].[PostalCode], [t0].[Country], [t0].[Phone], [t0].[Fax] FROM [dbo].[Customers] AS [t0]窗體頂端

窗體底端

系列文章導(dǎo)航:

一步一步學(xué)Linq to sql(一):預(yù)備知識(shí)

一步一步學(xué)Linq to sql(二):DataContext與實(shí)體

一步一步學(xué)Linq to sql(三):增刪改

一步一步學(xué)Linq to sql(四):查詢句法

一步一步學(xué)Linq to sql(五):存儲(chǔ)過程

一步一步學(xué)Linq to sql(六):探究特性

一步一步學(xué)Linq to sql(七):并發(fā)與事務(wù)

一步一步學(xué)Linq to sql(八):繼承與關(guān)系

一步一步學(xué)Linq to sql(九):其它補(bǔ)充

一步一步學(xué)Linq to sql(十):分層構(gòu)架的例子


撤銷提交

        var customer = ctx.Customers.Single(c => c.CustomerID == "AROUT");

        customer.ContactName = "zhuye";

        customer.Country = "Shanghai";

        Response.Write(string.Format("Name:{0},Country:{1}<br/>", customer.ContactName, customer.Country));

        customer = ctx.Customers.GetOriginalEntityState(customer);

        Response.Write(string.Format("Name:{0},Country:{1}<br/>", customer.ContactName, customer.Country));

       上面的代碼執(zhí)行效果如下:

Name:zhuye,Country:Shanghai
Name:Thomas Hardy,Country:UK

批量操作

       下面的代碼會(huì)導(dǎo)致提交NDELETE操作:

        var query = from c in ctx.Customers select c;

        ctx.Customers.RemoveAll(query);

        ctx.SubmitChanges();

       應(yīng)該使用sql語句進(jìn)行批操作:

        string sql = String.Format("delete from {0}", ctx.Mapping.GetTable(typeof(Customer)).TableName);

        ctx.ExecuteCommand(sql);

       對(duì)于批量更新操作也是同樣道理。

本文將會(huì)不斷補(bǔ)充其它點(diǎn)滴。最后一篇將會(huì)結(jié)合分層分布式應(yīng)用給出一個(gè)實(shí)際的項(xiàng)目。

it知識(shí)庫一步一步學(xué)Linq to sql(九):其它補(bǔ)充,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 爽死你个放荡粗暴小淫货漫画 | 大乳牛奶女magnet | 国产精品97久久AV麻豆 | 在线观看成年人免费视频 | 无限资源在线观看高清 | 97免费人妻在线观看 | 国产福利一区二区精品 | 精品一区二区三区四区五区六区 | 色欲精品国产AV久久久 | 男人的天堂色偷偷 | 又紧又大又爽精品一区二区 | 大香伊蕉在人线国产97 | 美女叉腿掰阴大胆艺术照 | 亚洲va在线va天堂XX xX | 有码在线播放 | 亚洲高清无在码在线电影 | 色-情-伦-理一区二区三区 | 国产欧美日韩网站 | 一个人看的www视频动漫版 | 久久精品熟女亚洲AV国产 | 办公室中文BD | 国产午夜AV无码无片久久96 | 韩国伦理片2018在线播放免费观看 | 泡妞高手在都市完整版视频免费 | 久久人妻熟女中文字幕AV蜜芽 | 国产色精品久久人妻无码看片软件 | 精品无码人妻一区二区免费AV | 在线观看中文字幕码2021不用下载 | 亚洲一区二区免费看 | 春药按摩人妻中文字幕 | 亚洲黄视频在线观看 | 怪物高h粗暴无尽 | 视频专区亚洲欧美日韩 | 色色色999 | 国产传媒在线观看 | 美女用手扒开粉嫩的屁股 | 里番acg纲手的熟蜜姬训练场 | 亚洲国产精品一区二区久久第 | 乱VODAFONEWIFI熟妇| 婷婷久久无码欧美人妻 | 免费欧美大片 |