日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

深入LINQ | 动态构建LINQ表达式

發(fā)布時間:2023/12/4 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深入LINQ | 动态构建LINQ表达式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文:bit.ly/3fwlKQJ
作者:Jeremy Likness
譯者:精致碼農-王亮

LINQ 是 Language Integrated Query(語言集成查詢)的縮寫,是我最喜歡的 .NET 和 C# 技術之一。使用 LINQ,開發(fā)者可以直接在強類型代碼中編寫查詢。LINQ 提供了一種標準的語言和語法,使不同的數據源的查詢編碼方法一致。

1一些基礎

考慮如下這個 LINQ 查詢(你可以把它粘貼到一個控制臺應用程序中運行)。

using System; using System.Linq;public?class?Program {public?static?void?Main(){var someNumbers = new?int[]{4, 8, 15, 16, 23, 42};var query =from num in someNumberswhere num > 10orderby num descendingselect num.ToString();Console.WriteLine(string.Join('-', query.ToArray()));// 42-23-16-15} }

因為 someNumbers 是一個 IEnumerable<int>,該查詢是被 LINQ to Objects 解析的。同樣的查詢語法可用于像 Entity Framework Core 這樣的工具,生成針對關系型數據庫運行的 T-SQL。LINQ 可以使用兩種語法來編寫:查詢語法(如上所示)和(擴展)方法語法。這兩種語法在語義上是相同的,你使用哪一種語法取決于你的偏好。上面同樣的查詢可以用方法語法寫成這樣:

var secondQuery = someNumbers.Where(n => n > 10).OrderByDescending(n => n).Select(n => n.ToString());

每個 LINQ 查詢都有三個階段:

  • 設置一個數據源,稱為提供者(provider),供查詢時使用。例如,到目前為止的代碼使用了內置的 LINQ to Objects 提供者。你的 EF Core 項目使用的是 EF Core 提供者,它映射到你的數據庫。

  • 查詢被定義并轉變成一個表達式樹(expression tree),我將在稍后介紹。

  • 查詢被執(zhí)行,數據被返回。

  • 第 3 步很重要,因為 LINQ 使用了所謂的延遲執(zhí)行(deferred execution)。在上面的例子中,secondQuery 定義了一個表達式樹,但還沒有返回任何數據。事實上,在你開始迭代數據之前,實際上什么都沒有發(fā)生。這很重要,因為它允許提供者通過只提供所要求的數據。例如,假設你想用 secondQuery 找到一個特定的字符串,所以你做了這樣的事情:

    var found = false; foreach(var item in secondQuery.AsEnumerable()) {if (item == "23"){found = true;break;} }

    一個提供者通過枚舉器(enumerator)訪問,這樣它就可以一次輸入一個元素的數據。如果你在第三次迭代時得到了想要的值,可能實際上只有三條數據從數據庫中返回。另一方面,當你使用 .ToList() 擴展方法時,所有的數據都會立即被取出并填充到列表中。

    2難題

    我作為我們公司的 .NET 項目經理,我經常與客戶交談,了解他們的需求。最近,我與一位客戶進行了討論,他想在他們的網站上使用第三方控件來建立業(yè)務規(guī)則。更具體地說,業(yè)務規(guī)則是“謂詞”(predicates,譯注:也可以翻譯成判斷語句)或一組條件,可解析為 true 或 false。該工具可以用 JSON 或 SQL 格式生成規(guī)則。SQL 很香,可以持久化到給數據庫,但他們的要求是將“謂詞”應用于內存對象,作為服務器上的一個過濾器。他們正在考慮使用一種工具,將 SQL 翻譯成表達式(其實就是動態(tài)生成 LINQ)。我建議使用 JSON 格式,因為它可以被解析成 LINQ 表達式,針對內存中的對象運行,或者很容易應用到 Entity Framework Core 集合,相對 SQL 數據庫是更好的選擇。

    我只要處理工具產生的 JSON:

    {"condition": "and","rules": [{"label": "Category","field": "Category","operator": "in","type": "string","value": ["Clothing"]},{"condition": "or","rules": [{"label": "TransactionType","field": "TransactionType","operator": "equal","type": "boolean","value": "income"},{"label": "PaymentMode","field": "PaymentMode","operator": "equal","type": "string","value": "Cash"}]},{"label": "Amount","field": "Amount","operator": "equal","type": "number","value": 10}] }

    結構很簡單:有一個 AND 或 OR 條件,包含一組規(guī)則,要么是比較,要么是嵌套條件。我的目標有兩個:學習更多關于 LINQ 表達式的知識,以便更好地了解 EF Core 和相關技術;提供一個簡單的例子,說明如何在不依賴第三方工具的情況下使用 JSON。

    3動態(tài)表達式

    我創(chuàng)建了一個簡單的控制臺應用程序來測試我的假設,即解析 JSON 信息直接生成 LINQ 查詢。

    https://github.com/JeremyLikness/ExpressionGenerator

    譯注:建議參照此 GitHub 源代碼閱讀本文,方便理解。

    在本文的第一部分,將啟動項目設置為 ExpressionGenerator。如果你從命令行運行它,請確保 rules.json 在你的當前目錄中。

    我將樣本 JSON 嵌入為 rules.json。使用 System.Text.Json 來解析文件,就是這么簡單:

    var jsonStr = File.ReadAllText("rules.json"); var jsonDocument = JsonDocument.Parse(jsonStr);

    然后我創(chuàng)建了一個 JsonExpressionParser 來解析 JSON 并創(chuàng)建一個表達式樹。因為動態(tài)表達式是一個謂詞,所以表達式樹是由二元表達式 BinaryExpression 的實例構成的,這些實例計算一個左表達式和一個右表達式。這個計算可能是一個邏輯門(AND 或 OR),或一個比較(equal 或 greaterThan),或一個方法調用。對于 In 的情況,即我們想讓屬性 Category 出現在一個列表中,我使用 Contains。從概念上講,引用的 JSON 看起來像這樣:

    /-----------AND-----------\| |/-AND-\ | Category IN ['Clothing'] Amount eq 10.0 /-OR-\TransactionType EQ 'income' PaymentMode EQ 'Cash'

    注意,每個節(jié)點都是二元的。讓我們開始解析吧!

    4引入 Transaction

    注意,這不是 System.Transaction(這里的 Transaction 不是指事務,而是指交易)。這是示例項目中使用的一個自定義類。我沒有在供應商的網站上花很多時間,所以我根據規(guī)則猜測實體可能的樣子。我想出了這個:

    public?class?Transaction {public?int Id { get; set; }public?string Category { get; set; }public?string TransactionType { get; set; }public?string PaymentMode { get; set; }public?decimal Amount { get; set; } }

    我還添加了一些額外的方法,以使其易于生成隨機實例。你可以自己在 GitHub 代碼中看到這些。

    5參數表達式

    主要方法返回一個謂詞(predicate)函數。下面是該方法開始部分的代碼:

    public?Func<T, bool> ParsePredicateOf<T>(JsonDocument doc) {var itemExpression = Expression.Parameter(typeof(T));var conditions = ParseTree<T>(doc.RootElement, itemExpression); }

    第一步是創(chuàng)建謂詞參數。謂詞可以傳遞給 Where 子句,如果我們自己寫的話,它看起來就像這樣:

    var query = ListOfThings.Where(t => t.Id > 2);

    t => 是一個參數,代表列表中一個條目的類型。因此,我們?yōu)樵擃愋蛣?chuàng)建一個參數。然后我們遞歸地遍歷 JSON 節(jié)點來建立樹。

    6邏輯表達式

    解析器的開頭看起來像這樣:

    private Expression ParseTree<T>(JsonElement condition,ParameterExpression parm){Expression left = null;var gate = condition.GetProperty(nameof(condition)).GetString();JsonElement rules = condition.GetProperty(nameof(rules));Binder binder = gate == And ? (Binder)Expression.And : Expression.Or;Expression bind(Expression left, Expression right) =>left == null ? right : binder(left, right);

    gate 變量是條件,即“and”或“or”。規(guī)則語句得到一個節(jié)點,是相關規(guī)則的列表。我們正在跟蹤表達式的左邊和右邊。Binder 簽名是二元表達式的簡寫,定義如下:

    private?delegate Expression Binder(Expression left, Expression right);

    binder 變量簡單地設置了頂層表達式:Expression.And 或 Expression.Or。兩者都使用左邊和右邊表達式來計算。

    bind 函數更有趣一點。當我們遍歷樹時,我們需要建立各種節(jié)點。如果我們還沒有創(chuàng)建一個表達式(left 是 null),我們就從創(chuàng)建的第一個表達式開始。如果我們有一個現有的表達式,我們就用這個表達式來合并兩邊的內容。

    現在,left 是 null,然后我們開始列舉屬于這個條件的規(guī)則:

    foreach (var rule in rules.EnumerateArray())

    7屬性表達式

    第一條規(guī)則是一個相等規(guī)則,所以我現在跳過條件部分。大致情況是下面這樣的:

    string @operator = rule.GetProperty(nameof(@operator)).GetString(); string type = rule.GetProperty(nameof(type)).GetString(); string field = rule.GetProperty(nameof(field)).GetString(); JsonElement value = rule.GetProperty(nameof(value)); var property = Expression.Property(parm, field);

    首先,我們得到運算符(in)、類型(string)、字段(Category)和值(一個以Clothing為唯一元素的數組)。注意對 Expression.Property 的調用。這個規(guī)則的 LINQ 看起來是這樣的:

    var filter = new List<string> { "Clothing" }; Transactions.Where(t => filter.Contains(t.Category));

    該屬性是 t.Category,所以我們根據父屬性(t)和字段名來創(chuàng)建它。

    8常量和調用表達式

    接下來,我們需要建立對 Contains 的調用。為了簡化,我在這里創(chuàng)建了一個對該方法的引用:

    private?readonly MethodInfo MethodContains = typeof(Enumerable).GetMethods(BindingFlags.Static | BindingFlags.Public).Single(m => m.Name == nameof(Enumerable.Contains)&& m.GetParameters().Length == 2);

    這就動態(tài)提取了 Enumerable 的 Contains 方法,該方法需要兩個參數:要使用的集合和要檢查的值。接下來的邏輯看起來像這樣:

    if (@operator == In) {var contains = MethodContains.MakeGenericMethod(typeof(string));object val = value.EnumerateArray().Select(e => e.GetString()).ToList();var right = Expression.Call(contains,Expression.Constant(val),property);left = bind(left, right); }

    首先,我們使用 Enumerable.Contains 模板來創(chuàng)建一個 Enumerable<string>。接下來,我們獲取值的列表,把它變成一個 List<string>。最后,建立我們的調用,需要傳遞:

    • 要調用的方法(contains)

    • 要檢查的參數的值(帶有 Clothing 的列表,或者 Expression.Constant(val))

    • 要對其進行檢查的屬性(t.Category)。

    我們的表達式樹已經相當深了,有參數、屬性、調用和常量。記住,left 仍然是空的,所以對 bind 的調用只是將 left 設置為我們剛剛創(chuàng)建的調用表達式。到目前為止,看起來像這樣:

    Transactions.Where(t => (new List<string> { "Clothing" }).Contains(t.Category));

    循環(huán)往復,下一個規(guī)則是一個嵌套條件。關鍵代碼如下:

    if (rule.TryGetProperty(nameof(condition), out JsonElement check)) {var right = ParseTree<T>(rule, parm);left = bind(left, right);continue; }

    目前,left 被分配給 in 表達式。right 將被分配為解析新條件的結果。現在,我們的 binder 被設置為 Expression.And,所以當函數返回時,bind 的調用結果是這樣的:

    Transactions.Where(t => (new List<string> { "Clothing" }).Contains(t.Category) && <something>);

    我們再來看看這里的“something”。

    9比較表達式

    首先,遞歸調用確定了一個新的條件存在,這次是一個邏輯 OR。binder 被設置為 Expression.Or,規(guī)則開始運算。第一條規(guī)則是關于 TransactionType 的。它被設置為布爾值,但根據我的推斷,它意味著用戶在界面中可以選擇一個值或切換到另一個值。因此,我把它實現為一個簡單的字符串比較。下面是建立比較的代碼:

    object val = (type == StringStr || type == BooleanStr) ?(object)value.GetString() : value.GetDecimal(); var toCompare = Expression.Constant(val); var right = Expression.Equal(property, toCompare); left = bind(left, right);

    該值被解析為字符串或小數(后面的規(guī)則將使用小數格式)。然后,該值被轉換成一個常數,然后創(chuàng)建比較。注意它是通過屬性比較的。現在的變量看起來像這樣:

    Transactions.Where(t => t.TransactionType == "income");

    在這個嵌套循環(huán)中,left 仍然是空的。解析器計算了下一條規(guī)則,即 PaymentMode。bind 函數把它變成了這個“或”語句:

    Transactions.Where(t => t.TransactionType == "income" || t.PaymentMode == "Cash");

    其余的應該是不言自明的。表達式的一個很好的特點是它們可以重載 ToString() 來展現輸出。下面就是我們的表達式的樣子(為了方便查看,我手動進行了格式化):

    ((value(System.Collections.Generic.List`1[System.String]).Contains(Param_0.Category)And ((Param_0.TransactionType == "income")Or(Param_0.PaymentMode == "Cash")))And(Param_0.Amount == 10) )

    它看起來不錯......但我們還沒有完成!

    10Lambda 表達式和編譯

    接下來,我創(chuàng)建一個 lambda 表達式。這里定義了解析后的表達式的形狀,它將是一個謂詞(Func<T,bool>)。最后,返回編譯后的委托:

    var conditions = ParseTree<T>(doc.RootElement, itemExpression); if (conditions.CanReduce) {conditions = conditions.ReduceAndCheck(); } var query = Expression.Lambda<Func<T, bool>>(conditions, itemExpression); return query.Compile();

    為了測試,我生成了 1000 個 Transaction。然后我應用過濾器并迭代結果,這樣我就可以手動測試條件是否滿足:

    var predicate = jsonExpressionParser.ParsePredicateOf<Transaction>(jsonDocument); var transactionList = Transaction.GetList(1000); var filteredTransactions = transactionList.Where(predicate).ToList(); filteredTransactions.ForEach(Console.WriteLine);

    正如你所看到的,結果出來了(我平均每次運行約 70 次“命中”)。

    11從內存到數據庫

    生成的委托并不只是用于對象。我們也可以用它來訪問數據庫。

    在這篇文章的其余部分,將啟動項目設置為 DatabaseTest。如果你從命令行運行它,要確保 databaseRules.json 在你的當前目錄中。

    首先,我重構了代碼。還記得表達式是如何要求一個數據源的嗎?在前面的例子中,我們編譯了表達式,最后得到了一個對對象工作的委托。為了使用不同的數據源,我們需要在編譯表達式之前將其傳遞給它。這允許數據源對其進行編譯。如果我們傳遞已編譯的數據源,數據庫提供者將被迫從數據庫中獲取所有行,然后解析返回的列表。我們希望數據庫來做這些工作。我把大部分代碼移到一個名為 ParseExpressionOf<T> 的方法中,該方法返回 lambda。我把原來的方法重構成這樣:

    public?Func<T, bool> ParsePredicateOf<T>(JsonDocument doc) {var query = ParseExpressionOf<T>(doc);return query.Compile(); }

    ExpressionGenerator 程序使用編譯后的查詢,DatabaseTest 使用原始的 lambda 表達式。它將其應用于一個本地的 SQLite 數據庫,以演示 EF Core 是如何解析表達式的。在數據庫中創(chuàng)建并插入 1000 條 Transaction 后,通過下面代碼查詢總數:

    var count = await context.DbTransactions.CountAsync(); Console.WriteLine($"Verified insert count: {count}.");

    這會生成以下 SQL 語句:

    SELECT?COUNT(*) FROM "DbTransactions" AS "d"

    謂詞被解析(這次是來自 databaseRules.json 中的一組新規(guī)則)并傳遞給 Entity Framework Core 提供者。

    var parser = new JsonExpressionParser(); var predicate = parser.ParseExpressionOf<Transaction>(JsonDocument.Parse(await File.ReadAllTextAsync("databaseRules.json")));var query = context.DbTransactions.Where(predicate).OrderBy(t => t.Id);var results = await query.ToListAsync();

    打開 Entity Framework Core 日志記錄開關,我們能夠檢索到生成的 SQL,看到數據條目是如何被一次性獲取和在數據庫引擎中如何計算的。注意 PaymentMode 被檢查為“Credit”而不是“Cash”。

    SELECT "d"."Id", "d"."Amount", "d"."Category", "d"."PaymentMode", "d"."TransactionType" FROM "DbTransactions" AS "d" WHERE ("d"."Category" IN ('Clothing') &((("d"."TransactionType" = 'income') AND "d"."TransactionType" IS NOT NULL) |(("d"."PaymentMode" = 'Credit') AND "d"."PaymentMode" IS NOT NULL))) &("d"."Amount" = '10.0') ORDER BY "d"."Id"

    該示例應用程序還打印了一個實體,以進行抽查。

    12總結

    LINQ 表達式是一個非常強大的工具,可以過濾和轉換數據。我希望這個例子有助于理解表達式樹是如何構建的。當然,解析表達式樹感覺有點像魔術。Entity Framework Core 是如何在表達式樹上行走以產生有意義的 SQL?我正在自己探索這個問題,并得到了 ExpressionVisitor 類的幫助。我將陸續(xù)發(fā)表更多關于這個問題的文章。

    總結

    以上是生活随笔為你收集整理的深入LINQ | 动态构建LINQ表达式的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    国产精品无 | 在线精品在线 | 999国内精品永久免费视频 | 婷婷色网 | 国产精品视频免费看 | 天天天综合| 婷婷丁香色| 国产一区免费视频 | 久久久久久蜜av免费网站 | 久久久久在线观看 | 99精品一级欧美片免费播放 | 久久精品人人做人人综合老师 | 五月天中文字幕mv在线 | 成人久久免费 | 日韩精品免费一区二区在线观看 | 国产成人久久精品一区二区三区 | 久久久精品成人 | 欧美成人精品三级在线观看播放 | 日韩在线免费电影 | 热re99久久精品国产66热 | 在线观看深夜福利 | 91精品啪 | 国产精品永久免费 | 欧美性大胆 | 久久99热这里只有精品国产 | 国产日本三级 | 成人黄色在线观看视频 | 在线网址你懂得 | 亚洲免费一级电影 | 欧美性做爰猛烈叫床潮 | 免费福利片2019潦草影视午夜 | 日韩成人精品一区二区三区 | 午夜性色 | 色综合小说 | 久久99国产精品久久99 | 97国产大学生情侣白嫩酒店 | 亚洲激情p| 免费看的黄色网 | 亚洲成人av电影在线 | www黄| 日韩国产精品久久久久久亚洲 | 99久久久久久久久 | 日韩av手机在线观看 | 人人爽人人片 | 91精品在线免费观看视频 | 日韩av免费在线看 | 精品国产乱码久久久久 | 五月婷香蕉久色在线看 | 欧洲一区二区在线观看 | 国产一级免费片 | 99精品国产一区二区三区麻豆 | www黄在线 | 97福利视频| 国产一区网址 | av福利第一导航 | www.人人草 | 精品国产福利在线 | 日韩中文字幕在线看 | 欧美一级视频免费 | 久久精品7 | 九九视频免费在线观看 | 爱情影院aqdy鲁丝片二区 | 欧美日韩国产精品一区二区 | 亚洲综合欧美精品电影 | 五月婷婷六月丁香在线观看 | 中文字幕国产精品一区二区 | 国产欧美精品一区二区三区 | 日韩高清www | 一级黄色片毛片 | 久久综合婷婷综合 | 日韩欧美在线一区二区 | 最新国产精品久久精品 | 毛片a级片 | av成人在线观看 | 91中文字幕| 亚洲国产经典视频 | 国产精品99久久久久人中文网介绍 | 中文字幕在线观看完整版电影 | 天天射天天射 | 亚洲国产精品激情在线观看 | 在线亚洲观看 | 狠狠色丁婷婷日日 | 天天操天天干天天操天天干 | 91手机视频 | 在线观看日韩免费视频 | 91视频 - x99av | 日本女人的性生活视频 | 天天av天天| 欧美日韩国产色综合一二三四 | www视频在线观看 | 免费高清在线观看成人 | 国产一级特黄毛片在线毛片 | 麻豆91网站 | 天天天天天天天天操 | 欧美视频日韩 | 黄色毛片电影 | www.夜色321.com | 日韩欧美精品一区二区 | 亚洲精品在线观 | 中文字幕在线看视频国产中文版 | av在线播放亚洲 | 欧美日韩不卡在线视频 | 国产精品一区二区久久国产 | 亚洲国产成人精品在线 | 最新国产精品久久精品 | 免费av网址在线观看 | 91网站观看 | 久久艹在线 | 麻豆91精品91久久久 | 亚洲欧美成人综合 | 97超碰资源总站 | 在线观看香蕉视频 | 天天久久夜夜 | 美女国产| 激情久久五月 | 久久伊人八月婷婷综合激情 | 免费在线观看不卡av | 色91av| 免费观看黄色12片一级视频 | 毛片美女网站 | 国产精品午夜免费福利视频 | 蜜臀一区二区三区精品免费视频 | 日韩av一区在线观看 | 在线看日韩av | 超碰97国产在线 | 美女网站免费福利视频 | 91大神精品视频 | 色在线中文字幕 | 国产剧情av在线播放 | 亚洲日本va午夜在线电影 | 五月天综合网 | 国产视频中文字幕 | 久久久久国产精品免费免费搜索 | 国产91精品一区二区麻豆网站 | 久久国产精品视频免费看 | 中日韩欧美精彩视频 | 在线最新av | 国产成人一区在线 | 国产在线观看中文字幕 | 操久在线 | 亚洲国产成人在线 | av片在线观看免费 | 婷婷综合激情 | 超碰在线日韩 | 国内精品久久久久影院一蜜桃 | 日韩一区二区久久 | 成人性生交大片免费观看网站 | av网站在线观看免费 | 成人av影视在线 | 免费成人在线观看视频 | 西西人体4444www高清视频 | 久久久2o19精品 | 九九九视频精品 | 国产色秀视频 | 成人av在线直播 | 久久久久9999亚洲精品 | 日韩精品一区二区在线观看视频 | 亚洲精品动漫成人3d无尽在线 | 色网站中文字幕 | 国内精品美女在线观看 | 久久看免费视频 | 国产午夜精品一区二区三区欧美 | 久久精品99国产精品亚洲最刺激 | 国产专区免费 | 亚洲狠狠丁香婷婷综合久久久 | 亚洲精区二区三区四区麻豆 | 国产精品情侣视频 | 中文字幕 在线 一 二 | 久久国产精品99久久久久久进口 | 久久99精品一区二区三区三区 | 91精品影视| 麻花传媒mv免费观看 | 亚洲精品国产日韩 | 1000部国产精品成人观看 | 久草视频一区 | 欧美福利视频一区 | 国产色视频网站2 | 日韩中文久久 | 国产精品日韩精品 | 亚洲婷婷综合色高清在线 | 婷婷综合亚洲 | 国模精品一区二区三区 | 香蕉影视在线观看 | 婷婷丁香自拍 | 亚洲日本精品视频 | 狠狠狠的干 | 天天干天天操天天做 | 中文字幕在线观看的网站 | 麻豆视频观看 | 欧美在线视频第一页 | 国产精品黄色影片导航在线观看 | 91人人澡人人爽人人精品 | 久久综合狠狠综合 | 高清av免费看 | 欧美精品v国产精品v日韩精品 | 中文在线字幕免费观看 | 日日插日日干 | 婷婷激情综合网 | 免费看一级特黄a大片 | 91香蕉久久 | 欧美极品xxx | 中文字幕国产一区二区 | 超碰97在线人人 | 久草视频观看 | 国产一区二区免费看 | 国产伦精品一区二区三区在线 | 日韩精品久久一区二区三区 | 韩国av免费观看 | 国产精品一区二区三区久久 | 91网在线看| 2019天天干天天色 | 婷婷丁香狠狠爱 | 免费看av片网站 | 激情婷婷av| 久久丁香| 久久综合精品国产一区二区三区 | 91天堂影院 | 久久久99精品免费观看app | 蜜臀久久99精品久久久无需会员 | 国产精品久久久久久久久久尿 | 国产在线最新 | 中文在线8资源库 | 久久高清毛片 | 国产xxxx性hd极品 | 欧美精品在线免费 | 成人a视频在线观看 | 免费在线国产视频 | 天天综合视频在线观看 | av在线免费播放网站 | 91精品一区国产高清在线gif | 国产成人精品一区二区三区在线 | 在线观看视频色 | 国产三级国产精品国产专区50 | 黄色三级视频片 | 在线性视频日韩欧美 | 日韩久久久久久久久久 | 91亚洲激情 | 日韩免费视频观看 | 成人动漫精品一区二区 | 国产精品久久伊人 | 日韩乱码中文字幕 | 一区二区三区四区不卡 | 国产免费又粗又猛又爽 | 婷婷久久一区二区三区 | 韩国av免费 | 亚洲综合视频在线播放 | 国产黄色一级大片 | 国产精品一区二区 91 | 国产亚洲精品久久久久久无几年桃 | 四川妇女搡bbbb搡bbbb搡 | 日韩高清精品免费观看 | 日韩免费在线观看 | 日韩黄色一级电影 | 久久久久成人免费 | 中文字幕av一区二区三区四区 | 久久精品一区二区三区中文字幕 | 国产精品女人久久久 | 国外av在线| 精品一二三四五区 | 99久久国产免费看 | 国产视频精选 | 2019精品手机国产品在线 | 综合久久影院 | 日韩专区 在线 | 91麻豆精品国产91久久久无需广告 | 成人av网站在线观看 | 99国产精品久久久久久久久久 | 欧美作爱视频 | 中文字幕在线视频网站 | 精品播放 | 亚洲精品成人av在线 | 亚洲人成人天堂h久久 | 久草在线观 | 国产成在线观看免费视频 | 99视频精品全部免费 在线 | 日本xxxx.com | 久久精品首页 | 日本h在线播放 | 欧美日韩高清一区二区 国产亚洲免费看 | 久久精品91久久久久久再现 | 欧美日在线 | 久久99久久精品 | 亚洲在线黄色 | 亚洲精品乱码久久久一二三 | av理论电影| 精品一区二区三区电影 | av免费观看网址 | 九色91av| 亚洲伦理一区 | 91桃色在线免费观看 | 精品美女久久 | 在线观看91精品国产网站 | 婷婷激情5月天 | av免费在线看网站 | av黄色成人 | 91亚洲精品久久久蜜桃网站 | 天堂av在线7 | www.久久免费视频 | 精品福利国产 | 日韩精品极品视频 | 国产91九色蝌蚪 | 女人魂免费观看 | 国产一区在线视频播放 | 中文字幕在线网址 | 午夜视频免费播放 | 免费看短 | 久久影院精品 | 久久99久久精品 | 99久精品视频 | 91激情在线视频 | 久久字幕网| 亚洲一区av| 视频在线观看一区 | 精品福利av| 最近2019年日本中文免费字幕 | 国产精品久久久久久久久久了 | 99999精品 | 婷婷久月 | 射射射综合网 | 国产99久久久精品视频 | 色999在线 | 久久成年人网站 | 国产成人精品女人久久久 | 国产精品黄色av | 久久精美视频 | 日韩一二区在线观看 | 久久91久久久久麻豆精品 | 久久精品美女视频网站 | 岛国av在线 | 五月开心网 | 9在线观看免费 | 久久免费一级片 | 四虎影院在线观看av | 热久久99这里有精品 | 精品国产区 | 国产在线999 | 成人亚洲欧美 | 亚洲成人网在线 | 日韩视频免费观看高清完整版在线 | 青春草视频 | 视频在线99 | 色综合久久久久网 | www.国产在线 | 成年人视频在线免费观看 | 午夜在线观看影院 | 日本特黄特色aaa大片免费 | 日韩免费视频线观看 | 最近中文字幕完整高清 | 最近中文字幕大全 | 在线播放国产一区二区三区 | 亚洲春色奇米影视 | 国产最顶级的黄色片在线免费观看 | 日韩免费区| 日韩高清网站 | 欧美一区中文字幕 | 日日夜夜操av | 久久久久99精品国产片 | 久久综合精品国产一区二区三区 | 久章草在线 | 久久一区二区免费视频 | 国产91aaa| 又大又硬又黄又爽视频在线观看 | 在线精品视频免费播放 | 日韩久久精品一区二区三区下载 | 91最新在线观看 | 五月婷婷在线视频观看 | 97色婷婷人人爽人人 | 亚洲国产成人av网 | 国产精品久久久久av免费 | 精品国产电影 | 97在线精品国自产拍中文 | 亚洲国产中文在线观看 | 国产高h视频 | 精品免费久久久久 | 超碰在线1 | 视频在线99re| 亚洲激情综合网 | 91传媒在线播放 | 中文字幕一区二区在线播放 | 免费在线观看av不卡 | 美女精品| 中文字幕色婷婷在线视频 | 国产视频观看 | 欧美人zozo | 97综合视频| 欧美精品久久人人躁人人爽 | 国产精品久久久久久一二三四五 | 午夜av免费在线观看 | 96国产在线| 国产精品不卡在线播放 | 国产中文字幕在线观看 | 激情视频免费在线 | 国产97在线视频 | 99草视频在线观看 | 欧美综合色 | 天天操夜操视频 | 天天操天天射天天操 | 国产综合在线观看视频 | 日韩一区二区三区不卡 | 色天天综合久久久久综合片 | 99视频国产精品 | 天天爱天天射天天干天天 | 亚洲精品美女视频 | 亚洲精品国产综合久久 | 欧美成人按摩 | 久久国产精品二国产精品中国洋人 | 狠狠久久综合 | 亚洲黄色软件 | 黄色精品一区 | 国产精品美女免费 | 久草在线资源免费 | 欧美久久久久久久久久久久久 | 91成人精品国产刺激国语对白 | 亚洲 欧洲 国产 精品 | 黄色在线成人 | 韩日电影在线 | 亚洲一级免费电影 | 免费看成人a | 国产精品亚洲综合久久 | 国模一二三区 | 人人艹人人 | 国产精品久久久久一区二区国产 | 黄色片视频在线观看 | 国产婷婷一区二区 | 久久久国产在线视频 | 1000部18岁以下禁看视频 | 999视频在线播放 | 日韩欧美精品免费 | 黄a网站 | 九九爱免费视频在线观看 | 国产69精品久久app免费版 | 日日夜夜天天射 | 欧美日韩xxx | 亚洲少妇自拍 | 久久私人影院 | 免费人人干 | 97人人人人 | 亚洲综合婷婷 | 色婷婷综合久久久久 | 麻花豆传媒mv在线观看网站 | 日韩在线电影 | 欧美一级免费高清 | 一级a毛片高清视频 | 日韩电影久久久 | 日韩高清在线一区二区三区 | 亚洲成年人免费网站 | 亚洲精品视频网站在线观看 | 亚洲一级免费电影 | 色小说在线 | 日日夜夜精品免费 | 欧美成人黄 | 国产人成精品一区二区三 | 国产三级国产精品国产专区50 | av色影院| 在线观看一级片 | 99国产精品一区 | 日韩午夜一级片 | 毛片在线网 | 最新国产视频 | 色插综合 | 伊人激情网 | 国产亚洲观看 | 天天色图 | 在线观看第一页 | 97综合在线 | 91麻豆精品国产91久久久久久 | 日韩久久精品一区二区 | 成年人网站免费观看 | 天天射天天干天天 | 国产热re99久久6国产精品 | 国产成人精品999在线观看 | 2022久久国产露脸精品国产 | 免费观看9x视频网站在线观看 | 波多野结衣在线观看一区二区三区 | 久久好看免费视频 | 91免费高清观看 | 2018精品视频| 日p在线观看 | 久久精品中文字幕少妇 | 色网站在线观看 | av中文天堂在线 | 国产欧美中文字幕 | 国产精品第一页在线 | 色99久久 | av资源免费在线观看 | 综合国产视频 | 欧洲在线免费视频 | 免费a视频| 97福利在线观看 | 视频在线99 | 日日爽夜夜操 | 欧美激情h | 久久精品79国产精品 | 久久精品99视频 | 在线中文字幕一区二区 | 日本精品视频一区 | 日韩在线观看的 | 97电影院在线观看 | 91视频免费播放 | 久久精品综合网 | 成人精品一区二区三区中文字幕 | 久久这里只有精品视频首页 | 97色婷婷 | 天天爱天天草 | 又黄又爽又刺激的视频 | 欧美精品中文 | 天天操天天干天天操天天干 | 国产精品videossex国产高清 | 涩涩网站在线观看 | 在线精品一区二区 | 国产精品免费看久久久8精臀av | 天天综合久久综合 | 久久久久久毛片精品免费不卡 | 五月天亚洲激情 | 久久九九九九 | 国产片免费在线观看视频 | 精品一区二区三区在线播放 | 91精品婷婷国产综合久久蝌蚪 | 中文字幕精品三级久久久 | 高清中文字幕av | 夜夜操综合网 | 国产精品久久99综合免费观看尤物 | 又黄又爽又无遮挡的视频 | 欧美日韩午夜爽爽 | 久久久久亚洲精品国产 | 免费一级毛毛片 | x99av成人免费| 国产视频在线一区二区 | 91男人影院 | 激情亚洲综合在线 | 亚洲日本韩国一区二区 | 欧美人交a欧美精品 | 亚洲a成人v | 国产精品中文久久久久久久 | 91精品国产九九九久久久亚洲 | 亚洲午夜久久久久久久久 | 五月天久久综合网 | 午夜精品99久久免费 | 欧美精品中文字幕亚洲专区 | 亚洲欧美日韩中文在线 | 日韩视 | 综合精品在线 | 一级黄色片在线观看 | 在线观看激情av | 超碰97在线资源站 | 日韩高清在线一区二区三区 | 91亚洲精品久久久蜜桃 | 91精品国产自产在线观看永久 | 国产区精品视频 | 激情综合网色播五月 | 91九色蝌蚪视频在线 | 亚洲视频,欧洲视频 | 亚洲国产人午在线一二区 | 日韩免费二区 | 亚洲欧美怡红院 | 国产五月天婷婷 | 麻豆影视在线播放 | 成人影视免费 | 丁香花中文在线免费观看 | 精品美女久久久久久免费 | 国产一区在线播放 | 久久精品国产亚洲 | 亚洲2019精品| 日韩av一区二区三区四区 | 欧美日韩中文字幕在线视频 | 在线观看91精品视频 | 丰满少妇高潮在线观看 | 色开心| 日韩精品在线观看视频 | 欧美男男激情videos | 日本中文字幕在线视频 | 四虎8848免费高清在线观看 | 日本二区三区在线 | 国产精品入口麻豆 | 久久这里有| 中文字幕在线观看免费 | 日本精品久久久久中文字幕5 | jizz999| 激情婷婷综合网 | 中文字幕在线看 | 91视频3p| 欧美激情第八页 | 91片黄在线观看动漫 | 99这里只有精品99 | 亚洲精品视频网 | 在线观看免费 | 在线成人小视频 | 久黄色 | 久久高清国产 | 伊人导航| 精品国产一区二区三区日日嗨 | 国产高清久久久久 | 日韩精品无 | 国产精品情侣视频 | 国内精品久久久久久久97牛牛 | 欧美一级片免费 | 日韩欧美精品在线 | 日日夜夜精品免费观看 | 久草在线免费资源站 | 99爱精品在线 | 亚洲成人av在线电影 | 日韩在线播放欧美字幕 | 九九亚洲精品 | 日韩精品免费在线播放 | 亚州国产精品视频 | 337p西西人体大胆瓣开下部 | 欧美一区在线观看视频 | 91视频首页 | 久久深夜福利免费观看 | 999视频在线观看 | 亚洲一级黄色av | av视屏在线播放 | 亚洲va韩国va欧美va精四季 | 狠狠干电影 | 亚洲综合欧美日韩狠狠色 | 国产一级性生活视频 | 91最新国产 | 激情导航 | 91av视频在线播放 | 日韩亚洲精品电影 | av在线网站大全 | 亚洲精品久久久久久久蜜桃 | 男女激情网址 | 久久一本综合 | 十八岁以下禁止观看的1000个网站 | 久久精品一级片 | 在线观看韩国av | 日韩特黄av | 国产xxxxx在线观看 | 激情婷婷亚洲 | 久久精品这里热有精品 | 91av在线免费观看 | 国产一级精品在线观看 | 久久久午夜精品理论片中文字幕 | 亚洲免费一级 | 亚洲成人精品 | a级片在线播放 | 精品爱爱| 成人在线播放视频 | 日日夜夜免费精品 | 欧美日韩另类视频 | 色婷婷狠狠五月综合天色拍 | 欧美91片 | 中文字幕 成人 | 深夜免费福利网站 | 色婷婷啪啪免费在线电影观看 | 国产精品大片免费观看 | 久久久九色精品国产一区二区三区 | 国产在线观看你懂得 | 欧美精品久久久久久久免费 | av在线网站大全 | 亚洲aⅴ久久精品 | 欧美激情视频在线观看免费 | 日韩美女久久 | 人人爽人人爽人人爽 | 久久精品4 | 精品视频免费看 | 欧美精品免费在线 | 日本mv大片欧洲mv大片 | 亚洲理论视频 | 超碰99人人 | 97在线观看免费高清 | 天天操夜夜想 | 久久久这里有精品 | 黄色毛片在线观看 | 国产精品视频线看 | 天天操天天操天天操天天 | 国产精品自产拍在线观看桃花 | 欧美精品久久久久久久久老牛影院 | 欧美日韩视频精品 | 在线观看一区二区精品 | 国产午夜免费视频 | 国产精品久久久久久久久免费看 | www.97视频| 麻豆久久久 | 中文字幕在线视频网站 | 丁香六月欧美 | 欧洲一区二区三区精品 | 久久999久久 | 国产精品久久久久久久久久久久午夜 | 免费久久久久久久 | 免费av小说 | 99爱精品视频 | 日韩av进入 | 丝袜精品视频 | 午夜影视一区 | 久久综合网色—综合色88 | 久久这里有 | 97视频免费播放 | 黄色特一级 | 色婷婷国产精品一区在线观看 | 国产不卡在线播放 | 色资源二区在线视频 | 国产黄色片网站 | 天天插天天干天天操 | 天天操天天干天天干 | 婷婷久久久 | 婷婷色 亚洲| 欧亚日韩精品一区二区在线 | 69热国产视频 | 欧美一级xxxx| 91c网站色版视频 | 在线观看国产区 | 国产成人黄色av | 中文av不卡 | 欧美一区二区三区在线视频观看 | 中文字幕九九 | 国产一区在线免费 | 成人xxxx| 一区二区三区电影 | 91精品对白一区国产伦 | 午夜美女wwww| 亚洲黄网站| 二区视频在线观看 | 91香蕉视频在线下载 | 天天干婷婷 | 天天干天天做天天操 | 成人小视频在线观看免费 | 国产在线精品福利 | 日韩欧美一区二区在线观看 | 欧美中文字幕第一页 | 婷婷伊人综合亚洲综合网 | 久久国产精品一区二区 | 成人一区电影 | 日日精品 | 91在线观看高清 | 亚洲一级在线观看 | 爱情影院aqdy鲁丝片二区 | 国产成人av免费在线观看 | 黄色软件在线看 | 久久美女免费视频 | 99久久国产免费免费 | 国产黄色大片免费看 | 日本三级人妇 | 国产色a在线观看 | 青草视频免费观看 | 久久免费看 | 中文久久精品 | 狠狠操操网 | 五月开心激情网 | 亚洲精品免费在线视频 | 国产亚洲成人精品 | 麻豆国产视频下载 | 草久草久 | 国产一区二区三区免费在线观看 | 国产精品久久久久久久久久新婚 | 色天天中文 | 狠狠色丁香婷婷 | 亚洲资源| 99热 精品在线 | 日韩综合一区二区三区 | 久久久久国产成人免费精品免费 | 日韩av中文 | 国产香蕉av| 国内精品久久久久久久久久久 | 欧美在线观看视频一区二区三区 | 婷婷久草 | 精品久久久久久国产偷窥 | 成人一级黄色片 | 久久精品超碰 | 在线影院中文字幕 | 国产又粗又猛又黄又爽的视频 | 五月开心六月伊人色婷婷 | 欧美性做爰猛烈叫床潮 | 精品免费观看视频 | 色99导航 | www国产亚洲| 日韩中字在线 | 免费的国产精品 | 在线免费观看麻豆视频 | 粉嫩av一区二区三区四区 | 成人午夜电影在线播放 | 欧美福利精品 | 韩日电影在线观看 | 精品亚洲午夜久久久久91 | 国产黄免费 | 中文字幕中文字幕在线一区 | av电影一区二区三区 | 美女黄濒 | 亚洲天天做 | 99精品国产免费久久 | 伊人天天色 | 欧美日韩精品网站 | 国产女人18毛片水真多18精品 | 97热视频 | 亚洲精品久久久久久中文传媒 | 欧美精品久久久久久久久久丰满 | 99久久婷婷国产 | 日韩高清在线看 | 国产一二三在线视频 | 99国产免费网址 | 亚洲三级在线播放 | 国产在线97 | 久碰视频在线观看 | 国产黄色大片 | 久久久久久久久久久高潮一区二区 | 国产精品久久久久久久久久99 | 在线观看一级视频 | 国产高清在线免费观看 | 日本女人的性生活视频 | 亚洲一级黄色片 | 免费aa大片 | 国产精品原创在线 | 天天操天天干天天综合网 | 久久久999精品视频 国产美女免费观看 | 中文字幕色在线视频 | av成人免费在线 | 日韩有码在线观看视频 | 91九色蝌蚪视频 | 久久三级视频 | 亚洲一级特黄 | 黄色小说视频在线 | 91大神免费在线观看 | 在线影视 一区 二区 三区 | 日韩精品 在线视频 | 黄免费在线观看 | 少妇性色午夜淫片aaaze | 中文字幕二区三区 | 91成人精品视频 | 麻豆成人精品视频 | 99视频精品免费观看, | 亚洲精品国产自产拍在线观看 | 狠狠88综合久久久久综合网 | 日韩av在线高清 | 2024国产精品视频 | 激情网在线视频 | 日韩视频中文字幕在线观看 | 国产1区在线观看 | 亚洲国产精品激情在线观看 | 黄色精品一区 | 99精品在线 | 美女免费视频观看网站 | 日韩毛片一区 | 国产精品乱码在线 | 久久亚洲婷婷 | 日韩精品极品视频 | 天天弄天天操 | 亚洲精品视频在线 | 久久精品九色 | 91精品网站在线观看 | 国产在线国产 | 国产精品网站一区二区三区 | 成年人毛片在线观看 | 成人资源在线播放 | 久热免费在线 | 色噜噜日韩精品欧美一区二区 | 麻豆一精品传二传媒短视频 | 日日夜夜精品免费 | 4438全国亚洲精品观看视频 | 视频91| 久久国产经典视频 | 成人a大片 | 久久国产成人午夜av影院潦草 | 亚洲人在线7777777精品 | 色婷婷免费视频 | 激情五月婷婷激情 | 日韩免费视频一区二区 | 欧美午夜理伦三级在线观看 | 久久精品视频网站 | 91av播放 | 亚洲动漫在线观看 | 国产免费小视频 | 91精品久久香蕉国产线看观看 | 91精品国产电影 | 经典三级一区 | 免费av片在线 | 日韩一级网站 | 在线播放你懂 | 久久久久久久久精 | 久久久电影 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 91高清视频在线 | 天天草天天干天天射 | 五月激情电影 | 中文字幕免费观看视频 | a黄在线观看 | 中文字幕丝袜美腿 | 国产精品高清免费在线观看 | 国内三级在线观看 | 免费观看一区 | 在线观看一区二区视频 | 综合网成人 | 亚洲精品videossex少妇 | 日本久久久精品视频 | 四季av综合网站 | 狠狠干,狠狠操 | 久热免费在线观看 | 免费观看视频黄 | 欧美精品999 | 久久电影色| 天天爱av导航 | 视频91| av免费观看高清 | 欧美色图另类 | 操一草| 99国产精品久久久久久久久久 | av免费看在线 | 亚洲最大av | 亚洲 欧美 另类人妖 | 九九九毛片 | 精品国产一区二区三区在线观看 | 亚洲视频久久久久 | 久久久国产精品人人片99精片欧美一 | 国产色爽 | 国产一级二级三级在线观看 | 免费成人在线观看视频 | 久久99网站| 亚洲免费在线 | 天天插天天狠天天透 | 欧美日韩精品在线观看视频 | 日本美女xx | 日本黄色大片免费 | 91免费黄视频 | 日女人电影 | 国产在线观看你懂得 | 亚洲综合成人在线 | 日韩黄视频 | 97色在线视频 | 亚洲综合网站在线观看 | 一区二区三区电影在线播 | 精品在线一区二区 | 欧美精品一区二区免费 | 欧美最猛性xxxxx(亚洲精品) | 亚洲欧美日韩国产一区二区三区 | 国产精品久久久久久久久久久久午夜 | 2018好看的中文在线观看 | 九九视频一区 | 麻豆 free xxxx movies hd | 久草在线看片 | av女优中文字幕在线观看 | 99热高清| 国产免费激情久久 | 国产专区在线看 | 日韩毛片在线播放 | 国产一级一级国产 | 国产区在线看 | 曰本免费av | 99欧美视频 | 伊人五月天.com | 久久精品国产免费 | 国产精品一区二区三区在线播放 | 五月天亚洲综合小说网 | 国产成人免费观看久久久 | 人人添人人 | 偷拍精偷拍精品欧洲亚洲网站 | 日本午夜在线观看 | av观看免费在线 | 中文字幕第 | 日韩av免费观看网站 | 国产一区久久久 | 欧美日韩高清一区二区 | 色综合久久精品 | 亚洲精品美女久久久 | 成人免费看片网址 | 99精品欧美一区二区 | 91经典在线| 在线观看视频精品 | 国产精品一区二区三区久久 | 91看片看淫黄大片 | 在线国产日韩 | 日韩黄色免费 | 日韩免费电影一区二区 | 色在线视频网 | 中文字幕亚洲欧美日韩2019 | 中文字幕一区二区在线观看 | 国产精品免费在线 | 色狠狠一区二区 | 国产成人av一区二区三区在线观看 | 欧美精品成人在线 | 国产日韩欧美综合在线 | 久久激情小说 | 伊人黄| www.亚洲视频.com | 麻豆传媒在线免费看 | 成人一级片在线观看 | 久久人人爽爽 | 成人免费在线播放视频 | 精品国产aⅴ麻豆 | 成人毛片一区 | 亚洲精品婷婷 | 97在线视频观看 | 亚洲精品美女视频 | 亚洲国产无 | 国产大尺度视频 | 国产精品第2页 | 天天天在线综合网 | 国产精品刺激对白麻豆99 | 国产精品女同一区二区三区久久夜 | 亚洲午夜av久久乱码 | 婷婷成人亚洲综合国产xv88 | 久久免费国产视频 | 免费高清在线一区 | 很黄很黄的网站免费的 | 久久成人欧美 | 欧美另类v | 久久免费精彩视频 | 久久久久久久久久久影视 | 欧美日韩二区在线 |