.NET 下的一些查詢

我用過的.NET下的查詢方案

linq 2 sql

  1. 構(gòu)造查詢表達(dá)式,返回IQueryable對象.注意,生成這個IQueryable的時候,并沒有真正讀取數(shù)據(jù)庫:
                var q = from pp in ctx.Set<PostPicture>()
                    where pp.PostId == postId
                    orderby pp.Order
                    select new PictureInfo//這里的代碼實際上,介于C#和SQL之間,所以,在這里寫toString,會error的
                    {
                        Description = pp.Description,
                        RawUrl = pp.Url
                    };
  1. 根據(jù)這個查詢表達(dá)式,生成SQL腳本,去數(shù)據(jù)庫執(zhí)行腳本,并映射到對應(yīng)的實體類.通常這一步拋出異常,
    常見的異常有比如,timeout,使用了EF不認(rèn)識的函數(shù)(比方說數(shù)據(jù)類型轉(zhuǎn)換)
                q.ToList();//可以使用 q.ToListAsync();異步方法

linq 2 object

根據(jù)Linq 的特性,只要是序列,就繼承IEnumerbale接口,就可以使用Linq to this
與linq 2 sql 最大的差別就是,linq 2 object 是查詢本地(內(nèi)存中)的對象序列的操作,
所以linq2object實際上,是一種語法糖.在linq2object中可以采用各種函數(shù)來完成定制化要求.
具體語法與linq2sql一致.
一般情況下,我會采用先linq2sql與http請求獲取各個服務(wù)之間的數(shù)據(jù),然后在使用linq to object 拼接這些數(shù)據(jù)
未來可采用rx.Net來觀察數(shù)據(jù)流,并訂閱相關(guān)事件.    

ADO.NET 與 sqlhelper

在Entity framework中使用sqlquery<TObject>

上次碰到一個不算特殊的特殊要求.于是,創(chuàng)造出這種很奇怪的源生SQL+Linq expression混寫的方法,只是想說明一點,EF其實很靈活.
            using (var ctx = DbContextFactory.Default.Create())
            {
                var infos = ctx.Database.SqlQuery<PostRecyleInfo>(@"select 
A.Id,
B.AuthorId,
B.Content,
C.MangaId,
D.ClubId,
E.Name ClubName,
B.CreateTime,
A.DeleteOperator,
A.DeleteTime
from PostRecyles A
left join Posts B
on A.Id = B.Id
left join PostAssociatedMangas C
on a.Id = C.Id
left join MainPosts D
on a.Id = D.Id
left join Clubs E
on D.ClubId = E.Id
");
                var postRecyleInfos = infos.Where(i => id == null || i.Id == id)
                                            .Where(i => keyWords == null || i.Content.Contains(keyWords))
                                            .Where(i => authorId == null || i.AuthorId == authorId)
                                            .Where(i => mangaId == null || i.MangaId == mangaId)
                                            .Where(i => clubId == null || i.ClubId == clubId)
                                            .Where(i => clubName == null || i.ClubName == clubName)
                                            .Where(i => createTimeStart == null || i.CreateTime > createTimeStart.Value)
                                            .Where(i => createTimeEnd == null || i.CreateTime < createTimeEnd.Value)
                                            .Where(i => deleteTimeStart == null || i.DeleteTime > deleteTimeStart.Value)
                                            .Where(i => deleteTimeEnd == null || i.DeleteTime < deleteTimeEnd.Value);
                var postRecyles = postRecyleInfos
                    .Page(start, limit);
                return postRecyles;
            }

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鸟废,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件疟羹,死亡現(xiàn)場離奇詭異读跷,居然都是意外死亡底燎,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進(jìn)店門社裆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拙绊,“玉大人,你說我怎么就攤上這事泳秀”昊Γ” “怎么了?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵嗜傅,是天一觀的道長金句。 經(jīng)常有香客問我,道長吕嘀,這世上最難降的妖魔是什么违寞? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮偶房,結(jié)果婚禮上趁曼,老公的妹妹穿的比我還像新娘。我一直安慰自己蝴悉,他們只是感情好彰阴,可當(dāng)我...
    茶點故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著拍冠,像睡著了一般尿这。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上庆杜,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天射众,我揣著相機與錄音,去河邊找鬼晃财。 笑死叨橱,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的断盛。 我是一名探鬼主播罗洗,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼钢猛!你這毒婦竟也來了伙菜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤命迈,失蹤者是張志新(化名)和其女友劉穎贩绕,沒想到半個月后火的,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡淑倾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年馏鹤,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片娇哆。...
    茶點故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡湃累,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出迂尝,到底是詐尸還是另有隱情脱茉,我是刑警寧澤剪芥,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布垄开,位于F島的核電站,受9級特大地震影響税肪,放射性物質(zhì)發(fā)生泄漏溉躲。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一益兄、第九天 我趴在偏房一處隱蔽的房頂上張望锻梳。 院中可真熱鬧,春花似錦净捅、人聲如沸疑枯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽荆永。三九已至,卻和暖如春国章,著一層夾襖步出監(jiān)牢的瞬間具钥,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工液兽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留骂删,地道東北人。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓四啰,卻偏偏與公主長得像宁玫,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子柑晒,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,654評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理欧瘪,服務(wù)發(fā)現(xiàn),斷路器敦迄,智...
    卡卡羅2017閱讀 134,652評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,085評論 25 707
  • 此文章是我在學(xué)習(xí)CoreData的時候找到的非常詳細(xì)的文章恋追,所以在此做個鏈接收錄筆記凭迹。 iOS開發(fā) - CoreD...
    阿唯不知道閱讀 170評論 0 0
  • 討厭失望的感覺,也討厭等待的感覺苦囱。 有一天嗅绸,我們攢夠了失望。 干嘛要可憐自己撕彤,養(yǎng)分靠別人給鱼鸠,最是傷痛。 你看花還是...
    芷妹妹閱讀 277評論 0 0
  • 對,你沒有看錯职员,不是熱播劇老司機之間不吝分享經(jīng)驗傳達(dá)秘訣的“撩”麻蹋,也不是懷舊到追溯八十年代港臺偶像劇葬愛家族造型式...
    白若北閱讀 388評論 0 0