国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

SQL Server 數(shù)據(jù)太多優(yōu)化的方法

 更新時(shí)間:2024年11月09日 09:45:46   作者:威哥愛編程  
本文介紹了幾種優(yōu)化SQLServer數(shù)據(jù)庫性能的方法,包括索引優(yōu)化、數(shù)據(jù)分區(qū)和分表、數(shù)據(jù)歸檔、存儲(chǔ)和硬件優(yōu)化、數(shù)據(jù)庫參數(shù)和配置優(yōu)化、批量數(shù)據(jù)處理、清理無用數(shù)據(jù)、使用緩存、并行查詢與并發(fā)以及SQLServer實(shí)例優(yōu)化,這些方法可以幫助在處理大量數(shù)據(jù)時(shí)保持較好的性能

在 SQL Server 中,當(dāng)數(shù)據(jù)量增大時(shí),數(shù)據(jù)庫的性能可能會(huì)受到影響,導(dǎo)致查詢速度變慢、響應(yīng)時(shí)間變長(zhǎng)等問題。為了應(yīng)對(duì)大量數(shù)據(jù),以下是一些常用的優(yōu)化策略和案例詳解,寫著寫著又上1萬5了,原創(chuàng)不易,先贊后看,養(yǎng)好習(xí)慣:

1. 索引優(yōu)化

  • 創(chuàng)建索引:索引可以顯著提高查詢速度,特別是在使用 WHEREJOIN 和 ORDER BY 子句時(shí)。為常用的查詢字段(尤其是篩選條件字段)創(chuàng)建合適的索引。
  • 選擇合適的索引類型:使用聚集索引(Clustered Index)和非聚集索引(Non-clustered Index)來優(yōu)化查詢性能。聚集索引適用于排序、范圍查詢等,而非聚集索引適用于單一列或組合列的查詢。
  • 避免過多索引:雖然索引能提高查詢性能,但過多的索引會(huì)增加更新、插入和刪除操作的成本,因此要平衡索引的數(shù)量和性能。

在 SQL Server 中,索引優(yōu)化是提高查詢性能的重要手段。以下是一個(gè)具體的業(yè)務(wù)場(chǎng)景,假設(shè)我們有一個(gè)銷售訂單系統(tǒng),訂單表 Orders 需要根據(jù)不同的查詢需求來進(jìn)行索引優(yōu)化。

業(yè)務(wù)場(chǎng)景

  • 查詢需求1:按 CustomerID 和 OrderDate 查詢訂單信息。
  • 查詢需求2:按 ProductID 查詢所有相關(guān)的訂單。
  • 查詢需求3:查詢某一訂單的詳細(xì)信息(通過 OrderID)。

基于這些需求,我們將為 Orders 表創(chuàng)建索引,并展示如何選擇合適的索引類型。

1. 創(chuàng)建表 Orders

CREATE TABLE Orders (
    OrderID INT PRIMARY KEY,         -- 主鍵索引,自動(dòng)創(chuàng)建聚集索引
    CustomerID INT,                  -- 客戶ID
    OrderDate DATETIME,              -- 訂單日期
    ProductID INT,                   -- 產(chǎn)品ID
    TotalAmount DECIMAL(18, 2),      -- 訂單總金額
    Status VARCHAR(20)               -- 訂單狀態(tài)
);

2. 創(chuàng)建索引

2.1. 創(chuàng)建聚集索引(Clustered Index)

聚集索引通常是基于主鍵或唯一約束創(chuàng)建的。它將數(shù)據(jù)按照索引順序存儲(chǔ),因此在 OrderID 上創(chuàng)建聚集索引能夠加速按 OrderID 查找的查詢。

-- OrderID 是主鍵,默認(rèn)會(huì)創(chuàng)建聚集索引
-- 所以在這種情況下不需要額外創(chuàng)建聚集索引

2.2. 創(chuàng)建非聚集索引(Non-clustered Index)

對(duì)于 CustomerID 和 OrderDate 組合字段的查詢需求,我們可以為其創(chuàng)建一個(gè)復(fù)合非聚集索引。這樣可以加速基于 CustomerID 和 OrderDate 的查詢。

CREATE NONCLUSTERED INDEX idx_Customer_OrderDate
ON Orders (CustomerID, OrderDate);
  • 使用場(chǎng)景:該索引有助于加速按 CustomerID 和 OrderDate 查詢的性能,特別是當(dāng)訂單數(shù)據(jù)量較大時(shí)。

2.3. 創(chuàng)建單列非聚集索引

對(duì)于查詢需求2,如果我們需要按 ProductID 查找所有相關(guān)訂單,我們可以為 ProductID 創(chuàng)建單列非聚集索引。這樣可以提高查詢效率。

CREATE NONCLUSTERED INDEX idx_ProductID
ON Orders (ProductID);
  • 使用場(chǎng)景:查詢某個(gè)產(chǎn)品相關(guān)的所有訂單時(shí),通過該索引可以顯著提高查詢性能。

3. 刪除冗余索引

如果發(fā)現(xiàn)某個(gè)查詢經(jīng)常訪問多個(gè)列,而我們?cè)谶@些列上創(chuàng)建了多個(gè)單列索引,可能會(huì)導(dǎo)致性能下降。比如,創(chuàng)建多個(gè)針對(duì)單列的非聚集索引,可能會(huì)降低插入和更新操作的效率。為了避免這種情況,可以定期檢查并刪除冗余的索引。

假設(shè)我們發(fā)現(xiàn) ProductID 和 CustomerID 常常一起出現(xiàn)在查詢條件中,我們可以考慮刪除 idx_ProductID 索引,改為創(chuàng)建一個(gè)組合索引。

-- 刪除冗余的單列索引
DROP INDEX idx_ProductID ON Orders;

4. 查詢優(yōu)化

現(xiàn)在,假設(shè)我們有以下幾個(gè)查詢,我們將展示如何利用創(chuàng)建的索引來優(yōu)化查詢性能。

4.1. 按 CustomerID 和 OrderDate 查詢

-- 使用 idx_Customer_OrderDate 索引
SELECT OrderID, ProductID, TotalAmount
FROM Orders
WHERE CustomerID = 1001 AND OrderDate BETWEEN '2024-01-01' AND '2024-12-31';

4.2. 按 ProductID 查詢

-- 使用 idx_ProductID 索引
SELECT OrderID, CustomerID, TotalAmount
FROM Orders
WHERE ProductID = 500;

4.3. 查詢特定訂單詳細(xì)信息

-- 按 OrderID 查詢,使用默認(rèn)的聚集索引
SELECT CustomerID, ProductID, TotalAmount, Status
FROM Orders
WHERE OrderID = 123456;

5. 注意事項(xiàng)

  • 索引的維護(hù)成本:雖然索引能顯著提高查詢性能,但每當(dāng)進(jìn)行 INSERTUPDATE 或 DELETE 操作時(shí),索引也需要維護(hù)。這會(huì)增加操作的成本。因此,索引不宜過多,需要根據(jù)查詢需求進(jìn)行優(yōu)化。
  • 索引覆蓋:盡量創(chuàng)建覆蓋索引,即索引包含查詢所需的所有列,這樣可以避免查詢時(shí)回表操作,提高查詢效率。

小結(jié)一下

通過為 Orders 表創(chuàng)建合適的索引,我們可以顯著優(yōu)化查詢性能。在索引優(yōu)化中,需要綜合考慮查詢需求、索引類型(聚集索引、非聚集索引)、索引的數(shù)量及其維護(hù)成本。

2. 查詢優(yōu)化

  • 優(yōu)化 SQL 查詢:確保 SQL 查詢盡量高效。避免在查詢中使用 SELECT *,而是只選擇需要的列;避免重復(fù)的計(jì)算,盡量減少子查詢。
  • 使用執(zhí)行計(jì)劃:利用 SQL Server Management Studio (SSMS) 的執(zhí)行計(jì)劃工具查看查詢的執(zhí)行計(jì)劃,分析和優(yōu)化查詢中的瓶頸部分。
  • 避免復(fù)雜的嵌套查詢:復(fù)雜的子查詢可能會(huì)導(dǎo)致性能問題,考慮使用連接(JOIN)來代替。

查詢優(yōu)化是通過精心設(shè)計(jì) SQL 查詢語句和優(yōu)化索引來提高查詢性能的過程。根據(jù)你提供的業(yè)務(wù)場(chǎng)景,我們將基于一個(gè)訂單系統(tǒng)的 Orders 表,展示幾種常見的查詢優(yōu)化方法。

業(yè)務(wù)場(chǎng)景

假設(shè)我們有一個(gè)銷售訂單系統(tǒng),Orders 表包括以下字段:

  • OrderID:訂單ID,主鍵。
  • CustomerID:客戶ID。
  • OrderDate:訂單日期。
  • ProductID:產(chǎn)品ID。
  • TotalAmount:訂單總金額。
  • Status:訂單狀態(tài)(如已支付、未支付等)。

我們有以下幾種查詢需求:

  • 查詢某個(gè)客戶在某段時(shí)間內(nèi)的所有訂單。
  • 查詢某個(gè)產(chǎn)品在所有訂單中的銷售情況。
  • 查詢某個(gè)訂單的詳細(xì)信息。
  • 查詢多個(gè)客戶的訂單信息。

1. 查詢優(yōu)化:按 CustomerID 和 OrderDate 查詢訂單

查詢需求:

查詢某個(gè)客戶在某段時(shí)間內(nèi)的所有訂單。

查詢語句:

SELECT OrderID, ProductID, TotalAmount, Status
FROM Orders
WHERE CustomerID = 1001
  AND OrderDate BETWEEN '2024-01-01' AND '2024-12-31';

優(yōu)化建議:

  • 索引優(yōu)化:為 CustomerID 和 OrderDate 創(chuàng)建復(fù)合索引,因?yàn)檫@是常見的查詢模式。復(fù)合索引可以加速基于這兩個(gè)字段的查詢。
CREATE NONCLUSTERED INDEX idx_Customer_OrderDate
ON Orders (CustomerID, OrderDate);

執(zhí)行計(jì)劃優(yōu)化:

  • 使用 EXPLAIN 或 SET STATISTICS IO ON 來查看執(zhí)行計(jì)劃,確認(rèn)查詢是否使用了索引。

2. 查詢優(yōu)化:按 ProductID 查詢所有相關(guān)訂單

查詢需求:

查詢某個(gè)產(chǎn)品的所有訂單。

查詢語句:

SELECT OrderID, CustomerID, TotalAmount, Status
FROM Orders
WHERE ProductID = 500;

優(yōu)化建議:

  • 索引優(yōu)化:為 ProductID 創(chuàng)建索引,因?yàn)檫@個(gè)字段經(jīng)常作為查詢條件。
CREATE NONCLUSTERED INDEX idx_ProductID
ON Orders (ProductID);

執(zhí)行計(jì)劃優(yōu)化:

  • 確保查詢能夠利用 idx_ProductID 索引,避免全表掃描。

3. 查詢優(yōu)化:查詢某個(gè)訂單的詳細(xì)信息

查詢需求:

查詢某個(gè)訂單的詳細(xì)信息。

查詢語句:

SELECT CustomerID, ProductID, TotalAmount, Status
FROM Orders
WHERE OrderID = 123456;

優(yōu)化建議:

  • 索引優(yōu)化:因?yàn)?nbsp;OrderID 是主鍵字段,SQL Server 會(huì)自動(dòng)創(chuàng)建聚集索引。查詢 OrderID 字段時(shí),查詢會(huì)直接利用聚集索引。
-- 聚集索引已自動(dòng)創(chuàng)建,無需額外創(chuàng)建

執(zhí)行計(jì)劃優(yōu)化:

  • 確保查詢只掃描一行數(shù)據(jù),利用 OrderID 主鍵索引。

4. 查詢優(yōu)化:查詢多個(gè)客戶的訂單信息

查詢需求:

查詢多個(gè)客戶的訂單信息。

查詢語句:

SELECT OrderID, CustomerID, ProductID, TotalAmount, Status
FROM Orders
WHERE CustomerID IN (1001, 1002, 1003);

優(yōu)化建議:

  • 索引優(yōu)化:為 CustomerID 創(chuàng)建索引,以便快速過濾出目標(biāo)客戶的訂單。
CREATE NONCLUSTERED INDEX idx_CustomerID
ON Orders (CustomerID);

執(zhí)行計(jì)劃優(yōu)化:

  • 確保 IN 子句使用了 idx_CustomerID 索引來優(yōu)化查詢。

5. 查詢優(yōu)化:避免使用 SELECT *

查詢需求:

查詢所有字段(不推薦,通常用來調(diào)試或檢查表結(jié)構(gòu))。

查詢語句:

SELECT * FROM Orders;

優(yōu)化建議:

  • 明確選擇需要的列:避免使用 SELECT *,明確列出查詢需要的字段,避免讀取不必要的列。
SELECT OrderID, CustomerID, TotalAmount FROM Orders;

6. 查詢優(yōu)化:使用 JOIN 進(jìn)行多表查詢

查詢需求:

查詢某個(gè)客戶的訂單信息以及相關(guān)的產(chǎn)品信息。假設(shè)有一個(gè) Products 表,包含 ProductID 和 ProductName

查詢語句:

SELECT o.OrderID, o.TotalAmount, p.ProductName
FROM Orders o
JOIN Products p ON o.ProductID = p.ProductID
WHERE o.CustomerID = 1001
  AND o.OrderDate BETWEEN '2024-01-01' AND '2024-12-31';

優(yōu)化建議:

  • 索引優(yōu)化:為 Orders 表的 CustomerID、OrderDate 和 ProductID 創(chuàng)建復(fù)合索引,為 Products 表的 ProductID 創(chuàng)建索引,以加速 JOIN 查詢。
CREATE NONCLUSTERED INDEX idx_Orders_Customer_OrderDate_Product
ON Orders (CustomerID, OrderDate, ProductID);
CREATE NONCLUSTERED INDEX idx_Products_ProductID
ON Products (ProductID);

執(zhí)行計(jì)劃優(yōu)化:

  • 確保執(zhí)行計(jì)劃中使用了 JOIN 的相關(guān)索引,避免全表掃描。

7. 查詢優(yōu)化:分頁查詢

查詢需求:

查詢某個(gè)時(shí)間段內(nèi)的客戶訂單,并實(shí)現(xiàn)分頁功能。

查詢語句:

SELECT OrderID, CustomerID, TotalAmount, Status
FROM Orders
WHERE OrderDate BETWEEN '2024-01-01' AND '2024-12-31'
ORDER BY OrderDate
OFFSET 0 ROWS FETCH NEXT 20 ROWS ONLY;

優(yōu)化建議:

  • 索引優(yōu)化:確保在 OrderDate 上有合適的索引,能夠加速排序操作。
  • 使用 OFFSET 和 FETCH 語句實(shí)現(xiàn)分頁查詢,避免一次性加載大量數(shù)據(jù)。
CREATE NONCLUSTERED INDEX idx_OrderDate
ON Orders (OrderDate);

8. 避免過多的子查詢

查詢需求:

查詢某個(gè)客戶在某段時(shí)間內(nèi)的訂單總金額。

查詢語句:

SELECT CustomerID, 
       (SELECT SUM(TotalAmount) FROM Orders WHERE CustomerID = 1001 AND OrderDate BETWEEN '2024-01-01' AND '2024-12-31') AS TotalSpent
FROM Customers
WHERE CustomerID = 1001;

優(yōu)化建議:

  • 避免使用子查詢:盡量避免在 SELECT 語句中使用子查詢,可以改為 JOIN 或 GROUP BY 來提高效率。
SELECT o.CustomerID, SUM(o.TotalAmount) AS TotalSpent
FROM Orders o
WHERE o.CustomerID = 1001
  AND o.OrderDate BETWEEN '2024-01-01' AND '2024-12-31'
GROUP BY o.CustomerID;

小結(jié)一下

通過優(yōu)化 SQL 查詢語句、合理使用索引以及減少不必要的操作,我們能夠顯著提高查詢性能。具體做法包括:

  • 創(chuàng)建合適的索引(單列索引和復(fù)合索引)。
  • 優(yōu)化查詢語句,避免使用 SELECT * 和過多的子查詢。
  • 使用合適的分頁技術(shù)和 JOIN 優(yōu)化多表查詢。
  • 分析查詢執(zhí)行計(jì)劃,確保查詢高效執(zhí)行。

這些優(yōu)化措施可以幫助 SQL Server 在面對(duì)大量數(shù)據(jù)時(shí)保持高效的查詢性能。

3. 數(shù)據(jù)分區(qū)和分表

  • 表分區(qū):對(duì)于非常大的表,可以考慮使用表分區(qū)。表分區(qū)可以根據(jù)某些條件(例如時(shí)間、ID 范圍等)將數(shù)據(jù)分割到多個(gè)物理文件中,這樣查詢時(shí)只訪問相關(guān)的分區(qū),減少了全表掃描的開銷。
  • 水平拆分(Sharding):將數(shù)據(jù)分散到多個(gè)獨(dú)立的表或數(shù)據(jù)庫中,通?;谀撤N規(guī)則(如區(qū)域、日期等)。每個(gè)表包含數(shù)據(jù)的一個(gè)子集,可以提高查詢效率。

數(shù)據(jù)分區(qū)(Partitioning)和分表(Sharding)是優(yōu)化數(shù)據(jù)庫性能的關(guān)鍵手段,尤其在處理大數(shù)據(jù)量時(shí)。通過數(shù)據(jù)分區(qū)或分表,可以有效地減少查詢和寫入的壓力,提高數(shù)據(jù)訪問效率。以下是基于業(yè)務(wù)場(chǎng)景的具體代碼案例,展示如何使用數(shù)據(jù)分區(qū)和分表來優(yōu)化 SQL Server 的性能。

業(yè)務(wù)場(chǎng)景

假設(shè)我們有一個(gè)訂單系統(tǒng),Orders 表記錄了所有訂單信息。隨著訂單量的增加,單表的查詢和維護(hù)變得越來越困難。因此,我們需要使用分區(qū)和分表技術(shù)來優(yōu)化數(shù)據(jù)庫的性能。

1. 數(shù)據(jù)分區(qū)(Partitioning)

數(shù)據(jù)分區(qū)是在單一表上進(jìn)行邏輯分區(qū),它允許將一個(gè)大的表按某個(gè)規(guī)則(如時(shí)間范圍、數(shù)值區(qū)間等)分成多個(gè)物理段(分區(qū))。每個(gè)分區(qū)可以獨(dú)立管理,查詢可以在特定的分區(qū)內(nèi)進(jìn)行,從而提高查詢性能。

業(yè)務(wù)需求

  • 按照訂單日期(OrderDate)將 Orders 表分區(qū),以便在查詢時(shí)快速定位到特定時(shí)間段內(nèi)的訂單。

步驟:

  • 創(chuàng)建分區(qū)函數(shù)(Partition Function)和分區(qū)方案(Partition Scheme)。
  • 在 Orders 表上應(yīng)用分區(qū)。

創(chuàng)建分區(qū)函數(shù)(Partition Function)

-- 創(chuàng)建分區(qū)函數(shù):按年度分區(qū)
CREATE PARTITION FUNCTION OrderDatePartitionFunc (DATE)
AS RANGE RIGHT FOR VALUES ('2023-01-01', '2024-01-01', '2025-01-01');

該分區(qū)函數(shù)將根據(jù)訂單日期(OrderDate)把數(shù)據(jù)分為多個(gè)區(qū)間,每個(gè)區(qū)間的范圍是按年劃分的。

創(chuàng)建分區(qū)方案(Partition Scheme)

-- 創(chuàng)建分區(qū)方案:將分區(qū)函數(shù)應(yīng)用到物理文件組
CREATE PARTITION SCHEME OrderDatePartitionScheme
AS PARTITION OrderDatePartitionFunc
TO ([PRIMARY], [FG_2023], [FG_2024], [FG_2025]);

此方案為每個(gè)分區(qū)指定一個(gè)物理文件組(如 PRIMARY、FG_2023 等)。

創(chuàng)建分區(qū)表

-- 創(chuàng)建分區(qū)表:應(yīng)用分區(qū)方案
CREATE TABLE Orders
(
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
)
ON OrderDatePartitionScheme (OrderDate);

Orders 表按 OrderDate 字段進(jìn)行分區(qū),數(shù)據(jù)會(huì)根據(jù)日期分布到不同的物理文件組中。

查詢優(yōu)化

-- 查詢 2024 年的訂單,查詢僅會(huì)訪問相應(yīng)的分區(qū),提高查詢效率
SELECT OrderID, CustomerID, ProductID, TotalAmount
FROM Orders
WHERE OrderDate BETWEEN '2024-01-01' AND '2024-12-31';

通過分區(qū),查詢只會(huì)掃描相關(guān)分區(qū)的數(shù)據(jù),從而提高查詢速度。

2. 數(shù)據(jù)分表(Sharding)

分表是將數(shù)據(jù)水平拆分到多個(gè)物理表中,每個(gè)表存儲(chǔ)一部分?jǐn)?shù)據(jù)。常見的分表策略包括按范圍分表、按哈希值分表等。分表可以顯著提升查詢性能,但需要管理多個(gè)表及其關(guān)系。

業(yè)務(wù)需求

  • 按 CustomerID 將 Orders 表進(jìn)行分表,客戶ID為基礎(chǔ)將數(shù)據(jù)分配到不同的表中。
  • 客戶ID的范圍是均勻的,因此我們可以使用哈希分表策略。

步驟:

  • 創(chuàng)建多個(gè)分表。
  • 在應(yīng)用層處理分表邏輯。

創(chuàng)建分表

假設(shè)我們決定將 Orders 表按 CustomerID 的哈希值分成 4 個(gè)表??梢酝ㄟ^以下方式創(chuàng)建 4 個(gè)分表:

-- 創(chuàng)建 Orders_1 分表
CREATE TABLE Orders_1
(
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
);
-- 創(chuàng)建 Orders_2 分表
CREATE TABLE Orders_2
(
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
);
-- 創(chuàng)建 Orders_3 分表
CREATE TABLE Orders_3
(
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
);
-- 創(chuàng)建 Orders_4 分表
CREATE TABLE Orders_4
(
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
);

分表邏輯

在應(yīng)用層,我們需要實(shí)現(xiàn)一個(gè)分表路由邏輯,通過哈希值來確定應(yīng)該向哪個(gè)表插入數(shù)據(jù)或查詢數(shù)據(jù)。

-- 示例:根據(jù) CustomerID 哈希值選擇分表
DECLARE @CustomerID INT = 1001;
DECLARE @TableSuffix INT;
-- 使用哈希算法來決定表
SET @TableSuffix = @CustomerID % 4;
-- 插入數(shù)據(jù)
IF @TableSuffix = 0
BEGIN
    INSERT INTO Orders_1 (OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status)
    VALUES (123456, 1001, '2024-01-01', 101, 150.00, 'Paid');
END
ELSE IF @TableSuffix = 1
BEGIN
    INSERT INTO Orders_2 (OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status)
    VALUES (123457, 1002, '2024-01-02', 102, 250.00, 'Pending');
END
ELSE IF @TableSuffix = 2
BEGIN
    INSERT INTO Orders_3 (OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status)
    VALUES (123458, 1003, '2024-01-03', 103, 350.00, 'Shipped');
END
ELSE
BEGIN
    INSERT INTO Orders_4 (OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status)
    VALUES (123459, 1004, '2024-01-04', 104, 450.00, 'Delivered');
END

查詢邏輯

為了查詢某個(gè)客戶的訂單,我們也需要在應(yīng)用層決定查詢哪個(gè)分表:

-- 查詢某個(gè)客戶的訂單
DECLARE @CustomerID INT = 1001;
DECLARE @TableSuffix INT;
SET @TableSuffix = @CustomerID % 4;
-- 查詢數(shù)據(jù)
IF @TableSuffix = 0
BEGIN
    SELECT * FROM Orders_1 WHERE CustomerID = @CustomerID;
END
ELSE IF @TableSuffix = 1
BEGIN
    SELECT * FROM Orders_2 WHERE CustomerID = @CustomerID;
END
ELSE IF @TableSuffix = 2
BEGIN
    SELECT * FROM Orders_3 WHERE CustomerID = @CustomerID;
END
ELSE
BEGIN
    SELECT * FROM Orders_4 WHERE CustomerID = @CustomerID;
END

3. 分區(qū)和分表的選擇

  • 分區(qū):適用于對(duì)一個(gè)表進(jìn)行物理劃分,但仍然保持?jǐn)?shù)據(jù)的邏輯統(tǒng)一性。例如,按時(shí)間(如訂單日期)分區(qū)可以有效提高時(shí)間范圍查詢的性能。
  • 分表:適用于數(shù)據(jù)量特別大的情況,將數(shù)據(jù)拆分到多個(gè)表中,以減少單個(gè)表的查詢壓力。通常采用哈希分表或者范圍分表。

小結(jié)一下

  • 分區(qū)可以讓你在一個(gè)大的表上進(jìn)行邏輯劃分,在查詢時(shí)只訪問相關(guān)的分區(qū),提高性能。
  • 分表則是將數(shù)據(jù)水平拆分到多個(gè)物理表,通常用于處理極大數(shù)據(jù)量的場(chǎng)景。
  • 在 SQL Server 中實(shí)現(xiàn)分區(qū)和分表需要對(duì)表的設(shè)計(jì)、索引設(shè)計(jì)和查詢策略進(jìn)行綜合考慮,以確保數(shù)據(jù)訪問效率和維護(hù)的便利性。

4. 數(shù)據(jù)歸檔

  • 歸檔舊數(shù)據(jù):對(duì)于已經(jīng)不常查詢的數(shù)據(jù),可以將其歸檔到獨(dú)立的歷史表或數(shù)據(jù)庫中,從而減輕主數(shù)據(jù)庫的負(fù)擔(dān)。只保留近期數(shù)據(jù)在主表中,優(yōu)化查詢性能。
  • 壓縮舊數(shù)據(jù):可以通過壓縮技術(shù)來存儲(chǔ)歸檔數(shù)據(jù),節(jié)省存儲(chǔ)空間。

數(shù)據(jù)歸檔是指將不再頻繁訪問的歷史數(shù)據(jù)從主數(shù)據(jù)庫中移除,并將其存儲(chǔ)在歸檔系統(tǒng)或表中,從而提高主數(shù)據(jù)庫的性能。數(shù)據(jù)歸檔通常用于老舊數(shù)據(jù)、歷史記錄等不再活躍但需要保留的數(shù)據(jù)。

業(yè)務(wù)場(chǎng)景

假設(shè)我們有一個(gè)訂單系統(tǒng),Orders 表記錄了所有訂單信息。隨著時(shí)間的推移,訂單數(shù)據(jù)量急劇增加,但在實(shí)際業(yè)務(wù)中,超過一定時(shí)間的訂單數(shù)據(jù)查詢頻率下降。為了提高數(shù)據(jù)庫性能,我們決定將超過 1 年的訂單數(shù)據(jù)從主表中移除并存檔到歸檔表中。

步驟:

  • 創(chuàng)建主表(Orders)和歸檔表(ArchivedOrders)。
  • 定期將超過 1 年的訂單數(shù)據(jù)從 Orders 表移到 ArchivedOrders 表。
  • 確保歸檔數(shù)據(jù)的查詢不會(huì)影響到主表的性能。

1. 創(chuàng)建主表和歸檔表

-- 創(chuàng)建主訂單表 Orders
CREATE TABLE Orders
(
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
);
-- 創(chuàng)建歸檔表 ArchivedOrders
CREATE TABLE ArchivedOrders
(
    OrderID INT PRIMARY KEY,
    CustomerID INT,
    OrderDate DATE,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
);

2. 歸檔操作(將超過 1 年的訂單移至歸檔表)

為了定期將過期的訂單移至歸檔表,可以使用定時(shí)任務(wù)(如 SQL Server Agent 作業(yè))來執(zhí)行這個(gè)操作。

-- 將超過 1 年的訂單數(shù)據(jù)從 Orders 表移到 ArchivedOrders 表
INSERT INTO ArchivedOrders (OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status)
SELECT OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status
FROM Orders
WHERE OrderDate < DATEADD(YEAR, -1, GETDATE());
-- 刪除 Orders 表中超過 1 年的訂單數(shù)據(jù)
DELETE FROM Orders
WHERE OrderDate < DATEADD(YEAR, -1, GETDATE());

這段代碼會(huì)將 Orders 表中 OrderDate 小于當(dāng)前日期 1 年的訂單數(shù)據(jù)插入到 ArchivedOrders 表,并將這些數(shù)據(jù)從 Orders 表中刪除。

3. 定時(shí)歸檔任務(wù)(使用 SQL Server Agent)

我們可以使用 SQL Server Agent 來創(chuàng)建一個(gè)定時(shí)任務(wù),定期執(zhí)行數(shù)據(jù)歸檔操作。例如,每天運(yùn)行一次,將 1 年前的訂單數(shù)據(jù)歸檔:

-- 在 SQL Server Agent 中創(chuàng)建作業(yè)來執(zhí)行歸檔操作
USE msdb;
GO
EXEC sp_add_job
    @job_name = N'ArchiveOldOrders';
GO
EXEC sp_add_jobstep
    @job_name = N'ArchiveOldOrders',
    @step_name = N'ArchiveOrdersStep',
    @subsystem = N'TSQL',
    @command = N'
        INSERT INTO ArchivedOrders (OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status)
        SELECT OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status
        FROM Orders
        WHERE OrderDate < DATEADD(YEAR, -1, GETDATE());
        DELETE FROM Orders
        WHERE OrderDate < DATEADD(YEAR, -1, GETDATE());
    ',
    @database_name = N'VGDB';
GO
-- 設(shè)置作業(yè)的調(diào)度,例如每天運(yùn)行一次
EXEC sp_add_schedule
    @schedule_name = N'ArchiveOrdersDaily',
    @enabled = 1,
    @freq_type = 4, -- 每天
    @freq_interval = 1, -- 每天執(zhí)行一次
    @active_start_time = 0;
GO
EXEC sp_attach_schedule
    @job_name = N'ArchiveOldOrders',
    @schedule_name = N'ArchiveOrdersDaily';
GO
-- 啟動(dòng)作業(yè)
EXEC sp_start_job @job_name = N'ArchiveOldOrders';
GO

4. 查詢歸檔數(shù)據(jù)

歸檔后的數(shù)據(jù)依然可以查詢,但不會(huì)影響主表的查詢性能。為了查找某個(gè)客戶的歷史訂單,可以查詢歸檔表:

-- 查詢某個(gè)客戶的歷史訂單
SELECT OrderID, CustomerID, OrderDate, ProductID, TotalAmount, Status
FROM ArchivedOrders
WHERE CustomerID = 1001
ORDER BY OrderDate DESC;

5. 優(yōu)化與注意事項(xiàng)

  • 歸檔策略:可以根據(jù)實(shí)際業(yè)務(wù)需求選擇合適的時(shí)間范圍(例如,3 個(gè)月、6 個(gè)月或 1 年)??梢酝ㄟ^調(diào)整 WHERE 條件來修改歸檔規(guī)則。
  • 性能優(yōu)化:定期歸檔操作可以減輕主表的負(fù)擔(dān),提高查詢性能。定期刪除舊數(shù)據(jù)也能減少主表的存儲(chǔ)空間。
  • 歸檔數(shù)據(jù)的備份和恢復(fù):歸檔數(shù)據(jù)同樣需要定期備份,并能夠在需要時(shí)恢復(fù)。確保歸檔表也包括足夠的備份策略。

6. 歸檔與清理數(shù)據(jù)的另一個(gè)選項(xiàng):軟刪除

在某些情況下,數(shù)據(jù)歸檔后并沒有從數(shù)據(jù)庫中完全刪除,而是標(biāo)記為“已歸檔”或“已刪除”。這種方法的優(yōu)點(diǎn)是可以隨時(shí)恢復(fù)數(shù)據(jù),而不會(huì)丟失。

-- 在 Orders 表中添加 Archived 標(biāo)志
ALTER TABLE Orders
ADD Archived BIT DEFAULT 0;
-- 將數(shù)據(jù)標(biāo)記為已歸檔
UPDATE Orders
SET Archived = 1
WHERE OrderDate < DATEADD(YEAR, -1, GETDATE());
-- 查詢未歸檔的數(shù)據(jù)
SELECT * FROM Orders WHERE Archived = 0;
-- 查詢歸檔數(shù)據(jù)
SELECT * FROM Orders WHERE Archived = 1;

通過這種方法,歸檔的訂單仍然保留在主表中,但通過 Archived 字段可以區(qū)分已歸檔和未歸檔的訂單。

小結(jié)一下

數(shù)據(jù)歸檔操作是管理大數(shù)據(jù)量數(shù)據(jù)庫的一種有效策略。通過定期將歷史數(shù)據(jù)從主數(shù)據(jù)庫表中遷移到歸檔表,可以顯著提高數(shù)據(jù)庫的查詢性能,同時(shí)確保歷史數(shù)據(jù)得以保留,便于以后查詢和審計(jì)。

5. 存儲(chǔ)和硬件優(yōu)化

  • 磁盤 I/O 優(yōu)化:數(shù)據(jù)庫的性能受到磁盤 I/O 的限制,尤其是在處理大量數(shù)據(jù)時(shí)。使用 SSD 存儲(chǔ)比傳統(tǒng)的硬盤(HDD)提供更快的 I/O 性能。
  • 增加內(nèi)存:增加 SQL Server 的內(nèi)存,可以使數(shù)據(jù)庫緩沖池更大,從而減少磁盤 I/O,提升查詢性能。
  • 使用 RAID 配置:使用 RAID 10 或其他 RAID 配置,確保數(shù)據(jù)讀寫的高效性和可靠性。

存儲(chǔ)和硬件優(yōu)化是提升數(shù)據(jù)庫性能的關(guān)鍵部分,尤其是在大規(guī)模數(shù)據(jù)處理的環(huán)境中。通過合理的硬件資源分配、存儲(chǔ)結(jié)構(gòu)優(yōu)化以及數(shù)據(jù)庫配置,可以顯著提高性能。下面我們將針對(duì)一個(gè)電商平臺(tái)的訂單系統(tǒng)來講解如何在存儲(chǔ)和硬件層面優(yōu)化 SQL Server。

業(yè)務(wù)場(chǎng)景:

假設(shè)你有一個(gè)電商平臺(tái),訂單數(shù)據(jù)存儲(chǔ)在 SQL Server 中,訂單數(shù)量日益增加,導(dǎo)致查詢性能下降。在此場(chǎng)景中,我們可以通過以下方法進(jìn)行存儲(chǔ)和硬件優(yōu)化。

優(yōu)化策略:

  • 磁盤 I/O 優(yōu)化

    • 使用 SSD 替代傳統(tǒng)硬盤(HDD)以提高讀寫速度。
    • 將數(shù)據(jù)文件、日志文件和臨時(shí)文件存儲(chǔ)在不同的物理磁盤上。
  • 表和索引存儲(chǔ)

    • 使用適當(dāng)?shù)拇鎯?chǔ)格式和文件組織方式,如分區(qū)表和表壓縮。
    • 將頻繁訪問的表和索引放置在高性能的磁盤上。
  • 硬件資源配置

    • 增加內(nèi)存以支持更多的數(shù)據(jù)緩存,減少磁盤訪問。
    • 使用多核 CPU 以提高并發(fā)查詢的處理能力。
  • 數(shù)據(jù)壓縮

    • 在 SQL Server 中啟用數(shù)據(jù)壓縮,以減少磁盤空間的使用并提高 I/O 性能。

1. 創(chuàng)建表并優(yōu)化存儲(chǔ)

首先,我們創(chuàng)建訂單表,并為訂單表的 OrderID 列創(chuàng)建聚集索引。

-- 創(chuàng)建 Orders 表并優(yōu)化存儲(chǔ)
CREATE TABLE Orders
(
    OrderID INT PRIMARY KEY CLUSTERED,  -- 聚集索引
    CustomerID INT,
    OrderDate DATETIME,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
) 
ON [PRIMARY]
WITH (DATA_COMPRESSION = PAGE);  -- 啟用數(shù)據(jù)頁壓縮以節(jié)省空間
-- 啟用非聚集索引,用于優(yōu)化查詢
CREATE NONCLUSTERED INDEX idx_OrderDate
ON Orders(OrderDate)
WITH (DATA_COMPRESSION = PAGE);  -- 同樣啟用數(shù)據(jù)壓縮

通過使用 DATA_COMPRESSION = PAGE,我們啟用了 SQL Server 的數(shù)據(jù)壓縮功能,以節(jié)省存儲(chǔ)空間并提高磁盤 I/O 性能。PAGE 壓縮比 ROW 壓縮更高效,適合大型數(shù)據(jù)表。

2. 分區(qū)表優(yōu)化

在訂單數(shù)據(jù)量不斷增加的情況下,我們可以將訂單表進(jìn)行分區(qū)。根據(jù) OrderDate 列將數(shù)據(jù)劃分為不同的分區(qū),以減少查詢時(shí)的掃描范圍,提高查詢效率。

-- 創(chuàng)建分區(qū)函數(shù)
CREATE PARTITION FUNCTION pf_OrderDate (DATETIME)
AS RANGE RIGHT FOR VALUES ('2022-01-01', '2023-01-01', '2024-01-01');
-- 創(chuàng)建分區(qū)方案
CREATE PARTITION SCHEME ps_OrderDate
AS PARTITION pf_OrderDate
TO ([PRIMARY], [PRIMARY], [PRIMARY], [PRIMARY]);
-- 創(chuàng)建分區(qū)表
CREATE TABLE Orders
(
    OrderID INT PRIMARY KEY CLUSTERED, 
    CustomerID INT,
    OrderDate DATETIME,
    ProductID INT,
    TotalAmount DECIMAL(10, 2),
    Status VARCHAR(20)
) 
ON ps_OrderDate(OrderDate);  -- 按 OrderDate 列進(jìn)行分區(qū)

在此代碼中,我們根據(jù) OrderDate 列的年份劃分了不同的分區(qū)(如 2022 年、2023 年和 2024 年的訂單數(shù)據(jù))。這樣可以使查詢?cè)谀骋惶囟〞r(shí)間范圍內(nèi)的性能更高,因?yàn)?SQL Server 只需要掃描相關(guān)分區(qū)的數(shù)據(jù),而不是整個(gè)表。

3. 硬件優(yōu)化配置

3.1. 確保使用 SSD 磁盤

SSD 磁盤比傳統(tǒng)硬盤的讀寫速度快,因此將數(shù)據(jù)庫的主要數(shù)據(jù)文件、日志文件和臨時(shí)文件分別存儲(chǔ)在不同的磁盤上(最好是 SSD)可以提高性能。

-- 將 SQL Server 數(shù)據(jù)文件 (.mdf) 存儲(chǔ)在 SSD 磁盤
-- 將日志文件 (.ldf) 存儲(chǔ)在 SSD 磁盤
-- 將臨時(shí)數(shù)據(jù)庫文件 (.ndf) 存儲(chǔ)在 SSD 磁盤

3.2. 配置 SQL Server 內(nèi)存

將 SQL Server 的內(nèi)存設(shè)置為最大化,以便更多數(shù)據(jù)可以緩存在內(nèi)存中,從而減少磁盤 I/O。以下為如何設(shè)置 SQL Server 的最大內(nèi)存配置:

-- 查看當(dāng)前內(nèi)存設(shè)置
EXEC sp_configure 'show advanced options', 1;
RECONFIGURE;
EXEC sp_configure 'max server memory (MB)';
-- 設(shè)置最大內(nèi)存為 16 GB
EXEC sp_configure 'max server memory (MB)', 16384;
RECONFIGURE;

通過適當(dāng)?shù)膬?nèi)存配置,SQL Server 可以將更多數(shù)據(jù)緩存在內(nèi)存中,從而減少對(duì)磁盤的訪問,提高查詢響應(yīng)速度。

3.3. 配置 SQL Server 并行處理

如果服務(wù)器具有多核 CPU,可以通過設(shè)置 SQL Server 允許更多的并行查詢操作,從而提高多線程查詢的處理能力。

-- 查看當(dāng)前并行度配置
EXEC sp_configure 'max degree of parallelism';
-- 設(shè)置為 4,允許最多 4 個(gè) CPU 并行處理查詢
EXEC sp_configure 'max degree of parallelism', 4;
RECONFIGURE;

4. 磁盤 I/O 優(yōu)化:分開存儲(chǔ)數(shù)據(jù)文件、日志文件和臨時(shí)文件

磁盤 I/O 是數(shù)據(jù)庫性能的瓶頸之一。為了提高數(shù)據(jù)庫的性能,最好將數(shù)據(jù)文件、日志文件和臨時(shí)文件存儲(chǔ)在不同的物理磁盤上。

-- 數(shù)據(jù)文件 (.mdf) 存儲(chǔ)在磁盤 A
-- 日志文件 (.ldf) 存儲(chǔ)在磁盤 B
-- 臨時(shí)數(shù)據(jù)庫文件 (.ndf) 存儲(chǔ)在磁盤 C

5. 數(shù)據(jù)備份和恢復(fù)優(yōu)化

確保定期備份數(shù)據(jù),并使用增量備份、差異備份等方式以減少備份時(shí)的磁盤負(fù)擔(dān)。

-- 進(jìn)行完整備份
BACKUP DATABASE VGDB TO DISK = 'D:\Backups\VGDB_full.bak';
-- 進(jìn)行差異備份
BACKUP DATABASE WGDB TO DISK = 'D:\Backups\VGDB_diff.bak' WITH DIFFERENTIAL;
-- 進(jìn)行事務(wù)日志備份
BACKUP LOG VGDB TO DISK = 'D:\Backups\VGDB_log.trn';

通過這種方法,可以在系統(tǒng)崩潰時(shí)快速恢復(fù)數(shù)據(jù),同時(shí)減少備份過程中對(duì)硬盤 I/O 性能的影響。

6. 監(jiān)控和維護(hù)

定期監(jiān)控 SQL Server 的性能,并根據(jù)硬件和存儲(chǔ)需求做出相應(yīng)的調(diào)整。通過 SQL Server 的動(dòng)態(tài)管理視圖(DMV)來監(jiān)控 I/O 性能、查詢執(zhí)行計(jì)劃、索引使用情況等。

-- 查看磁盤 I/O 狀況
SELECT * FROM sys.dm_io_virtual_file_stats(NULL, NULL);
-- 查看查詢執(zhí)行計(jì)劃的緩存
SELECT * FROM sys.dm_exec_query_stats;
-- 查看當(dāng)前的索引使用情況
SELECT * FROM sys.dm_db_index_usage_stats;

小結(jié)一下

通過存儲(chǔ)和硬件優(yōu)化,可以顯著提升 SQL Server 數(shù)據(jù)庫的性能。關(guān)鍵的優(yōu)化措施包括使用 SSD 磁盤、將數(shù)據(jù)文件、日志文件和臨時(shí)文件分開存儲(chǔ)、啟用數(shù)據(jù)壓縮、使用分區(qū)表來提高查詢效率以及調(diào)整內(nèi)存和并行處理配置等。定期的維護(hù)和監(jiān)控也能幫助你發(fā)現(xiàn)性能瓶頸并作出相應(yīng)調(diào)整。

6. 數(shù)據(jù)庫參數(shù)和配置優(yōu)化

  • 調(diào)整最大并發(fā)連接數(shù):確保 SQL Server 配置了足夠的最大并發(fā)連接數(shù),避免過多連接時(shí)導(dǎo)致性能下降。
  • 設(shè)置合適的內(nèi)存限制:為 SQL Server 配置足夠的內(nèi)存(max server memory),避免內(nèi)存溢出或過度使用磁盤交換。
  • 自動(dòng)更新統(tǒng)計(jì)信息:確保 SQL Server 自動(dòng)更新查詢的統(tǒng)計(jì)信息(AUTO_UPDATE_STATISTICS),以便查詢優(yōu)化器選擇最優(yōu)執(zhí)行計(jì)劃。

數(shù)據(jù)庫參數(shù)和配置優(yōu)化是確保數(shù)據(jù)庫系統(tǒng)性能達(dá)到最佳狀態(tài)的重要步驟。在高并發(fā)、高負(fù)載的場(chǎng)景下,合理的配置可以顯著提高數(shù)據(jù)庫性能,減少響應(yīng)時(shí)間和延遲。以下是基于一個(gè)電商平臺(tái)訂單系統(tǒng)的業(yè)務(wù)場(chǎng)景,如何通過優(yōu)化數(shù)據(jù)庫的參數(shù)和配置來提升性能的完整代碼案例。

業(yè)務(wù)場(chǎng)景:

假設(shè)電商平臺(tái)的訂單量非常大,系統(tǒng)每天處理數(shù)百萬個(gè)訂單,數(shù)據(jù)庫的性能和響應(yīng)速度是系統(tǒng)正常運(yùn)行的關(guān)鍵。為確保數(shù)據(jù)庫性能,在 SQL Server 中進(jìn)行參數(shù)和配置優(yōu)化至關(guān)重要。

優(yōu)化策略:

  • 調(diào)整內(nèi)存配置:通過配置 SQL Server 使用更多的內(nèi)存來緩存數(shù)據(jù),減少磁盤 I/O。
  • 設(shè)置最大并行度:根據(jù) CPU 核心數(shù),調(diào)整 SQL Server 的并行查詢處理能力。
  • 優(yōu)化磁盤和存儲(chǔ)配置:確保日志文件、數(shù)據(jù)文件和臨時(shí)文件分開存儲(chǔ)。
  • 啟用自動(dòng)數(shù)據(jù)庫優(yōu)化:確保數(shù)據(jù)庫能夠自動(dòng)進(jìn)行碎片整理、更新統(tǒng)計(jì)信息等任務(wù)。
  • 調(diào)整事務(wù)日志和恢復(fù)模式:確保數(shù)據(jù)庫在發(fā)生故障時(shí)能夠快速恢復(fù)。

1. 調(diào)整內(nèi)存配置

內(nèi)存配置優(yōu)化是提高 SQL Server 性能的關(guān)鍵部分。通過增加 SQL Server 的最大內(nèi)存,可以保證查詢操作不會(huì)因?yàn)榇疟P I/O 的瓶頸而導(dǎo)致性能問題。

-- 查看當(dāng)前最大內(nèi)存配置
EXEC sp_configure 'show advanced options', 1;
RECONFIGURE;
EXEC sp_configure 'max server memory (MB)';
-- 設(shè)置最大內(nèi)存為 16 GB
EXEC sp_configure 'max server memory (MB)', 16384;  -- 16 GB
RECONFIGURE;

在上述代碼中,我們將 SQL Server 的最大內(nèi)存設(shè)置為 16 GB。適當(dāng)配置內(nèi)存可以提高查詢性能,減少磁盤的訪問。

2. 設(shè)置最大并行度

SQL Server 可以利用多個(gè) CPU 核心進(jìn)行并行查詢處理。通過合理設(shè)置并行度,可以提高大查詢的處理能力。

-- 查看當(dāng)前的最大并行度設(shè)置
EXEC sp_configure 'max degree of parallelism';
-- 設(shè)置最大并行度為 4(適用于 4 核 CPU 的機(jī)器)
EXEC sp_configure 'max degree of parallelism', 4;
RECONFIGURE;

通過此設(shè)置,SQL Server 可以在查詢時(shí)利用最多 4 個(gè) CPU 核心進(jìn)行并行處理。如果你的服務(wù)器有更多核心,可以根據(jù)實(shí)際情況調(diào)整這個(gè)參數(shù)。

3. 調(diào)整事務(wù)日志和恢復(fù)模式

對(duì)于電商平臺(tái)而言,事務(wù)日志的優(yōu)化至關(guān)重要。確保在進(jìn)行大規(guī)模事務(wù)操作時(shí),日志文件能夠高效地處理,并且確?;謴?fù)模式符合業(yè)務(wù)需求。

-- 查看數(shù)據(jù)庫的恢復(fù)模式
SELECT name, recovery_model_desc
FROM sys.databases
WHERE name = 'VGDB';
-- 設(shè)置恢復(fù)模式為簡(jiǎn)單恢復(fù)模式
ALTER DATABASE VGDB
SET RECOVERY SIMPLE;

對(duì)于不需要完整備份的數(shù)據(jù)庫,使用簡(jiǎn)單恢復(fù)模式可以減少日志文件的增長(zhǎng),減輕磁盤 I/O 壓力。

4. 配置自動(dòng)數(shù)據(jù)庫優(yōu)化

確保數(shù)據(jù)庫能夠定期執(zhí)行自動(dòng)優(yōu)化任務(wù),如重建索引、更新統(tǒng)計(jì)信息等。定期優(yōu)化可以提高數(shù)據(jù)庫的查詢性能,避免碎片化問題。

-- 啟用自動(dòng)更新統(tǒng)計(jì)信息
EXEC sp_configure 'auto update statistics', 1;
RECONFIGURE;
-- 啟用自動(dòng)創(chuàng)建統(tǒng)計(jì)信息
EXEC sp_configure 'auto create statistics', 1;
RECONFIGURE;

通過啟用自動(dòng)更新統(tǒng)計(jì)信息和自動(dòng)創(chuàng)建統(tǒng)計(jì)信息,可以確保 SQL Server 在執(zhí)行查詢時(shí)能夠使用最新的執(zhí)行計(jì)劃,減少查詢優(yōu)化器的負(fù)擔(dān)。

5. 配置磁盤和存儲(chǔ)

確保 SQL Server 的數(shù)據(jù)文件、日志文件和臨時(shí)文件存儲(chǔ)在不同的磁盤上,特別是將日志文件和數(shù)據(jù)文件存儲(chǔ)在高速磁盤(如 SSD)上。

-- 將數(shù)據(jù)文件 (.mdf) 存儲(chǔ)在磁盤 A(SSD)
-- 將日志文件 (.ldf) 存儲(chǔ)在磁盤 B(SSD)
-- 將臨時(shí)數(shù)據(jù)庫文件 (.ndf) 存儲(chǔ)在磁盤 C(SSD)

通過將數(shù)據(jù)文件、日志文件和臨時(shí)文件分別存儲(chǔ)在不同的磁盤上,可以避免磁盤 I/O 爭(zhēng)用,提升數(shù)據(jù)庫的整體性能。

6. 啟用數(shù)據(jù)庫壓縮

對(duì)于需要存儲(chǔ)大量數(shù)據(jù)的電商平臺(tái),啟用數(shù)據(jù)壓縮可以減少存儲(chǔ)空間并提高查詢性能,尤其是在磁盤 I/O 上。

-- 啟用表壓縮
ALTER TABLE Orders REBUILD PARTITION = ALL WITH (DATA_COMPRESSION = PAGE);
-- 啟用索引壓縮
ALTER INDEX ALL ON Orders REBUILD PARTITION = ALL WITH (DATA_COMPRESSION = PAGE);

通過啟用數(shù)據(jù)壓縮,我們可以有效節(jié)省存儲(chǔ)空間,減少磁盤 I/O 操作,并提高查詢速度。

7. 配置自動(dòng)維護(hù)任務(wù)

SQL Server 提供了自動(dòng)維護(hù)任務(wù),如索引重建、數(shù)據(jù)庫碎片整理等,可以通過 SQL Server Agent 定時(shí)任務(wù)來自動(dòng)執(zhí)行這些任務(wù),保持?jǐn)?shù)據(jù)庫的高效運(yùn)行。

-- 創(chuàng)建一個(gè)定期執(zhí)行的作業(yè),執(zhí)行索引重建任務(wù)
EXEC sp_add_job @job_name = 'RebuildIndexes', @enabled = 1;
EXEC sp_add_jobstep @job_name = 'RebuildIndexes', 
    @step_name = 'RebuildIndexStep', 
    @subsystem = 'TSQL', 
    @command = 'ALTER INDEX ALL ON Orders REBUILD',
    @retry_attempts = 3, 
    @retry_interval = 5;
-- 設(shè)置作業(yè)運(yùn)行頻率:每天凌晨 2 點(diǎn)執(zhí)行
EXEC sp_add_schedule @schedule_name = 'RebuildIndexSchedule',
    @enabled = 1,
    @freq_type = 4, 
    @freq_interval = 1, 
    @active_start_time = 20000;
EXEC sp_attach_schedule @job_name = 'RebuildIndexes', @schedule_name = 'RebuildIndexSchedule';

這個(gè)作業(yè)將在每天凌晨 2 點(diǎn)執(zhí)行,重建 Orders 表上的所有索引,從而避免因索引碎片而降低查詢性能。

8. 啟用即時(shí)日志備份

對(duì)于生產(chǎn)環(huán)境,尤其是電商平臺(tái),確保日志備份及時(shí)執(zhí)行至關(guān)重要。啟用日志備份可以保證在數(shù)據(jù)庫發(fā)生故障時(shí)進(jìn)行快速恢復(fù)。

-- 設(shè)置事務(wù)日志備份
BACKUP LOG VGDB TO DISK = 'D:\Backups\YourDatabase_log.trn';

通過定期執(zhí)行事務(wù)日志備份,可以確保在發(fā)生故障時(shí),數(shù)據(jù)庫能夠恢復(fù)到最新的狀態(tài)。

9. 啟用數(shù)據(jù)庫緩存

SQL Server 會(huì)緩存查詢結(jié)果和數(shù)據(jù)頁,通過調(diào)整緩存策略來優(yōu)化性能。

-- 查看緩存的頁面數(shù)量
DBCC SHOW_STATISTICS('Orders');
-- 強(qiáng)制清除緩存(有時(shí)可以用于測(cè)試)
DBCC FREEPROCCACHE;
DBCC DROPCLEANBUFFERS;

在日常操作中,我們不建議經(jīng)常清除緩存,但可以在需要時(shí)清除緩存來測(cè)試性能優(yōu)化效果。

小結(jié)一下

通過優(yōu)化 SQL Server 的配置和參數(shù),可以顯著提升電商平臺(tái)的數(shù)據(jù)庫性能。關(guān)鍵的優(yōu)化措施包括調(diào)整內(nèi)存和并行度、優(yōu)化磁盤存儲(chǔ)和日志配置、啟用數(shù)據(jù)壓縮、定期執(zhí)行自動(dòng)數(shù)據(jù)庫優(yōu)化任務(wù)、配置數(shù)據(jù)庫壓縮和定期備份等。根據(jù)業(yè)務(wù)需求和硬件資源進(jìn)行合理配置,以確保數(shù)據(jù)庫在高并發(fā)、高負(fù)載的環(huán)境中能夠穩(wěn)定高效地運(yùn)行。

7. 批量數(shù)據(jù)處理

  • 批量插入/更新操作:在處理大量數(shù)據(jù)時(shí),可以使用批量插入或更新操作,而不是一行一行地進(jìn)行。這能顯著提高數(shù)據(jù)的加載速度。
  • 避免大事務(wù):對(duì)于大量的數(shù)據(jù)修改,避免使用大事務(wù),因?yàn)榇笫聞?wù)可能會(huì)導(dǎo)致鎖競(jìng)爭(zhēng)、日志文件過大等問題。使用小批次事務(wù)進(jìn)行操作。

批量數(shù)據(jù)處理在大規(guī)模應(yīng)用中是不可避免的,尤其是像電商平臺(tái)、金融系統(tǒng)等業(yè)務(wù)場(chǎng)景,通常需要進(jìn)行大批量的訂單、用戶信息處理等。批量操作能夠顯著提高數(shù)據(jù)處理效率,但也需要謹(jǐn)慎設(shè)計(jì),以確保性能和穩(wěn)定性。

業(yè)務(wù)場(chǎng)景:

假設(shè)在電商平臺(tái)中,訂單信息需要進(jìn)行批量處理,比如批量更新訂單狀態(tài)、批量刪除失效訂單、批量插入訂單數(shù)據(jù)等。通過設(shè)計(jì)合適的批量操作,能夠有效減少單次操作的數(shù)據(jù)庫訪問次數(shù),提升系統(tǒng)的響應(yīng)能力。

優(yōu)化方案:

  • 批量插入數(shù)據(jù):通過 BULK INSERT 或者 INSERT INTO 多行插入方式,減少多次單獨(dú)插入操作帶來的性能瓶頸。
  • 批量更新數(shù)據(jù):使用 UPDATE 操作一次性更新多條記錄。
  • 批量刪除數(shù)據(jù):批量刪除過期的訂單,或者批量刪除無效的用戶信息。

以下是具體的 SQL Server 批量數(shù)據(jù)處理的代碼案例。

1. 批量插入數(shù)據(jù)

批量插入可以減少大量單獨(dú)插入操作的時(shí)間開銷,通過 INSERT INTO 語句一次插入多條數(shù)據(jù)。

示例:批量插入訂單數(shù)據(jù)

-- 假設(shè) Orders 表結(jié)構(gòu)如下:OrderID INT, CustomerID INT, OrderDate DATETIME, OrderStatus VARCHAR(20)
DECLARE @OrderData TABLE (OrderID INT, CustomerID INT, OrderDate DATETIME, OrderStatus VARCHAR(20));
-- 將訂單數(shù)據(jù)插入臨時(shí)表
INSERT INTO @OrderData (OrderID, CustomerID, OrderDate, OrderStatus)
VALUES
    (1, 101, '2024-11-01', 'Pending'),
    (2, 102, '2024-11-02', 'Shipped'),
    (3, 103, '2024-11-03', 'Delivered'),
    (4, 104, '2024-11-04', 'Cancelled');
-- 批量插入數(shù)據(jù)到 Orders 表
INSERT INTO Orders (OrderID, CustomerID, OrderDate, OrderStatus)
SELECT OrderID, CustomerID, OrderDate, OrderStatus
FROM @OrderData;

在此例中,我們先將數(shù)據(jù)插入臨時(shí)表 @OrderData,然后通過 INSERT INTO SELECT 語句批量插入 Orders 表。這種方式可以大大減少數(shù)據(jù)庫訪問的次數(shù)。

2. 批量更新數(shù)據(jù)

批量更新操作通常用于修改多個(gè)記錄中的某些字段,避免多次單獨(dú)更新。

示例:批量更新訂單狀態(tài)

假設(shè)需要批量更新所有未發(fā)貨的訂單狀態(tài)為 "Shipped",可以通過如下 SQL 來實(shí)現(xiàn):

-- 批量更新訂單狀態(tài)
UPDATE Orders
SET OrderStatus = 'Shipped'
WHERE OrderStatus = 'Pending' AND OrderDate < '2024-11-01';

該操作會(huì)一次性更新所有符合條件的記錄,避免多次單獨(dú)更新操作帶來的性能問題。

3. 批量刪除數(shù)據(jù)

在某些場(chǎng)景下,我們需要批量刪除某些過期或無效的數(shù)據(jù)。例如,刪除 30 天之前的過期訂單。

示例:批量刪除過期訂單

-- 刪除過期的訂單
DELETE FROM Orders
WHERE OrderDate < DATEADD(DAY, -30, GETDATE()) AND OrderStatus = 'Completed';

在這個(gè)例子中,我們刪除所有已完成且訂單日期超過 30 天的訂單。這種批量刪除操作比逐個(gè)刪除要高效得多。

4. 批量處理邏輯優(yōu)化

有時(shí)批量操作的數(shù)據(jù)量非常大,直接處理可能導(dǎo)致性能問題或數(shù)據(jù)庫鎖爭(zhēng)用??梢钥紤]分批次執(zhí)行操作來減輕系統(tǒng)負(fù)擔(dān)。

示例:按批次處理訂單數(shù)據(jù)

DECLARE @BatchSize INT = 1000;
DECLARE @StartRow INT = 0;
DECLARE @TotalRows INT;
-- 計(jì)算總記錄數(shù)
SELECT @TotalRows = COUNT(*) FROM Orders WHERE OrderStatus = 'Pending';
-- 循環(huán)批量處理數(shù)據(jù)
WHILE @StartRow < @TotalRows
BEGIN
    -- 批量更新 1000 條數(shù)據(jù)
    UPDATE TOP (@BatchSize) Orders
    SET OrderStatus = 'Shipped'
    WHERE OrderStatus = 'Pending' AND OrderDate < '2024-11-01' AND OrderID > @StartRow;
    -- 更新已處理的行數(shù)
    SET @StartRow = @StartRow + @BatchSize;
END

通過分批次處理(每次處理 1000 條記錄),可以避免一次性處理大量數(shù)據(jù)時(shí)造成的性能瓶頸或數(shù)據(jù)庫鎖的問題。適用于需要批量更新大量記錄的情況。

5. 使用事務(wù)保證數(shù)據(jù)一致性

對(duì)于批量操作來說,通常需要使用事務(wù)來保證數(shù)據(jù)一致性,即要么全部成功,要么全部失敗。

示例:批量插入訂單并使用事務(wù)

BEGIN TRANSACTION;
BEGIN TRY
    -- 假設(shè) Orders 表結(jié)構(gòu):OrderID INT, CustomerID INT, OrderDate DATETIME, OrderStatus VARCHAR(20)
    DECLARE @OrderData TABLE (OrderID INT, CustomerID INT, OrderDate DATETIME, OrderStatus VARCHAR(20));
    -- 批量插入訂單數(shù)據(jù)
    INSERT INTO @OrderData (OrderID, CustomerID, OrderDate, OrderStatus)
    VALUES
        (5, 105, '2024-11-05', 'Pending'),
        (6, 106, '2024-11-06', 'Pending');
    INSERT INTO Orders (OrderID, CustomerID, OrderDate, OrderStatus)
    SELECT OrderID, CustomerID, OrderDate, OrderStatus
    FROM @OrderData;
    -- 提交事務(wù)
    COMMIT TRANSACTION;
END TRY
BEGIN CATCH
    -- 錯(cuò)誤處理并回滾事務(wù)
    ROLLBACK TRANSACTION;
    PRINT 'Error occurred: ' + ERROR_MESSAGE();
END CATCH;

在這個(gè)例子中,批量插入操作被包含在一個(gè)事務(wù)中,確保插入操作的原子性,即要么全部成功,要么全部失敗。如果在執(zhí)行過程中發(fā)生錯(cuò)誤,會(huì)回滾事務(wù),避免數(shù)據(jù)不一致的情況。

小結(jié)一下

批量數(shù)據(jù)處理是提高 SQL Server 性能的有效手段,尤其是在數(shù)據(jù)量龐大的電商平臺(tái)等業(yè)務(wù)場(chǎng)景中。通過合理使用批量插入、批量更新和批量刪除操作,可以大幅度提高數(shù)據(jù)庫的處理效率,減少數(shù)據(jù)庫的 I/O 操作次數(shù)和鎖競(jìng)爭(zhēng)。在執(zhí)行批量操作時(shí),記得通過事務(wù)保證數(shù)據(jù)的一致性,分批處理可以進(jìn)一步優(yōu)化大規(guī)模數(shù)據(jù)的處理性能。

8. 清理無用數(shù)據(jù)

  • 刪除過期數(shù)據(jù):定期清理過期或不再需要的數(shù)據(jù),減少數(shù)據(jù)庫的大小和查詢的復(fù)雜性。
  • 清理數(shù)據(jù)庫碎片:隨著數(shù)據(jù)的增刪,表和索引的碎片會(huì)增加,影響性能。定期重建索引或重新組織索引,減少碎片。

清理無用數(shù)據(jù)是數(shù)據(jù)庫維護(hù)中的常見任務(wù),特別是在處理歷史數(shù)據(jù)、過期記錄或冗余數(shù)據(jù)時(shí)。定期清理無用數(shù)據(jù)不僅能夠節(jié)省存儲(chǔ)空間,還能提高數(shù)據(jù)庫性能,避免無用數(shù)據(jù)對(duì)查詢、索引等造成不必要的影響。

業(yè)務(wù)場(chǎng)景:

假設(shè)我們?cè)谝粋€(gè)電商平臺(tái)中,用戶的訂單數(shù)據(jù)每年都會(huì)生成大量記錄。為了避免訂單表過于龐大,且不再使用的訂單記錄(比如 3 年之前的訂單)會(huì)占用大量存儲(chǔ)空間,我們需要定期清理這些過期訂單數(shù)據(jù)。

優(yōu)化方案:

  • 刪除過期數(shù)據(jù):定期刪除超過一定時(shí)間的訂單數(shù)據(jù)(比如 3 年前的訂單)。
  • 歸檔過期數(shù)據(jù):將過期的訂單數(shù)據(jù)移到一個(gè)歷史表或外部存儲(chǔ)中,保留必要的歷史信息。

代碼示例

1. 定期刪除過期數(shù)據(jù)

假設(shè)我們的 Orders 表有字段 OrderDate 來記錄訂單的創(chuàng)建時(shí)間,OrderStatus 來標(biāo)識(shí)訂單狀態(tài)。我們可以每月清理 3 年前的已完成或已取消的訂單。

-- 刪除 3 年前已完成或已取消的訂單
DELETE FROM Orders
WHERE OrderDate < DATEADD(YEAR, -3, GETDATE()) 
    AND OrderStatus IN ('Completed', 'Cancelled');

在這個(gè)例子中,DATEADD(YEAR, -3, GETDATE()) 會(huì)計(jì)算出當(dāng)前日期 3 年前的日期,所有在此日期之前且狀態(tài)為 'Completed' 或 'Cancelled' 的訂單將被刪除。

2. 定期歸檔過期數(shù)據(jù)

如果刪除數(shù)據(jù)不符合業(yè)務(wù)需求,可以選擇將數(shù)據(jù)歸檔。比如,將 3 年前的訂單轉(zhuǎn)移到 ArchivedOrders 表。

-- 將 3 年前的已完成或已取消的訂單移動(dòng)到 ArchivedOrders 表
INSERT INTO ArchivedOrders (OrderID, CustomerID, OrderDate, OrderStatus)
SELECT OrderID, CustomerID, OrderDate, OrderStatus
FROM Orders
WHERE OrderDate < DATEADD(YEAR, -3, GETDATE()) 
    AND OrderStatus IN ('Completed', 'Cancelled');
-- 刪除已歸檔的訂單
DELETE FROM Orders
WHERE OrderDate < DATEADD(YEAR, -3, GETDATE()) 
    AND OrderStatus IN ('Completed', 'Cancelled');

首先將符合條件的訂單數(shù)據(jù)插入到 ArchivedOrders 表,然后再刪除原 Orders 表中的這些數(shù)據(jù)。這樣可以保持主表的清潔,減少存儲(chǔ)壓力,并保留歷史數(shù)據(jù)。

3. 使用觸發(fā)器自動(dòng)清理無用數(shù)據(jù)

為了自動(dòng)化清理操作,可以使用數(shù)據(jù)庫觸發(fā)器(Trigger),例如,在每次插入數(shù)據(jù)時(shí)檢查數(shù)據(jù)是否超期,如果超期則觸發(fā)清理操作。觸發(fā)器可以周期性地執(zhí)行清理任務(wù)。

-- 創(chuàng)建觸發(fā)器,每天檢查并刪除 3 年前的訂單
CREATE TRIGGER CleanOldOrders
ON Orders
AFTER INSERT, UPDATE
AS
BEGIN
    -- 清理過期訂單:刪除 3 年前的已完成或已取消訂單
    DELETE FROM Orders
    WHERE OrderDate < DATEADD(YEAR, -3, GETDATE()) 
        AND OrderStatus IN ('Completed', 'Cancelled');
END;

此觸發(fā)器將在 Orders 表每次執(zhí)行插入或更新操作時(shí)觸發(fā),自動(dòng)檢查并清理過期的訂單。

4. 分批次清理無用數(shù)據(jù)

如果訂單數(shù)據(jù)量非常大,直接刪除可能會(huì)導(dǎo)致性能瓶頸或數(shù)據(jù)庫鎖定問題。在這種情況下,可以分批次刪除數(shù)據(jù),以減少單次刪除操作的負(fù)載。

DECLARE @BatchSize INT = 1000;
DECLARE @StartRow INT = 0;
DECLARE @TotalRows INT;
-- 計(jì)算需要?jiǎng)h除的記錄數(shù)
SELECT @TotalRows = COUNT(*) FROM Orders
WHERE OrderDate < DATEADD(YEAR, -3, GETDATE()) 
    AND OrderStatus IN ('Completed', 'Cancelled');
-- 分批次刪除
WHILE @StartRow < @TotalRows
BEGIN
    -- 批量刪除 1000 條數(shù)據(jù)
    DELETE TOP (@BatchSize) FROM Orders
    WHERE OrderDate < DATEADD(YEAR, -3, GETDATE()) 
        AND OrderStatus IN ('Completed', 'Cancelled')
        AND OrderID > @StartRow;
    -- 更新已刪除的行數(shù)
    SET @StartRow = @StartRow + @BatchSize;
END

通過分批次處理刪除操作,每次刪除少量記錄,減少對(duì)數(shù)據(jù)庫性能的影響,并避免長(zhǎng)時(shí)間鎖定表。

5. 使用作業(yè)調(diào)度器定期清理無用數(shù)據(jù)

如果您使用的是 SQL Server,可以使用作業(yè)調(diào)度器(SQL Server Agent)定期執(zhí)行清理任務(wù)。首先,您可以創(chuàng)建一個(gè)存儲(chǔ)過程來執(zhí)行數(shù)據(jù)清理操作。

CREATE PROCEDURE CleanOldOrders
AS
BEGIN
    DELETE FROM Orders
    WHERE OrderDate < DATEADD(YEAR, -3, GETDATE()) 
        AND OrderStatus IN ('Completed', 'Cancelled');
END;

然后,在 SQL Server Management Studio 中設(shè)置定期作業(yè)(例如每天午夜運(yùn)行該存儲(chǔ)過程),這樣可以確保無用數(shù)據(jù)定期清理。

小結(jié)一下

清理無用數(shù)據(jù)不僅有助于節(jié)省存儲(chǔ)空間,還能提高數(shù)據(jù)庫性能。根據(jù)實(shí)際業(yè)務(wù)需求,我們可以選擇刪除、歸檔或分批處理的方式來清理數(shù)據(jù)。特別是對(duì)于大數(shù)據(jù)量的表,分批清理和定期作業(yè)調(diào)度可以有效減少系統(tǒng)的負(fù)擔(dān)。

9. 使用緩存

  • 緩存常用查詢結(jié)果:對(duì)于高頻次查詢,可以將查詢結(jié)果緩存到內(nèi)存中,避免每次查詢都去數(shù)據(jù)庫中查找。
  • 應(yīng)用層緩存:使用 Redis 或 Memcached 等緩存系統(tǒng),將一些常用數(shù)據(jù)緩存在內(nèi)存中,從而減少數(shù)據(jù)庫訪問頻率。

在實(shí)際業(yè)務(wù)中,緩存是提高系統(tǒng)性能的常用手段,特別是對(duì)于高頻訪問的熱點(diǎn)數(shù)據(jù),通過將其存儲(chǔ)在緩存中,可以減少數(shù)據(jù)庫查詢的次數(shù)和壓力,提高響應(yīng)速度。

業(yè)務(wù)場(chǎng)景

假設(shè)我們有一個(gè)電商平臺(tái),用戶在瀏覽商品詳情時(shí),頻繁地查詢商品的基本信息(如價(jià)格、庫存、描述等)。由于商品信息變化較少,而查詢請(qǐng)求頻繁,因此將商品信息緩存起來能夠有效提高系統(tǒng)的性能。

我們使用 Redis 作為緩存數(shù)據(jù)庫,常見的做法是:當(dāng)查詢某個(gè)商品時(shí),首先檢查緩存中是否存在該商品的詳情,如果存在,則直接返回緩存中的數(shù)據(jù);如果緩存中沒有,則從數(shù)據(jù)庫中查詢,并將查詢結(jié)果存入緩存中,以備下次使用。

解決方案

  • 使用 Redis 存儲(chǔ)商品信息。
  • 設(shè)置適當(dāng)?shù)倪^期時(shí)間(TTL,Time To Live),避免緩存數(shù)據(jù)過期。
  • 使用適當(dāng)?shù)木彺娓虏呗裕ɡ纾好看胃律唐沸畔r(shí)更新緩存)。

代碼示例

1. 設(shè)置 Redis 緩存

首先,使用 Redis 的客戶端庫(如 redis-py)連接 Redis 服務(wù)。假設(shè)商品信息表為 Products,有字段 ProductIDProductNamePriceStockDescription。

# 安裝 Redis 客戶端
pip install redis

2. 商品查詢和緩存邏輯

import redis
import mysql.connector
import json
# 連接 Redis
redis_client = redis.StrictRedis(host='localhost', port=6379, db=0, decode_responses=True)
# 連接 MySQL 數(shù)據(jù)庫
def get_db_connection():
    return mysql.connector.connect(
        host="localhost",
        user="root",
        password="password",
        database="ecommerce"
    )
# 獲取商品詳情
def get_product_details(product_id):
    # 檢查緩存
    cached_product = redis_client.get(f"product:{product_id}")
    if cached_product:
        print("從緩存中獲取商品信息")
        return json.loads(cached_product)  # 反序列化 JSON 數(shù)據(jù)
    # 如果緩存中沒有,查詢數(shù)據(jù)庫
    print("從數(shù)據(jù)庫中獲取商品信息")
    connection = get_db_connection()
    cursor = connection.cursor(dictionary=True)
    cursor.execute("SELECT * FROM Products WHERE ProductID = %s", (product_id,))
    product = cursor.fetchone()
    # 如果商品存在,緩存到 Redis 中
    if product:
        redis_client.setex(f"product:{product_id}", 3600, json.dumps(product))  # 緩存 1 小時(shí)
    cursor.close()
    connection.close()
    return product
# 更新商品信息并更新緩存
def update_product_details(product_id, name, price, stock, description):
    # 更新數(shù)據(jù)庫
    connection = get_db_connection()
    cursor = connection.cursor()
    cursor.execute("""
        UPDATE Products
        SET ProductName = %s, Price = %s, Stock = %s, Description = %s
        WHERE ProductID = %s
    """, (name, price, stock, description, product_id))
    connection.commit()
    cursor.close()
    connection.close()
    # 更新緩存
    updated_product = {
        "ProductID": product_id,
        "ProductName": name,
        "Price": price,
        "Stock": stock,
        "Description": description
    }
    redis_client.setex(f"product:{product_id}", 3600, json.dumps(updated_product))  # 緩存 1 小時(shí)
# 示例:查詢商品 101 的信息
product_info = get_product_details(101)
print(product_info)
# 示例:更新商品 101 的信息
update_product_details(101, "New Product Name", 199.99, 50, "Updated description")

代碼說明

  • 連接 Redis 和 MySQL: 使用 redis-py 連接 Redis,使用 mysql.connector 連接 MySQL 數(shù)據(jù)庫。
  • 查詢商品: 在 get_product_details 方法中,我們首先查詢 Redis 緩存,看是否已經(jīng)緩存了商品信息。如果緩存中存在,則直接返回緩存中的數(shù)據(jù);如果緩存中沒有,則從 MySQL 數(shù)據(jù)庫中查詢,并將查詢結(jié)果緩存到 Redis 中。
  • 更新商品信息: 當(dāng)商品信息發(fā)生變化時(shí)(例如商品名稱、價(jià)格、庫存等更新),我們?cè)跀?shù)據(jù)庫中更新商品信息后,同時(shí)更新 Redis 緩存,以確保緩存數(shù)據(jù)的最新性。
  • 緩存設(shè)置過期時(shí)間: 使用 setex 方法將商品信息緩存到 Redis 中,并為緩存數(shù)據(jù)設(shè)置過期時(shí)間(TTL)。這樣可以避免緩存過期數(shù)據(jù)的存在。

進(jìn)一步優(yōu)化

  • 緩存穿透: 在查詢時(shí),除了檢查緩存是否存在外,還可以添加一些防止緩存穿透的機(jī)制,如查詢數(shù)據(jù)庫時(shí)檢查是否存在該商品。如果商品不存在,可以將其設(shè)置為 None 或空值,避免多次查詢數(shù)據(jù)庫。
  • 緩存淘汰策略: Redis 有多種緩存淘汰策略(如 LRU、LFU),可以根據(jù)實(shí)際業(yè)務(wù)需求配置 Redis 實(shí)例的緩存策略,確保熱點(diǎn)數(shù)據(jù)可以長(zhǎng)時(shí)間保持在緩存中。
  • 異步更新緩存: 在高并發(fā)的場(chǎng)景下,更新緩存的操作可能導(dǎo)致性能問題,可以使用隊(duì)列和異步處理來優(yōu)化緩存更新的時(shí)機(jī),避免頻繁更新緩存。

小結(jié)一下

通過使用 Redis 緩存,電商平臺(tái)能夠有效提高查詢商品信息的性能,減輕數(shù)據(jù)庫負(fù)擔(dān)。根據(jù)業(yè)務(wù)需求,我們可以進(jìn)一步優(yōu)化緩存策略和更新機(jī)制。

10. 并行查詢與并發(fā)

  • 啟用并行查詢:SQL Server 允許在查詢中使用多個(gè) CPU 核心來并行處理。適當(dāng)調(diào)整并行查詢的設(shè)置(如 max degree of parallelism)可以提高查詢性能,尤其是在處理大量數(shù)據(jù)時(shí)。
  • 優(yōu)化鎖策略:確保數(shù)據(jù)庫的鎖策略合理,避免長(zhǎng)時(shí)間的鎖競(jìng)爭(zhēng)??梢允褂眯屑?jí)鎖而不是表級(jí)鎖,減少阻塞。

在高并發(fā)場(chǎng)景下,使用并行查詢可以顯著提升數(shù)據(jù)查詢的速度。并行查詢的核心思想是將復(fù)雜的查詢拆分成多個(gè)子任務(wù),利用多個(gè) CPU 核心同時(shí)處理這些子任務(wù),從而提高整體查詢性能。并發(fā)則是指在多個(gè)任務(wù)之間進(jìn)行切換,使得 CPU 更高效地利用,在某些場(chǎng)景下,通過并發(fā)執(zhí)行多個(gè)查詢?nèi)蝿?wù)可以實(shí)現(xiàn)較高的性能。

業(yè)務(wù)場(chǎng)景

假設(shè)我們有一個(gè)電商平臺(tái),其中存儲(chǔ)了大量的訂單數(shù)據(jù)。用戶查詢訂單數(shù)據(jù)時(shí),可能涉及到多個(gè)表的聯(lián)接、多個(gè)條件的篩選等復(fù)雜的查詢操作。為了提高查詢性能,我們可以通過并行查詢和并發(fā)的方式,針對(duì)不同的查詢?nèi)蝿?wù)進(jìn)行優(yōu)化。

例如,查詢訂單數(shù)據(jù)時(shí),查詢條件包括訂單狀態(tài)、訂單日期范圍和用戶 ID 等。我們將該查詢拆分為多個(gè)并行查詢,分別查詢不同的條件,再將結(jié)果合并返回。

解決方案

  • 并行查詢: 將查詢?nèi)蝿?wù)拆分成多個(gè)子任務(wù),利用多線程或者多進(jìn)程并行執(zhí)行每個(gè)子任務(wù)。
  • 并發(fā)查詢: 使用異步 IO 或者線程池來并發(fā)執(zhí)行多個(gè)查詢操作。

我們將使用 Python 的 concurrent.futures 庫來實(shí)現(xiàn)并行查詢,并利用 MySQL 數(shù)據(jù)庫來執(zhí)行查詢操作。

代碼示例

1. 并行查詢

我們將查詢條件分為多個(gè)部分,并行地執(zhí)行查詢操作。例如:分別查詢訂單狀態(tài)為 Completed 和 Pending 的訂單數(shù)據(jù),并行查詢。

# 安裝 MySQL 客戶端庫
pip install mysql-connector-python
import mysql.connector
from concurrent.futures import ThreadPoolExecutor
import time
# 連接 MySQL 數(shù)據(jù)庫
def get_db_connection():
    return mysql.connector.connect(
        host="localhost",
        user="root",
        password="123123",
        database="VGDB"
    )
# 執(zhí)行查詢:查詢訂單狀態(tài)為指定狀態(tài)的訂單
def query_orders_by_status(status):
    connection = get_db_connection()
    cursor = connection.cursor(dictionary=True)
    query = "SELECT * FROM Orders WHERE OrderStatus = %s"
    cursor.execute(query, (status,))
    result = cursor.fetchall()
    cursor.close()
    connection.close()
    return result
# 執(zhí)行并行查詢
def fetch_orders():
    statuses = ['Completed', 'Pending']  # 定義我們需要查詢的訂單狀態(tài)
    # 使用 ThreadPoolExecutor 并行查詢
    with ThreadPoolExecutor(max_workers=2) as executor:
        # 提交查詢?nèi)蝿?wù)
        futures = [executor.submit(query_orders_by_status, status) for status in statuses]
        # 獲取查詢結(jié)果
        results = [future.result() for future in futures]
    return results
# 示例:執(zhí)行查詢
if __name__ == "__main__":
    start_time = time.time()
    orders = fetch_orders()
    print("查詢結(jié)果:", orders)
    print(f"查詢用時(shí): {time.time() - start_time}秒")

代碼說明

  • query_orders_by_status:該方法執(zhí)行數(shù)據(jù)庫查詢,查詢指定狀態(tài)的訂單。
  • fetch_orders:該方法使用 ThreadPoolExecutor 來并行執(zhí)行多個(gè)查詢?nèi)蝿?wù)。在這里,我們將訂單狀態(tài) Completed 和 Pending 分別作為任務(wù)提交到線程池中并行查詢。
  • ThreadPoolExecutor:我們創(chuàng)建了一個(gè)最大工作線程數(shù)為 2 的線程池,并使用 submit 提交查詢?nèi)蝿?wù)。每個(gè)查詢會(huì)在一個(gè)獨(dú)立的線程中執(zhí)行。
  • future.result():獲取并行查詢?nèi)蝿?wù)的返回結(jié)果。

2. 并發(fā)查詢

我們可以通過異步查詢或多線程來執(zhí)行并發(fā)查詢,適用于數(shù)據(jù)庫查詢不會(huì)互相依賴的情況。

import asyncio
import mysql.connector
from concurrent.futures import ThreadPoolExecutor
# 異步查詢數(shù)據(jù)庫
async def query_orders_by_status_async(status, loop):
    # 使用 ThreadPoolExecutor 讓數(shù)據(jù)庫查詢異步執(zhí)行
    result = await loop.run_in_executor(None, query_orders_by_status, status)
    return result
# 執(zhí)行查詢:查詢訂單狀態(tài)為指定狀態(tài)的訂單
def query_orders_by_status(status):
    connection = get_db_connection()
    cursor = connection.cursor(dictionary=True)
    query = "SELECT * FROM Orders WHERE OrderStatus = %s"
    cursor.execute(query, (status,))
    result = cursor.fetchall()
    cursor.close()
    connection.close()
    return result
# 異步并發(fā)查詢
async def fetch_orders_concurrently():
    loop = asyncio.get_event_loop()
    statuses = ['Completed', 'Pending', 'Shipped']  # 查詢多個(gè)狀態(tài)的訂單
    tasks = [query_orders_by_status_async(status, loop) for status in statuses]
    orders = await asyncio.gather(*tasks)  # 等待所有任務(wù)完成
    return orders
# 示例:執(zhí)行并發(fā)查詢
if __name__ == "__main__":
    start_time = time.time()
    asyncio.run(fetch_orders_concurrently())
    print(f"查詢用時(shí): {time.time() - start_time}秒")

代碼說明

  • query_orders_by_status_async:此方法使用 loop.run_in_executor 來將數(shù)據(jù)庫查詢操作異步化。通過這種方式,盡管數(shù)據(jù)庫查詢是阻塞操作,我們可以并發(fā)地執(zhí)行多個(gè)查詢。
  • asyncio.gather:將多個(gè)異步任務(wù)組合在一起,等待所有任務(wù)完成后再返回結(jié)果。
  • asyncio.run:用于啟動(dòng)事件循環(huán)并執(zhí)行異步查詢。

進(jìn)一步優(yōu)化

  • 線程池大小:根據(jù)業(yè)務(wù)需求,調(diào)整 ThreadPoolExecutor 中的 max_workers 參數(shù)。如果任務(wù)非常多,可以適當(dāng)增加線程池大小,但要注意不要過多,以免影響系統(tǒng)性能。
  • 連接池:對(duì)于數(shù)據(jù)庫操作,可以使用數(shù)據(jù)庫連接池來優(yōu)化數(shù)據(jù)庫連接的管理。這樣可以避免每次查詢都建立新的數(shù)據(jù)庫連接,提高性能。
  • 分頁查詢:如果查詢結(jié)果非常龐大,可以通過分頁查詢來減小每次查詢的數(shù)據(jù)量,進(jìn)一步提高性能。

總結(jié)

  • 并行查詢:通過將查詢?nèi)蝿?wù)拆分為多個(gè)子任務(wù),并行地處理,可以顯著提高查詢性能。
  • 并發(fā)查詢:適用于在多個(gè)查詢?nèi)蝿?wù)之間進(jìn)行并發(fā)執(zhí)行,無需等待每個(gè)查詢?nèi)蝿?wù)逐個(gè)完成,可以加快整體查詢速度。

通過結(jié)合并行查詢和并發(fā)查詢策略,我們可以顯著提高電商平臺(tái)或其他業(yè)務(wù)系統(tǒng)的查詢響應(yīng)速度,尤其是在高并發(fā)的環(huán)境中,保證系統(tǒng)的高效性。

11. SQL Server 實(shí)例優(yōu)化

  • 定期重啟 SQL Server 實(shí)例:如果 SQL Server 長(zhǎng)時(shí)間運(yùn)行,可能會(huì)導(dǎo)致緩存過多或內(nèi)存泄漏等問題,定期重啟可以幫助釋放資源并優(yōu)化性能。
  • 啟用壓縮:SQL Server 提供數(shù)據(jù)壓縮功能,可以節(jié)省存儲(chǔ)空間,并提高查詢性能,尤其是在讀取數(shù)據(jù)時(shí)。

SQL Server 實(shí)例優(yōu)化是提升數(shù)據(jù)庫整體性能的一個(gè)重要方面。在大型業(yè)務(wù)系統(tǒng)中,SQL Server 的性能往往直接影響到整個(gè)應(yīng)用的響應(yīng)速度和穩(wěn)定性。實(shí)例優(yōu)化包括硬件資源的合理配置、SQL Server 配置參數(shù)的優(yōu)化、內(nèi)存和 I/O 管理、查詢優(yōu)化以及監(jiān)控等方面。

假設(shè)我們有一個(gè)在線電商平臺(tái),業(yè)務(wù)量很大,包含大量的商品、訂單、用戶等數(shù)據(jù)。我們需要對(duì) SQL Server 實(shí)例進(jìn)行優(yōu)化,以確保高效的查詢性能、穩(wěn)定的事務(wù)處理和快速的數(shù)據(jù)讀取能力。

1. 硬件配置優(yōu)化

SQL Server 實(shí)例的性能在很大程度上取決于底層硬件的配置,尤其是內(nèi)存、CPU、磁盤等資源。

  • 內(nèi)存:SQL Server 是一個(gè)內(nèi)存密集型應(yīng)用,內(nèi)存越大,緩存命中率越高,查詢性能也越好。
  • CPU:更多的 CPU 核心可以處理更多并發(fā)請(qǐng)求。
  • 磁盤:SSD 驅(qū)動(dòng)器在磁盤 I/O 性能方面要優(yōu)于傳統(tǒng)硬盤,尤其是在大型數(shù)據(jù)庫的讀寫操作中。

2. SQL Server 配置優(yōu)化

SQL Server 提供了很多配置參數(shù)來調(diào)整實(shí)例的行為,可以通過這些參數(shù)來優(yōu)化性能。

配置參數(shù)示例

  • max degree of parallelism:控制 SQL Server 查詢的并行度。通過合理設(shè)置并行度,可以提高多核 CPU 系統(tǒng)的查詢效率。
  • max server memory:限制 SQL Server 使用的最大內(nèi)存量,防止 SQL Server 占用過多內(nèi)存導(dǎo)致操作系統(tǒng)性能下降。
  • cost threshold for parallelism:設(shè)置查詢執(zhí)行的代價(jià)閾值,只有當(dāng)查詢的成本超過該值時(shí),SQL Server 才會(huì)使用并行執(zhí)行。

3. 索引優(yōu)化

索引是提高查詢性能的關(guān)鍵,可以根據(jù)業(yè)務(wù)場(chǎng)景為頻繁查詢的字段創(chuàng)建索引。但過多的索引會(huì)影響插入、更新和刪除操作的性能,因此需要在查詢性能和維護(hù)成本之間找到平衡。

4. 查詢優(yōu)化

對(duì)于大型業(yè)務(wù)系統(tǒng),查詢優(yōu)化尤為重要。優(yōu)化查詢可以減少數(shù)據(jù)庫的負(fù)擔(dān),提升響應(yīng)速度。

業(yè)務(wù)場(chǎng)景

假設(shè)電商平臺(tái)需要處理大量的訂單數(shù)據(jù),查詢常常涉及到聯(lián)接多個(gè)表,比如查詢某個(gè)用戶在某個(gè)時(shí)間段內(nèi)的所有訂單。我們可以通過優(yōu)化 SQL 查詢來提高查詢速度。

代碼示例

1. 設(shè)置 SQL Server 實(shí)例配置參數(shù)

在 SQL Server 實(shí)例中,我們可以通過以下 T-SQL 語句來設(shè)置一些基本的優(yōu)化參數(shù):

-- 設(shè)置最大內(nèi)存使用量為 16 GB
EXEC sp_configure 'max server memory', 16384;  -- 單位:MB
RECONFIGURE;
-- 設(shè)置最大并行度為 8 核 CPU
EXEC sp_configure 'max degree of parallelism', 8;
RECONFIGURE;
-- 設(shè)置查詢的成本閾值為 10
EXEC sp_configure 'cost threshold for parallelism', 10;
RECONFIGURE;

2. 查詢優(yōu)化

為了提高查詢性能,可以在查詢時(shí)使用以下技巧:

  • 避免 SELECT *,僅選擇需要的字段。
  • 使用 JOIN 替代子查詢,避免不必要的嵌套查詢。
  • 創(chuàng)建適當(dāng)?shù)乃饕齺砑铀俨樵儭?/li>
  • 利用分頁查詢減少單次查詢的數(shù)據(jù)量。

以下是一個(gè)優(yōu)化后的查詢示例:

-- 假設(shè)我們需要查詢某個(gè)用戶的訂單信息,優(yōu)化后的 SQL 查詢
SELECT o.OrderID, o.OrderDate, o.TotalAmount, u.UserName
FROM Orders o
JOIN Users u ON o.UserID = u.UserID
WHERE o.OrderDate BETWEEN '2024-01-01' AND '2024-12-31'
  AND u.UserID = 12345
ORDER BY o.OrderDate DESC;

3. 索引優(yōu)化

為了優(yōu)化查詢,我們可以在 Orders 表的 UserIDOrderDate 字段上創(chuàng)建索引:

-- 為 UserID 列創(chuàng)建索引
CREATE INDEX idx_user_id ON Orders(UserID);
-- 為 OrderDate 列創(chuàng)建索引
CREATE INDEX idx_order_date ON Orders(OrderDate);
-- 為 UserID 和 OrderDate 的組合創(chuàng)建復(fù)合索引
CREATE INDEX idx_user_order_date ON Orders(UserID, OrderDate);

4. 數(shù)據(jù)庫備份和維護(hù)

定期備份和維護(hù)數(shù)據(jù)庫可以確保系統(tǒng)在高負(fù)載下保持高效。定期的數(shù)據(jù)庫優(yōu)化任務(wù)包括:

  • 備份數(shù)據(jù)。
  • 更新統(tǒng)計(jì)信息。
  • 重建索引。

以下是一個(gè)定期重建索引的示例:

-- 重建所有表的索引
ALTER INDEX ALL ON Orders REBUILD;
ALTER INDEX ALL ON Users REBUILD;

5. 使用 SQL Server 的性能監(jiān)控工具

SQL Server 提供了一些性能監(jiān)控工具來幫助識(shí)別性能瓶頸。例如,SQL Server Profiler 和 Dynamic Management Views (DMVs) 可以幫助我們實(shí)時(shí)監(jiān)控 SQL Server 實(shí)例的性能,并根據(jù)實(shí)際情況進(jìn)行調(diào)優(yōu)。

-- 查看 SQL Server 實(shí)例當(dāng)前的資源使用情況
SELECT * FROM sys.dm_exec_requests;
-- 查看 SQL Server 實(shí)例的內(nèi)存使用情況
SELECT * FROM sys.dm_os_memory_clerks;
-- 查看 SQL Server 實(shí)例的磁盤 I/O 使用情況
SELECT * FROM sys.dm_io_virtual_file_stats(NULL, NULL);

小結(jié)一下

  • 硬件優(yōu)化:合理配置 CPU、內(nèi)存和磁盤,提升 SQL Server 實(shí)例的性能。
  • 實(shí)例配置優(yōu)化:通過配置 SQL Server 的參數(shù),如內(nèi)存限制、并行度等,優(yōu)化性能。
  • 索引優(yōu)化:合理設(shè)計(jì)索引結(jié)構(gòu),提高查詢效率。
  • 查詢優(yōu)化:使用高效的 SQL 查詢語句,避免不必要的計(jì)算和 I/O 操作。
  • 定期維護(hù)和備份:定期進(jìn)行數(shù)據(jù)庫維護(hù)和備份,確保系統(tǒng)穩(wěn)定運(yùn)行。

通過對(duì) SQL Server 實(shí)例的優(yōu)化,可以顯著提升數(shù)據(jù)庫的性能,確保電商平臺(tái)在高并發(fā)、高負(fù)載的情況下仍能保持高效響應(yīng)。

最后

以上11種優(yōu)化方案供你參考,優(yōu)化 SQL Server 數(shù)據(jù)庫性能得從多個(gè)方面著手,包括硬件配置、數(shù)據(jù)庫結(jié)構(gòu)、查詢優(yōu)化、索引管理、分區(qū)分表、并行處理等。通過合理的索引、查詢優(yōu)化、數(shù)據(jù)分區(qū)等技術(shù),可以在數(shù)據(jù)量增大時(shí)保持較好的性能。同時(shí),定期進(jìn)行數(shù)據(jù)庫維護(hù)和清理,保證數(shù)據(jù)庫高效運(yùn)行。關(guān)注威哥愛編程,V哥做你的技術(shù)門童。

到此這篇關(guān)于SQL Server 數(shù)據(jù)太多如何優(yōu)化的文章就介紹到這了,更多相關(guān)SQL Server 數(shù)據(jù)優(yōu)化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論

欧美日韩中文字幕欧美| 国产精品黄片免费在线观看| 亚洲最大免费在线观看| 自拍偷拍日韩欧美一区二区| 男人天堂最新地址av| 青青草在观免费国产精品| jiuse91九色视频| 国产精品系列在线观看一区二区| av高潮迭起在线观看| 天天日天天添天天爽| 日本熟妇喷水xxx| 国产一区自拍黄视频免费观看| 亚洲在线一区二区欧美| 中文字幕在线视频一区二区三区| 2018在线福利视频| 黄工厂精品视频在线观看| 55夜色66夜色国产精品站| 成人精品在线观看视频| 亚洲 图片 欧美 图片| 午夜福利人人妻人人澡人人爽| 中文字母永久播放1区2区3区| 国产在线91观看免费观看| 大陆av手机在线观看| 亚洲粉嫩av一区二区三区| 少妇与子乱在线观看| 亚洲av天堂在线播放| tube69日本少妇| 在线播放一区二区三区Av无码| av在线免费中文字幕| 亚洲综合色在线免费观看| 人妻素人精油按摩中出| 97国产福利小视频合集| 88成人免费av网站| 动漫美女的小穴视频| 九九视频在线精品播放| 国产精品久久久久网| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 9久在线视频只有精品| 国产亚洲欧美另类在线观看| 香蕉片在线观看av| 沈阳熟妇28厘米大战黑人| 国产一区av澳门在线观看| 馒头大胆亚洲一区二区| 天天干天天插天天谢| 一区二区三区的久久的蜜桃的视频 | 一区二区视频在线观看视频在线| 91一区精品在线观看| 欧洲黄页网免费观看| 午夜的视频在线观看| 亚洲区欧美区另类最新章节| 亚洲图片偷拍自拍区| 大陆精品一区二区三区久久| 2021天天色天天干| 国产亚州色婷婷久久99精品| 中文字幕综合一区二区| 换爱交换乱高清大片| 1000部国产精品成人观看视频| 色av色婷婷人妻久久久精品高清| 全国亚洲男人的天堂| 扒开腿挺进肉嫩小18禁视频| 噜噜色噜噜噜久色超碰| 亚洲福利精品福利精品福利| 日韩近亲视频在线观看| 国产精品久久9999| 午夜av一区二区三区| 热久久只有这里有精品| 国产伊人免费在线播放| 亚洲无码一区在线影院| 啊啊好大好爽啊啊操我啊啊视频| 偷拍自拍视频图片免费| 啪啪啪18禁一区二区三区| 国产黄色片蝌蚪九色91| 97瑟瑟超碰在线香蕉| 国产精品视频欧美一区二区 | 三级av中文字幕在线观看| 国产三级片久久久久久久 | 中文字幕免费福利视频6| 精品91高清在线观看| 在线观看亚洲人成免费网址| 无忧传媒在线观看视频| 午夜激情久久不卡一区二区| 亚洲伊人av天堂有码在线| brazzers欧熟精品系列| 五月天中文字幕内射| 家庭女教师中文字幕在线播放| www骚国产精品视频| 91国偷自产一区二区三区精品| 偷拍自拍 中文字幕| 国产亚洲欧美视频网站| 2020av天堂网在线观看| 91传媒一区二区三区| 福利午夜视频在线合集| 97国产在线观看高清| 中文字幕最新久久久| 亚洲成高清a人片在线观看| 亚洲人人妻一区二区三区| www,久久久,com| 性感美女诱惑福利视频| 91免费福利网91麻豆国产精品| 国产不卡av在线免费| 日本xx片在线观看| 青青草人人妻人人妻| 99精品免费久久久久久久久a| 久青青草视频手机在线免费观看 | 日韩精品一区二区三区在线播放| 国产日本精品久久久久久久| 久久久精品999精品日本| 日本乱人一区二区三区| 无套猛戳丰满少妇人妻| 狠狠操狠狠操免费视频| 热思思国产99re| 日韩a级黄色小视频| 亚洲高清一区二区三区视频在线| 把腿张开让我插进去视频| 一区二区久久成人网| 天堂av在线最新版在线| 青青操免费日综合视频观看| 天天操天天射天天操天天天| 这里只有精品双飞在线播放| 中文字幕免费在线免费| 中文字幕第一页国产在线| 男生舔女生逼逼视频| 偷偷玩弄新婚人妻h视频| 天天日天天操天天摸天天舔| 亚洲成人免费看电影| 亚洲天堂第一页中文字幕| 亚洲免费成人a v| 国产+亚洲+欧美+另类| 亚洲一区二区人妻av| 欧美香蕉人妻精品一区二区| 国产精品久久综合久久| 女同久久精品秋霞网| 激情国产小视频在线| 国产卡一卡二卡三乱码手机| 男人和女人激情视频| 天天躁夜夜躁日日躁a麻豆| 偷拍3456eee| 快插进小逼里大鸡吧视频| 亚洲成人激情av在线| aⅴ精产国品一二三产品| 91she九色精品国产| wwwxxx一级黄色片| 91av精品视频在线| 福利国产视频在线观看| 午夜福利资源综合激情午夜福利资| 小穴多水久久精品免费看| 男女啪啪啪啪啪的网站| 国产91嫩草久久成人在线视频| 在线免费观看亚洲精品电影| 91久久综合男人天堂| 精品久久久久久高潮| 视频 一区二区在线观看| 日韩美女精品视频在线观看网站| 91九色porny蝌蚪国产成人| 亚洲av日韩av网站| 曰本无码人妻丰满熟妇啪啪| 日本免费一级黄色录像 | 亚洲一区二区三区五区| 2021年国产精品自拍| 天天做天天干天天操天天射| 久久久91蜜桃精品ad| 欧美成人精品欧美一级黄色| 97人人妻人人澡人人爽人人精品| 成年人黄色片免费网站| 亚洲av日韩av第一区二区三区| 精品人妻伦一二三区久| 亚洲国产中文字幕啊啊啊不行了 | 最新的中文字幕 亚洲| 男人在床上插女人视频| 99一区二区在线观看| 一区二区熟女人妻视频| 粉嫩av蜜乳av蜜臀| 九色视频在线观看免费| 免费在线播放a级片| 中文字幕一区二区人妻电影冢本| 天天射夜夜操综合网| 在线观看免费视频色97| 激情国产小视频在线| 性色蜜臀av一区二区三区| 超pen在线观看视频公开97| 日本熟妇色熟妇在线观看| AV天堂一区二区免费试看| 一区二区三区在线视频福利| 91大神福利视频网| 欧美视频中文一区二区三区| 国产精品三级三级三级| 少妇人妻100系列| 99热99这里精品6国产| 又色又爽又黄的美女裸体| 久久久久久国产精品| av无限看熟女人妻另类av | 北条麻妃高跟丝袜啪啪| 久草视频中文字幕在线观看| 色婷婷综合激情五月免费观看| okirakuhuhu在线观看| 国产超码片内射在线| 亚洲在线免费h观看网站| 精品久久久久久久久久中文蒉| 久久久麻豆精亚洲av麻花| 日本韩国亚洲综合日韩欧美国产 | 免费av岛国天堂网站| 大鸡巴后入爆操大屁股美女| 玩弄人妻熟妇性色av少妇| 免费在线播放a级片| 日韩av熟妇在线观看| 欧美中文字幕一区最新网址| 熟妇一区二区三区高清版| 中国无遮挡白丝袜二区精品 | 亚洲天堂精品久久久| 久久久精品999精品日本| 亚洲国产第一页在线观看| 青青青青草手机在线视频免费看| 午夜免费观看精品视频| 精品美女久久久久久| 国产精品视频男人的天堂| 天天想要天天操天天干| 和邻居少妇愉情中文字幕| 十八禁在线观看地址免费| 国产午夜男女爽爽爽爽爽视频| 91啪国自产中文字幕在线| 国产女人被做到高潮免费视频| 青青青激情在线观看视频| 又色又爽又黄又刺激av网站| 一区二区三区视频,福利一区二区| 又色又爽又黄又刺激av网站| 亚洲码av无色中文| 五月天色婷婷在线观看视频免费| 亚洲精品国产综合久久久久久久久| 99热久久这里只有精品8| 2021最新热播中文字幕| 亚洲av色香蕉一区二区三区| 欧美精品中文字幕久久二区| 亚洲精品在线资源站| 久久免看30视频口爆视频| 91精品激情五月婷婷在线| 蜜臀av久久久久蜜臀av麻豆| 国产又粗又硬又大视频| 欧美地区一二三专区| 综合一区二区三区蜜臀| 丰满的子国产在线观看| 国产成人综合一区2区| 日韩在线视频观看有码在线| 97欧洲一区二区精品免费| 青青草亚洲国产精品视频| 57pao国产一区二区| 青青草国内在线视频精选| 护士小嫩嫩又紧又爽20p| 五色婷婷综合狠狠爱| 亚洲综合在线观看免费| 国产精品自拍偷拍a| 天天日天天添天天爽| 欲乱人妻少妇在线视频裸| av在线免费观看亚洲天堂| 成人福利视频免费在线| 亚洲av日韩精品久久久| 国产综合高清在线观看| 欧美日韩亚洲国产无线码| 成人精品在线观看视频| 99精品国自产在线人| 天天做天天干天天舔| 亚洲 图片 欧美 图片| 亚洲1069综合男同| 亚洲av日韩精品久久久| 一区二区三区视频,福利一区二区| 欧美亚洲偷拍自拍色图| 成人动漫大肉棒插进去视频| 18禁无翼鸟成人在线| 亚洲av一妻不如妾| 中文字幕亚洲久久久| 青青草精品在线视频观看| 中文字幕 人妻精品| 99热国产精品666| 中国熟女@视频91| 亚洲欧美另类手机在线| 一区二区视频视频视频| 四虎永久在线精品免费区二区| av老司机精品在线观看| 亚洲精品乱码久久久久久密桃明| 精品人妻伦一二三区久| 91精品啪在线免费| 国产1区,2区,3区| 免费观看成年人视频在线观看| 久久www免费人成一看片| 18禁免费av网站| 日日操综合成人av| av久久精品北条麻妃av观看| 欧美精产国品一二三产品区别大吗| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 班长撕开乳罩揉我胸好爽| 六月婷婷激情一区二区三区| 五十路丰满人妻熟妇| 免费人成黄页网站在线观看国产| 久久久久久97三级| 亚洲自拍偷拍综合色| 人妻自拍视频中国大陆| 日本熟妇丰满厨房55| 亚洲精品无码久久久久不卡| 日本午夜福利免费视频| 91精品啪在线免费| www天堂在线久久| 偷拍3456eee| 国产在线免费观看成人| 色婷婷精品大在线观看| 久草视频首页在线观看| av成人在线观看一区| 一区二区在线观看少妇| 免费观看成年人视频在线观看| av中文字幕国产在线观看| 久草视频在线一区二区三区资源站 | 精彩视频99免费在线| 欧美亚洲一二三区蜜臀| 操日韩美女视频在线免费看| 国产精品黄页网站视频| 欧美老妇精品另类不卡片| 淫秽激情视频免费观看| 亚洲国产精品美女在线观看| 免费观看丰满少妇做受| 999九九久久久精品| 91小伙伴中女熟女高潮| 日韩av大胆在线观看| 女生自摸在线观看一区二区三区 | 精品黑人巨大在线一区| 精品一区二区三四区| 午夜精品福利91av| 日日操夜夜撸天天干| 在线免费观看国产精品黄色| 欧美激情电影免费在线| 1769国产精品视频免费观看| 97香蕉碰碰人妻国产樱花| 国产免费高清视频视频| 91超碰青青中文字幕| 精品亚洲中文字幕av| 最近中文字幕国产在线| 欧美精品黑人性xxxx| 日本在线不卡免费视频| 日韩欧美一级黄片亚洲| 男人的网址你懂的亚洲欧洲av| 天天摸天天干天天操科普| 青青尤物在线观看视频网站| 美女小视频网站在线| 国产精品久久久久网| 亚洲第17页国产精品| 日本精品视频不卡一二三| 自拍偷拍 国产资源| 亚洲精品ww久久久久久| 国产精品污污污久久| 久久精品国产999| 好男人视频在线免费观看网站| 国产日韩一区二区在线看| 国产成人精品亚洲男人的天堂| 亚洲国产精品美女在线观看 | 日韩在线中文字幕色| h国产小视频福利在线观看| 亚洲熟妇无码一区二区三区| av老司机精品在线观看| 人妻丝袜诱惑我操她视频| 亚洲在线免费h观看网站| 日韩午夜福利精品试看| 亚洲日本一区二区久久久精品| av无限看熟女人妻另类av| 国产精品手机在线看片| 成人色综合中文字幕| 硬鸡巴动态操女人逼视频| 91大神福利视频网| 亚洲 欧美 精品 激情 偷拍| 国产九色91在线观看精品| 绝色少妇高潮3在线观看| 亚洲国产美女一区二区三区软件| 国产麻豆剧传媒精品国产av蜜桃| 亚洲精品乱码久久久久久密桃明| av网址在线播放大全| 亚洲成a人片777777| 亚洲精品一区二区三区老狼| h国产小视频福利在线观看| 欧美性感尤物人妻在线免费看| 中文字幕高清免费在线人妻| 欧美国品一二三产区区别| 男人的天堂在线黄色| 国产91精品拍在线观看| 国产成人精品一区在线观看| 精品国产午夜视频一区二区| 亚洲成人情色电影在线观看| 精品久久久久久久久久中文蒉| 少妇人妻真实精品视频| 伊人综合aⅴ在线网| 久草视频 久草视频2| 视频 一区二区在线观看| 精品久久婷婷免费视频| 老司机在线精品福利视频| 成人av在线资源网站| 青青青国产免费视频| 中国黄色av一级片| 日韩美av高清在线| 精品美女久久久久久| 日韩熟女系列一区二区三区| 国产精品自拍视频大全| 韩国女主播精品视频网站| 少妇一区二区三区久久久| 偷拍自拍国产在线视频| 欧洲日韩亚洲一区二区三区 | 免费观看丰满少妇做受| 欧美精品免费aaaaaa| av欧美网站在线观看| chinese国产盗摄一区二区 | av在线资源中文字幕| av网址国产在线观看| 综合激情网激情五月五月婷婷| 国产综合视频在线看片| 自拍偷拍,中文字幕| 88成人免费av网站| 中文字幕在线观看国产片| 9色精品视频在线观看| 亚洲精品国产久久久久久| 成人av在线资源网站| 欧美黄片精彩在线免费观看| 久久久麻豆精亚洲av麻花| 99精品国产免费久久| 久久久久久久精品老熟妇| 久久亚洲天堂中文对白| 黄色成年网站午夜在线观看 | 国产精品中文av在线播放| 粉嫩小穴流水视频在线观看| 免费无码人妻日韩精品一区二区| 93精品视频在线观看| 国产黑丝高跟鞋视频在线播放 | 午夜在线观看岛国av,com| 不卡一区一区三区在线| av亚洲中文天堂字幕网| 青青草在观免费国产精品| 天天操天天插天天色| 久久综合老鸭窝色综合久久| 狠狠嗨日韩综合久久| 成人蜜臀午夜久久一区| 丰满的子国产在线观看| 一区二区三区的久久的蜜桃的视频| 成人乱码一区二区三区av| 日本xx片在线观看| 国产美女一区在线观看| 一区二区三区激情在线| 国产男女视频在线播放| 天天日天天干天天要| 亚洲中文字幕国产日韩| 国产在线拍揄自揄视频网站| 含骚鸡巴玩逼逼视频| 国产伊人免费在线播放| 色花堂在线av中文字幕九九| 婷婷午夜国产精品久久久| 精品一区二区三区欧美| 亚洲综合在线观看免费| 亚洲最大免费在线观看| 丰满的继坶3中文在线观看| 国产第一美女一区二区三区四区 | 国产亚洲精品视频合集| 国产真实乱子伦a视频| 日本少妇的秘密免费视频| 天天想要天天操天天干| 999久久久久999| 日本韩国亚洲综合日韩欧美国产| 中国黄片视频一区91| 亚洲精品国产在线电影| 欧美亚洲一二三区蜜臀| 第一福利视频在线观看| 成人午夜电影在线观看 久久| 51精品视频免费在线观看| av在线免费中文字幕| 丝袜长腿第一页在线| 中文乱理伦片在线观看| 中字幕人妻熟女人妻a62v网| 熟女人妻三十路四十路人妻斩| 中文字幕免费福利视频6| 亚洲欧美成人综合在线观看| 亚洲图库另类图片区| 大香蕉大香蕉在线有码 av| 亚洲av一妻不如妾| 日本裸体熟妇区二区欧美| 亚洲一级av大片免费观看| 欧美地区一二三专区| 伊人开心婷婷国产av| 日韩欧美一级黄片亚洲| 香港一级特黄大片在线播放| 毛片av在线免费看| 人妻久久久精品69系列| 国产精品大陆在线2019不卡| 亚洲欧美激情中文字幕| 中文字幕在线第一页成人| 女同互舔一区二区三区| 亚洲天堂av最新网址| 日本裸体熟妇区二区欧美| 日本一区精品视频在线观看| 熟女视频一区,二区,三区| 国产亚洲视频在线二区| 80电影天堂网官网| 99精品视频之69精品视频 | 黄色三级网站免费下载| 91欧美在线免费观看| 中文字幕一区二区三区人妻大片 | 全国亚洲男人的天堂| 日本三极片中文字幕| 色吉吉影音天天干天天操 | 亚洲成人线上免费视频观看| 亚洲天堂成人在线观看视频网站| 十八禁在线观看地址免费| 精品美女福利在线观看| 五十路人妻熟女av一区二区| 亚洲综合一区二区精品久久| 第一福利视频在线观看| 日本在线不卡免费视频| 亚洲伊人色一综合网| 丝袜肉丝一区二区三区四区在线 | 日日日日日日日日夜夜夜夜夜夜| 青青青视频手机在线观看| 天天射,天天操,天天说| 狠狠操狠狠操免费视频| 婷婷久久一区二区字幕网址你懂得 | 成人精品视频99第一页| 国产乱子伦一二三区| 日韩影片一区二区三区不卡免费| 91九色国产porny蝌蚪| 天堂av在线官网中文| 中文字幕—97超碰网| 在线国产精品一区二区三区| 欧美国产亚洲中英文字幕| 欧美日韩不卡一区不区二区| 免费观看国产综合视频| 97超碰最新免费在线观看| 天天操天天干天天插| 午夜久久久久久久99| 国产白嫩美女一区二区| 日曰摸日日碰夜夜爽歪歪| 97精品视频在线观看| 三级等保密码要求条款| 91在线免费观看成人| 制服丝袜在线人妻中文字幕| 少妇与子乱在线观看| 男人的天堂一区二区在线观看| 欧美中文字幕一区最新网址| 顶级尤物粉嫩小尤物网站| 亚洲欧美一卡二卡三卡| 欧美交性又色又爽又黄麻豆| 日韩欧美国产一区ab| 自拍偷拍日韩欧美亚洲| 亚洲一区二区三区久久午夜 | 免费看国产av网站| 黄色黄色黄片78在线| nagger可以指黑人吗| yy96视频在线观看| 99热这里只有精品中文| 五十路av熟女松本翔子| 精品美女在线观看视频在线观看| 日本男女操逼视频免费看| 大鸡巴操娇小玲珑的女孩逼| 久久久精品999精品日本| 婷婷午夜国产精品久久久| 97色视频在线观看| 97人妻夜夜爽二区欧美极品| 欧美精品激情在线最新观看视频| 亚洲 欧美 精品 激情 偷拍| 国产日韩欧美美利坚蜜臀懂色| 亚洲精品欧美日韩在线播放| 国产精品久久久久久久精品视频| 中国黄片视频一区91| 亚洲成人国产综合一区| 成人资源在线观看免费官网| 五月激情婷婷久久综合网| 蜜臀成人av在线播放| 亚洲综合一区二区精品久久| 97国产在线观看高清| 亚洲综合图片20p| 五月精品丁香久久久久福利社| 日本午夜爽爽爽爽爽视频在线观看| 天天干天天日天天谢综合156| 日韩一区二区电国产精品| 岛国青草视频在线观看| 成人性黑人一级av| 天天操天天插天天色| 92福利视频午夜1000看| 欧美亚洲自偷自拍 在线| 97资源人妻免费在线视频| 亚洲欧美一卡二卡三卡| 日本在线一区二区不卡视频| 可以在线观看的av中文字幕| 曰本无码人妻丰满熟妇啪啪| 午夜免费观看精品视频| 国内资源最丰富的网站| 国产视频一区在线观看| 免费费一级特黄真人片| 亚洲精品亚洲人成在线导航 | 97瑟瑟超碰在线香蕉| 91国内视频在线观看| 国产精品一二三不卡带免费视频| 丝袜长腿第一页在线| 久久美欧人妻少妇一区二区三区| 99热久久这里只有精品| 日本最新一二三区不卡在线| 福利一二三在线视频观看| 日本一区美女福利视频| 成人av在线资源网站| 日比视频老公慢点好舒服啊| 在线可以看的视频你懂的| 成人综合亚洲欧美一区| 91免费观看国产免费| av在线shipin| av完全免费在线观看av| 午夜蜜桃一区二区三区| 国产精品成人xxxx| 婷婷色国产黑丝少妇勾搭AV| 免费观看国产综合视频| 亚洲精品一区二区三区老狼| yellow在线播放av啊啊啊 | 亚洲欧美激情中文字幕| 国产卡一卡二卡三乱码手机| av视网站在线观看| 天天操夜夜操天天操天天操| 97国产在线av精品| 红桃av成人在线观看| 国产janese在线播放| 欧美精品国产综合久久| 在线免费91激情四射| caoporm超碰国产| 天天操天天射天天操天天天| 女同性ⅹxx女同h偷拍| 老司机免费视频网站在线看| 久精品人妻一区二区三区 | 国产精品一二三不卡带免费视频 | 大白屁股精品视频国产| 欧美xxx成人在线| 人妻丝袜榨强中文字幕| 国产黑丝高跟鞋视频在线播放| 欧美第一页在线免费观看视频| 国产一区自拍黄视频免费观看| 中文字幕免费福利视频6| 色婷婷久久久久swag精品| 欧美老妇精品另类不卡片| 亚洲 欧美 自拍 偷拍 在线| 中文乱理伦片在线观看| 天天摸天天亲天天舔天天操天天爽 | 97精品综合久久在线| 亚洲精品国产久久久久久| 二区中出在线观看老师 | 老司机福利精品免费视频一区二区| 91大神福利视频网| 亚洲特黄aaaa片| 女生自摸在线观看一区二区三区| 97香蕉碰碰人妻国产樱花| 91p0rny九色露脸熟女| 无码精品一区二区三区人 | nagger可以指黑人吗| av在线shipin| 性欧美日本大妈母与子| 五月天久久激情视频| 黑人大几巴狂插日本少妇| 最新欧美一二三视频| 亚洲高清国产拍青青草原| 亚洲综合在线视频可播放| 国产精品3p和黑人大战| 精品亚洲中文字幕av| 99热这里只有精品中文| 日韩美在线观看视频黄| 91精品国产91久久自产久强| 天天射夜夜操综合网| 色爱av一区二区三区| 久久精品美女免费视频| 天天色天天舔天天射天天爽| 国产欧美日韩第三页| 成熟丰满熟妇高潮xx×xx| 任你操任你干精品在线视频| 天天日夜夜干天天操| 青青操免费日综合视频观看| 日韩成人综艺在线播放| 亚洲高清国产自产av| 中文字幕日韩精品日本| 黄色大片男人操女人逼| 亚洲最大黄 嗯色 操 啊| 国产九色91在线视频| 在线免费观看日本伦理| 最新国产亚洲精品中文在线| 亚洲国产在人线放午夜| 亚洲av男人天堂久久| 免费啪啪啪在线观看视频| 天天日天天天天天天天天天天| 日韩不卡中文在线视频网站| 欧美黑人与人妻精品| 狠狠鲁狠狠操天天晚上干干| 日本黄色三级高清视频| 男人插女人视频网站| 亚洲国产成人av在线一区| 18禁精品网站久久| 天天干天天操天天摸天天射| 中文字幕—97超碰网| 天天干狠狠干天天操| 啊啊好大好爽啊啊操我啊啊视频 | 亚洲一区自拍高清免费视频| 精品一区二区亚洲欧美| 中文字幕人妻被公上司喝醉在线| 国产午夜亚洲精品不卡在线观看| 亚洲激情唯美亚洲激情图片| 国产在线拍揄自揄视频网站| 第一福利视频在线观看| 一区二区久久成人网| 男人天堂av天天操| 日韩激情文学在线视频| 久久这里有免费精品| 中文字幕乱码av资源| 在线免费观看欧美小视频| 91免费黄片可看视频| 人人妻人人澡欧美91精品| 日本阿v视频在线免费观看| 欧美亚洲免费视频观看| 成人伊人精品色xxxx视频| 黑人变态深video特大巨大| 精品成人午夜免费看| 国产精品黄色的av| 午夜蜜桃一区二区三区| 久久丁香婷婷六月天| 制服丝袜在线人妻中文字幕| 黄色资源视频网站日韩| 亚洲国产欧美一区二区三区…| 久久热这里这里只有精品| 狍和女人的王色毛片| 国产高清在线观看1区2区| 熟女少妇激情五十路| 色天天天天射天天舔| 亚洲人妻国产精品综合| 视频 国产 精品 熟女 | 国产精品成人xxxx| 天天摸天天干天天操科普| 中文字幕日韩无敌亚洲精品| 一区二区三区蜜臀在线| 深夜男人福利在线观看| 久久久久久九九99精品| 免费高清自慰一区二区三区网站| 免费69视频在线看| 国产福利小视频大全| 蜜桃视频入口久久久| 美味人妻2在线播放| 亚洲精品精品国产综合| 天天摸天天亲天天舔天天操天天爽| 大鸡巴操b视频在线| 天堂女人av一区二区| 亚洲中文字幕校园春色| 欧美aa一级一区三区四区| 一区二区三区国产精选在线播放 | 在线视频免费观看网| 521精品视频在线观看| 真实国产乱子伦一区二区| 亚洲激情唯美亚洲激情图片| 做爰视频毛片下载蜜桃视频1 | 日韩欧美一级aa大片| 免费看国产又粗又猛又爽又黄视频| 在线视频国产欧美日韩| japanese日本熟妇另类| 精品久久久久久久久久久a√国产| 91精品国产观看免费| 一区二区三区久久中文字幕| 男人插女人视频网站| 国产精彩对白一区二区三区| 天天干天天日天天谢综合156| 在线播放 日韩 av| 在线观看的a站 最新| 国产视频网站一区二区三区 | 婷婷色中文亚洲网68| 午夜久久香蕉电影网| 欧美3p在线观看一区二区三区| 欧美精品 日韩国产| 日韩中文字幕精品淫| 天天做天天爽夜夜做少妇| 免费黄页网站4188| 国产视频在线视频播放| 亚洲一区二区三区在线高清 | 亚洲变态另类色图天堂网| 在线免费91激情四射 | 青青青青视频在线播放| 中文字幕在线永久免费播放| 黄片大全在线观看观看| 人妻少妇精品久久久久久| 国产又粗又硬又大视频| 午夜精彩视频免费一区| 91综合久久亚洲综合| 成人乱码一区二区三区av| 2020av天堂网在线观看| 日韩二区视频一线天婷婷五| 亚洲国产精品久久久久久6| 日韩无码国产精品强奸乱伦| 天天日天天玩天天摸| 国产又粗又黄又硬又爽| 欧美另类重口味极品在线观看| 97超碰免费在线视频| 欧美成人一二三在线网| 熟女少妇激情五十路| 午夜在线观看岛国av,com| 日本黄色三级高清视频| 亚洲欧美清纯唯美另类| 国产日韩精品电影7777| 中文字幕在线视频一区二区三区| 欧美日韩激情啪啪啪| av中文在线天堂精品| 午夜精品在线视频一区| 家庭女教师中文字幕在线播放| 久久久久久久久久久久久97| 91国内精品久久久久精品一| 自拍偷拍vs一区二区三区| 2022天天干天天操| 日曰摸日日碰夜夜爽歪歪| 91国偷自产一区二区三区精品| 一区二区三区激情在线| 中文字幕 码 在线视频| 自拍 日韩 欧美激情| 国产性色生活片毛片春晓精品| www天堂在线久久| 亚洲日产av一区二区在线| 激情人妻校园春色亚洲欧美 | 蜜桃色婷婷久久久福利在线| 国产精品视频资源在线播放 | free性日本少妇| 青青伊人一精品视频| 日韩美在线观看视频黄| 日本最新一二三区不卡在线| 大肉大捧一进一出好爽在线视频 | 好吊操视频这里只有精品| 换爱交换乱高清大片| brazzers欧熟精品系列| 婷婷激情四射在线观看视频| 99视频精品全部15| 人人妻人人爽人人添夜| 2021国产一区二区| 早川濑里奈av黑人番号| 亚洲成人国产av在线| 免费观看污视频网站| 狠狠操操操操操操操操操| 日韩欧美制服诱惑一区在线| 国产日本欧美亚洲精品视| 中文字幕在线乱码一区二区| 国产大学生援交正在播放| 亚洲Av无码国产综合色区| 天干天天天色天天日天天射| 日本美女性生活一级片| 2021久久免费视频| 综合激情网激情五月五月婷婷| 97人妻夜夜爽二区欧美极品| 欧美日韩v中文在线| 国产亚洲精品品视频在线| okirakuhuhu在线观看| 久久久久国产成人精品亚洲午夜| 亚洲精品久久视频婷婷| 久久久久久久久久久久久97| 阴茎插到阴道里面的视频| 日本男女操逼视频免费看| 99久久超碰人妻国产| 天天爽夜夜爽人人爽QC| 亚洲欧美自拍另类图片| 中文字幕高清在线免费播放| 精品久久婷婷免费视频| 天天日夜夜干天天操| 欧美一级片免费在线成人观看| 香蕉91一区二区三区| 高清一区二区欧美系列| 在线免费观看日本伦理| 红杏久久av人妻一区| 一区二区三区四区五区性感视频 | 亚洲精品无码久久久久不卡| 欧美专区第八页一区在线播放| 黄工厂精品视频在线观看| 99热国产精品666| 国产成人一区二区三区电影网站| 人妻另类专区欧美制服| 91免费观看在线网站| 中文字幕AV在线免费看 | 日韩精品电影亚洲一区| 成熟熟女国产精品一区| 免费看国产又粗又猛又爽又黄视频 | 欧美男人大鸡吧插女人视频| 黄网十四区丁香社区激情五月天| 人妻少妇av在线观看| 欧美日韩高清午夜蜜桃大香蕉| 日韩欧美制服诱惑一区在线| 东京热男人的av天堂| 欧美亚洲牲夜夜综合久久| av在线资源中文字幕| 日辽宁老肥女在线观看视频| 中国熟女一区二区性xx| 亚洲久久午夜av一区二区| 久草视频首页在线观看| 在线免费观看日本伦理| 人妻丝袜精品中文字幕| 欧美激情精品在线观看| 国产精品熟女久久久久浪潮| 青青社区2国产视频| 人人爱人人妻人人澡39| 国产精品久久久黄网站| 91免费观看国产免费| 中文字幕中文字幕人妻| 九九视频在线精品播放| 国产不卡av在线免费| 日本午夜福利免费视频| 国产日韩精品电影7777| 在线 中文字幕 一区| 和邻居少妇愉情中文字幕| 97成人免费在线观看网站| 精品人妻每日一部精品| 美女大bxxxx内射| 亚洲av日韩av网站| 亚洲综合图片20p| 亚洲免费在线视频网站| 国产精品黄色的av| 天堂av中文在线最新版| 亚洲av无女神免非久久| 国产亚洲国产av网站在线| 亚洲精品久久综合久| 91人妻精品久久久久久久网站| 最近中文字幕国产在线| 2020久久躁狠狠躁夜夜躁 | 久草视频中文字幕在线观看| 97年大学生大白天操逼| 最新激情中文字幕视频| 天天干天天操天天插天天日| 亚洲人妻国产精品综合| 亚洲国产精品久久久久蜜桃| 在线观看操大逼视频| 精品av久久久久久久| 亚洲高清视频在线不卡| 97超碰最新免费在线观看| 天天干天天操天天插天天日| 国产成人精品一区在线观看| 亚洲av成人免费网站| 国产真实灌醉下药美女av福利| 91九色porny蝌蚪国产成人| 国产男女视频在线播放| 中文字幕av男人天堂| 91国内精品自线在拍白富美| 欧美黄色录像免费看的| 亚洲av日韩精品久久久久久hd| 天天日天天摸天天爱| 国产性色生活片毛片春晓精品 | 亚洲国产香蕉视频在线播放| 成人sm视频在线观看| 人妻熟女在线一区二区| 男人的天堂一区二区在线观看| 亚洲国产在线精品国偷产拍| 日本免费视频午夜福利视频| 成人av中文字幕一区| 精品美女在线观看视频在线观看| 粉嫩欧美美人妻小视频| 欧洲精品第一页欧洲精品亚洲| 蜜桃视频入口久久久| 免费成人av中文字幕| 在线视频自拍第三页| 天天色天天操天天舔| 国产又粗又硬又猛的毛片视频| 色吉吉影音天天干天天操| 都市激情校园春色狠狠| 精品人妻每日一部精品| 大鸡吧插逼逼视频免费看| 免费看美女脱光衣服的视频| 特大黑人巨大xxxx| 国产清纯美女al在线| 国产第一美女一区二区三区四区| 91精品国产高清自在线看香蕉网 | 人妻熟女在线一区二区| 国产女人被做到高潮免费视频| 99国产精品窥熟女精品| 老司机免费福利视频网| 老司机你懂得福利视频| 国产揄拍高清国内精品对白| 激情人妻校园春色亚洲欧美| 亚洲一区二区三区久久午夜| 色天天天天射天天舔| 成人网18免费视频版国产| 亚洲蜜臀av一区二区三区九色 | 男女啪啪啪啪啪的网站| 中文字幕 亚洲av| 色天天天天射天天舔| 97人妻人人澡爽人人精品| 中文亚洲欧美日韩无线码| 狠狠躁狠狠爱网站视频| 绝色少妇高潮3在线观看| 熟女妇女老妇一二三区| 99视频精品全部15| 亚洲美女高潮喷浆视频| 成人免费公开视频无毒| 中文字幕无码一区二区免费 | 婷婷久久久久深爱网| 在线不卡日韩视频播放| 亚洲一区二区三区av网站| 国产乱子伦一二三区| 最近中文字幕国产在线| 在线免费观看亚洲精品电影| 青青操免费日综合视频观看| 中文字幕奴隷色的舞台50| 色婷婷精品大在线观看| 国产91久久精品一区二区字幕 | 视频一区二区综合精品| 99一区二区在线观看| 丰满少妇人妻xxxxx| 久久永久免费精品人妻专区| 欧美色婷婷综合在线| 热思思国产99re| 午夜福利人人妻人人澡人人爽| 在线不卡成人黄色精品| 久久久久久久久久久久久97| 无码精品一区二区三区人| 三级黄色亚洲成人av| 久久机热/这里只有| 少妇高潮一区二区三区| 特一级特级黄色网片| 天天射,天天操,天天说| 成人av亚洲一区二区| 三级等保密码要求条款| 在线观看av观看av| 国产精品污污污久久| 午夜场射精嗯嗯啊啊视频| 亚洲精品久久视频婷婷| 日本高清撒尿pissing| 天天摸天天干天天操科普| 免费观看国产综合视频| 亚洲免费国产在线日韩| 日韩欧美国产一区不卡| 男生舔女生逼逼的视频| 99久久激情婷婷综合五月天| 久久美欧人妻少妇一区二区三区 | 最近的中文字幕在线mv视频| 嫩草aⅴ一区二区三区| 最新91精品视频在线| av日韩在线免费播放| 久久久麻豆精亚洲av麻花| 亚洲国产中文字幕啊啊啊不行了 | 久久久久91精品推荐99| 青青擦在线视频国产在线| 精品区一区二区三区四区人妻 | 夜色福利视频在线观看| 天天艹天天干天天操| 少妇人妻久久久久视频黄片| 亚洲激情唯美亚洲激情图片| 强行扒开双腿猛烈进入免费版| 日韩北条麻妃一区在线| 97年大学生大白天操逼| 天天射夜夜操综合网| 日韩美女福利视频网| 免费男阳茎伸入女阳道视频 | 欧美3p在线观看一区二区三区| 精品一区二区三区欧美| 果冻传媒av一区二区三区 | 五十路老熟女码av| 好吊操视频这里只有精品| 精品一区二区三四区| 非洲黑人一级特黄片| 九九热99视频在线观看97| 久久久制服丝袜中文字幕| 国产精品3p和黑人大战| 91亚洲手机在线视频播放| 亚洲午夜电影之麻豆| 美洲精品一二三产区区别| 成人性黑人一级av| 激情国产小视频在线| 中文字幕视频一区二区在线观看| 777奇米久久精品一区| 一二三区在线观看视频| 亚洲精品精品国产综合| 欧美日韩熟女一区二区三区| 首之国产AV医生和护士小芳| 99热这里只有国产精品6| 搞黄色在线免费观看| 最近的中文字幕在线mv视频| 亚洲成人三级在线播放| 女蜜桃臀紧身瑜伽裤| 91精品啪在线免费| 亚洲欧洲av天堂综合| 亚洲欧洲一区二区在线观看| 青青社区2国产视频| 视频在线免费观看你懂得| 亚洲国产欧美国产综合在线| 啪啪啪啪啪啪啪免费视频| 国产精品黄色的av| 中文字幕日韩精品日本| 亚洲精品在线资源站| 日韩北条麻妃一区在线| 亚洲精品无码久久久久不卡| 中文字幕在线免费第一页| 91精品激情五月婷婷在线| 国产日本精品久久久久久久 | 成年女人免费播放视频| 女生被男生插的视频网站| 新97超碰在线观看| 免费十精品十国产网站| 九色视频在线观看免费| 美女吃鸡巴操逼高潮视频| 欧美亚洲偷拍自拍色图| 亚洲欧美一卡二卡三卡| 偷青青国产精品青青在线观看| 亚洲码av无色中文| 青青青国产片免费观看视频| 国产一区成人在线观看视频| 女生被男生插的视频网站| 亚洲午夜高清在线观看| 99精品国自产在线人| 欧美3p在线观看一区二区三区| 啪啪啪18禁一区二区三区| 久久久久五月天丁香社区| 最新黄色av网站在线观看| 午夜在线一区二区免费| 中文字幕日本人妻中出| 六月婷婷激情一区二区三区| 国产精品免费不卡av| 天天干天天操天天插天天日| 都市家庭人妻激情自拍视频| 久草视频在线免播放| 中文字幕AV在线免费看 | 国产久久久精品毛片| 五月婷婷在线观看视频免费 | 超碰中文字幕免费观看| 免费男阳茎伸入女阳道视频| 国产精品大陆在线2019不卡| 日韩中文字幕在线播放第二页 | 成人免费毛片aaaa| 一级A一级a爰片免费免会员| 黑人借宿ntr人妻的沦陷2| 91av精品视频在线| 97色视频在线观看| 精品国产亚洲av一淫| 黑人性生活视频免费看| 在线观看av观看av| 狠狠嗨日韩综合久久| 欧洲国产成人精品91铁牛tv | 日韩激情文学在线视频| 18禁网站一区二区三区四区| 亚洲最大黄 嗯色 操 啊| av天堂中文字幕最新| 婷婷色国产黑丝少妇勾搭AV| 端庄人妻堕落挣扎沉沦| 人人爽亚洲av人人爽av| 欧美天堂av无线av欧美| 日本最新一二三区不卡在线| 91精品资源免费观看| 国产性感美女福利视频| 天天日夜夜操天天摸| 亚洲超碰97人人做人人爱| av中文字幕福利网| 99精品国自产在线人| 日本人竟这样玩学生妹| 国产视频一区在线观看| 国产乱子伦一二三区| 农村胖女人操逼视频| 97小视频人妻一区二区| 1000小视频在线| 国产激情av网站在线观看| 一级A一级a爰片免费免会员| 东京干手机福利视频| 999九九久久久精品| 日韩av有码一区二区三区4| 91福利在线视频免费观看| 日本美女性生活一级片| 91超碰青青中文字幕| 91人妻精品一区二区久久| 蜜臀av久久久久久久| 中国黄色av一级片| 成人av免费不卡在线观看| 99re国产在线精品| 中文字幕av熟女人妻| av中文在线天堂精品| 国产亚洲精品视频合集| 精品久久久久久高潮| 欧美精品免费aaaaaa| 福利国产视频在线观看| www日韩毛片av| 在线不卡成人黄色精品| 天天干狠狠干天天操| 午夜激情高清在线观看| 一区二区三区美女毛片| av黄色成人在线观看| 人妻素人精油按摩中出| 国产视频一区二区午夜| 亚洲 欧美 精品 激情 偷拍 | 亚洲精品欧美日韩在线播放| 自拍偷拍 国产资源| 国产实拍勾搭女技师av在线| 天天干天天爱天天色| 亚洲精品三级av在线免费观看| 天天干天天操天天插天天日| 中文字幕一区的人妻欧美日韩| 日本后入视频在线观看 | 在线观看视频网站麻豆| 中文字幕奴隷色的舞台50| 精品久久久久久久久久久a√国产| 日韩视频一区二区免费观看| 国产成人午夜精品福利| 亚洲综合另类欧美久久| 中文亚洲欧美日韩无线码| 一级黄色片夫妻性生活| 亚洲欧美在线视频第一页| 成人sm视频在线观看| 欧美日韩中文字幕欧美| yellow在线播放av啊啊啊| 在线观看欧美黄片一区二区三区| 成人高清在线观看视频| 99国内精品永久免费视频| 国产精品国产精品一区二区| 极品丝袜一区二区三区| 蜜桃精品久久久一区二区| 色婷婷精品大在线观看| 欧亚日韩一区二区三区观看视频| 亚洲一区二区三区在线高清| 少妇与子乱在线观看| 一区二区三区 自拍偷拍| 亚洲成人精品女人久久久| 国产综合高清在线观看| 亚洲国产欧美国产综合在线| 免费一级黄色av网站| 国产精品污污污久久| 1区2区3区不卡视频| 91精品免费久久久久久| 人妻激情图片视频小说| 亚洲高清一区二区三区视频在线| 日本女人一级免费片| 影音先锋女人av噜噜色| 偷拍自拍国产在线视频| av天堂加勒比在线| 51国产成人精品视频| 天天色天天爱天天爽| 18禁美女无遮挡免费| www久久久久久久久久久| 日韩三级电影华丽的外出| 国产在线一区二区三区麻酥酥| 天天做天天爽夜夜做少妇| 青青伊人一精品视频| 国产精品一区二区三区蜜臀av| 亚洲一级美女啪啪啪| 日韩午夜福利精品试看| 四虎永久在线精品免费区二区| 美女吃鸡巴操逼高潮视频| 欧美va不卡视频在线观看| 一区二区视频在线观看视频在线| 亚洲中文字字幕乱码| 91小伙伴中女熟女高潮| 大香蕉大香蕉在线看| 欧美成一区二区三区四区| 美女小视频网站在线| 91高清成人在线视频| 中文字幕高清在线免费播放| 五月色婷婷综合开心网4438| 激情啪啪啪啪一区二区三区| 人妻少妇亚洲一区二区| 亚洲 欧美 精品 激情 偷拍 | 欧美一区二区三区四区性视频| 青青青青青青青青青国产精品视频| 欧美3p在线观看一区二区三区| 最新中文字幕乱码在线| 成人激情文学网人妻| av天堂中文免费在线| 一区二区三区在线视频福利| 亚洲av琪琪男人的天堂| 午夜在线观看岛国av,com| 欧美日韩在线精品一区二区三| 少妇深喉口爆吞精韩国| 国产精品视频男人的天堂| 3344免费偷拍视频| 久久一区二区三区人妻欧美| 中文字幕日韩91人妻在线| 青青青青操在线观看免费| 亚洲精品久久视频婷婷| 日本真人性生活视频免费看| 51国产成人精品视频| 国产亚洲四十路五十路| 亚洲男人在线天堂网| 日本人妻少妇18—xx| 亚洲少妇高潮免费观看| 久青青草视频手机在线免费观看| 精品黑人一区二区三区久久国产| 521精品视频在线观看| 老司机免费视频网站在线看| 国产麻豆91在线视频| 亚洲 人妻 激情 中文| 中文字幕高清在线免费播放| 蜜桃视频入口久久久| 美日韩在线视频免费看| 超碰97人人做人人爱| 91人妻精品一区二区在线看| 午夜婷婷在线观看视频| 午夜精品一区二区三区4| 中文字幕成人日韩欧美| 日本高清撒尿pissing| xxx日本hd高清| 91免费黄片可看视频| 红桃av成人在线观看| 91p0rny九色露脸熟女| xxx日本hd高清| 亚洲午夜伦理视频在线| 91人妻精品一区二区久久| 日本一道二三区视频久久| 专门看国产熟妇的网站| 亚洲精品乱码久久久本| 久久久麻豆精亚洲av麻花| 亚洲精品一线二线在线观看| 亚洲熟女综合色一区二区三区四区| 欧美国产亚洲中英文字幕| 亚洲精品国产久久久久久| 国产极品美女久久久久久| 自拍偷拍 国产资源| 91亚洲精品干熟女蜜桃频道| 亚洲熟色妇av日韩熟色妇在线| 中文字幕奴隷色的舞台50| 免费黄色成人午夜在线网站| 天天日天天敢天天干| 亚洲精品成人网久久久久久小说| 国产精品自拍偷拍a| 少妇人妻二三区视频| 亚洲日产av一区二区在线| 天天操天天干天天艹| av网址在线播放大全| 97资源人妻免费在线视频| 亚洲免费福利一区二区三区| 亚洲国产欧美国产综合在线| 天美传媒mv视频在线观看| 最近中文字幕国产在线| 蜜桃久久久久久久人妻| 色综合久久久久久久久中文| 亚洲成人av一区久久| 韩国黄色一级二级三级| 国产成人精品亚洲男人的天堂| 91福利在线视频免费观看| 国产精品污污污久久| 青青青青在线视频免费观看| 大鸡吧插逼逼视频免费看| 国产超码片内射在线| 制丝袜业一区二区三区| 欧美黑人与人妻精品| 国产剧情演绎系列丝袜高跟| 人妻久久无码中文成人| 日本成人一区二区不卡免费在线| 免费成人av中文字幕| 日韩av有码中文字幕| 1000部国产精品成人观看视频| 国产一区二区神马久久| 精品suv一区二区69| 免费看国产av网站| 日韩av熟妇在线观看| 三级av中文字幕在线观看| 97资源人妻免费在线视频| 精品一区二区三区在线观看| 家庭女教师中文字幕在线播放| 特级欧美插插插插插bbbbb| av在线免费中文字幕| 熟女少妇激情五十路| 亚洲少妇人妻无码精品| 欧美亚洲偷拍自拍色图| 日韩av大胆在线观看| 日本一区二区三区免费小视频| 18禁精品网站久久| 换爱交换乱高清大片| 日韩精品中文字幕福利| 熟女国产一区亚洲中文字幕| 亚洲av日韩av网站| 视频在线免费观看你懂得| 亚洲欧美成人综合视频| 日韩中文字幕精品淫| 亚洲 人妻 激情 中文| 熟女少妇激情五十路| 日本www中文字幕| 亚洲变态另类色图天堂网| 亚洲图库另类图片区| 老鸭窝日韩精品视频观看| 欧美一区二区三区激情啪啪啪| 1000部国产精品成人观看视频| 不戴胸罩引我诱的隔壁的人妻| 青青青青青青草国产| 日本韩国免费一区二区三区视频| 久草视频 久草视频2| 男人在床上插女人视频| 日本黄色特一级视频| 国产乱子伦一二三区| 超碰97人人做人人爱| 亚洲天堂第一页中文字幕| 亚洲国产在线精品国偷产拍| 黑人借宿ntr人妻的沦陷2| 青青青aaaa免费| 亚洲美女自偷自拍11页| 日韩视频一区二区免费观看| 亚洲1069综合男同| 日本一道二三区视频久久| 男女第一次视频在线观看| 日韩美av高清在线| 色综合久久五月色婷婷综合| 成人av久久精品一区二区| 粉嫩小穴流水视频在线观看| 国产麻豆91在线视频| 婷婷综合蜜桃av在线| 姐姐的朋友2在线观看中文字幕| 成年人黄色片免费网站| 91免费福利网91麻豆国产精品| 亚洲一区二区久久久人妻| 国产麻豆乱子伦午夜视频观看| 热久久只有这里有精品| 成人免费做爰高潮视频| 大鸡八强奸视频在线观看| 成人资源在线观看免费官网| 91香蕉成人app下载| 动漫美女的小穴视频| 四川乱子伦视频国产vip| 色婷婷综合激情五月免费观看| 亚洲精品av在线观看| 91国产在线视频免费观看| 91高清成人在线视频| 青青青青草手机在线视频免费看| 欧美麻豆av在线播放| 日韩在线视频观看有码在线| 日本少妇人妻xxxxx18| 91大屁股国产一区二区| 美女视频福利免费看| 视频二区在线视频观看| aiss午夜免费视频| 中出中文字幕在线观看| 亚洲精品ww久久久久久| 成人国产影院在线观看| 一级a看免费观看网站| 国产福利小视频大全| 日本丰满熟妇大屁股久久| 亚洲 自拍 色综合图| 久久久人妻一区二区| 岛国一区二区三区视频在线| 区一区二区三国产中文字幕| 欧美香蕉人妻精品一区二区| 欧美特级特黄a大片免费| 天天插天天狠天天操| 欧美3p在线观看一区二区三区| 亚洲福利午夜久久久精品电影网| 中文字幕日韩91人妻在线| 老司机99精品视频在线观看 | 成人亚洲精品国产精品| 久草视频在线免播放| 婷婷色国产黑丝少妇勾搭AV| 成人sm视频在线观看| 大黑人性xxxxbbbb| 日本av熟女在线视频| 欧美在线偷拍视频免费看| 香蕉91一区二区三区| 婷婷色中文亚洲网68| 99久久超碰人妻国产| 日本性感美女三级视频| 色天天天天射天天舔| 色偷偷伊人大杳蕉综合网| 色花堂在线av中文字幕九九| 午夜频道成人在线91| 亚洲福利天堂久久久久久| 日本女大学生的黄色小视频| 天天日天天干天天舔天天射| 91小伙伴中女熟女高潮| 88成人免费av网站| 青青青青草手机在线视频免费看| av破解版在线观看| 欧美日韩熟女一区二区三区| 涩涩的视频在线观看视频| 国产欧美精品一区二区高清| 伊人网中文字幕在线视频| 色婷婷六月亚洲综合香蕉| 精品高潮呻吟久久av| 又色又爽又黄又刺激av网站| 亚洲精品欧美日韩在线播放| 晚上一个人看操B片| 丰满少妇人妻xxxxx| 黄色资源视频网站日韩| 日本熟女50视频免费| 国产麻豆国语对白露脸剧情| 天天日天天干天天爱| 天天综合天天综合天天网| 中文字幕第三十八页久久| 狠狠鲁狠狠操天天晚上干干| 操日韩美女视频在线免费看| 精品国产亚洲av一淫| 天天想要天天操天天干| 午夜精彩视频免费一区| 操日韩美女视频在线免费看| 这里只有精品双飞在线播放| 91快播视频在线观看| 大尺度激情四射网站| 亚洲女人的天堂av| 精品人人人妻人人玩日产欧| 少妇人妻100系列| 新97超碰在线观看| 成年午夜影片国产片| 99久久超碰人妻国产| 人妻少妇精品久久久久久| 国产黄色大片在线免费播放| av大全在线播放免费| 五月婷婷在线观看视频免费 | 亚洲国产精品黑丝美女| 在线 中文字幕 一区| 精品一区二区三区在线观看| 日本女大学生的黄色小视频| 全国亚洲男人的天堂| 国产揄拍高清国内精品对白| 日韩视频一区二区免费观看| 免费黄色成人午夜在线网站| 可以在线观看的av中文字幕| 国产精品久久久久久久久福交| 激情啪啪啪啪一区二区三区 | 亚洲自拍偷拍精品网| 粉嫩小穴流水视频在线观看| 精品高跟鞋丝袜一区二区| 红桃av成人在线观看| 黄色中文字幕在线播放| 91久久精品色伊人6882| 亚洲视频在线观看高清| 91麻豆精品久久久久| 欧美精品免费aaaaaa| 色秀欧美视频第一页| 天天干天天操天天玩天天射| 人妻另类专区欧美制服| 色97视频在线播放| 岳太深了紧紧的中文字幕| 国产又粗又黄又硬又爽| 在线免费91激情四射| 91高清成人在线视频| 国产亚洲成人免费在线观看 | 91亚洲手机在线视频播放| 福利午夜视频在线观看| 久久美欧人妻少妇一区二区三区 | 97超碰人人搞人人| 青青操免费日综合视频观看| 精品suv一区二区69| 久久香蕉国产免费天天| 国产视频一区二区午夜| 午夜精品福利91av| 19一区二区三区在线播放| 欧美视频不卡一区四区| 91chinese在线视频| 人妻熟女在线一区二区| 在线国产精品一区二区三区| 美女被肏内射视频网站| 天天日天天日天天射天天干 | 国产综合视频在线看片| 欧美一区二区三区激情啪啪啪| 中文字幕 亚洲av| 青青青青青青青在线播放视频| 国产男女视频在线播放| 天天综合天天综合天天网| 黄色大片男人操女人逼| 99热99这里精品6国产| 久久艹在线观看视频| 亚洲高清自偷揄拍自拍| aiss午夜免费视频| 国产亚洲四十路五十路| 国产黄色片蝌蚪九色91| 蜜桃臀av蜜桃臀av| 日韩在线视频观看有码在线| 国产高清97在线观看视频| 人人妻人人爽人人添夜| 天天日天天爽天天干| 色偷偷伊人大杳蕉综合网| 亚洲熟妇无码一区二区三区| 天天日天天干天天干天天日| 红杏久久av人妻一区| 2022天天干天天操| 国产性感美女福利视频| 最近中文字幕国产在线| 91色秘乱一区二区三区| 人人妻人人爽人人添夜| av成人在线观看一区| 日韩欧美一级精品在线观看| 欧美一区二区中文字幕电影| 日韩av有码中文字幕| 自拍偷拍一区二区三区图片| 2020久久躁狠狠躁夜夜躁| 国产精品大陆在线2019不卡| 66久久久久久久久久久| 日本a级视频老女人| 日韩欧美一级黄片亚洲| 久久精品在线观看一区二区 | 丝袜亚洲另类欧美变态| 天天躁日日躁狠狠躁av麻豆| 欧美日韩不卡一区不区二区| 午夜场射精嗯嗯啊啊视频| 色婷婷六月亚洲综合香蕉| 日本熟妇丰满厨房55| 中文字幕一区二区三区人妻大片| 最近中文字幕国产在线| 国产精品女邻居小骚货| 91免费观看在线网站| 欧美日本在线视频一区| 九色porny九色9l自拍视频| 大尺度激情四射网站| 偷拍自拍 中文字幕| 一区二区免费高清黄色视频| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 夜夜嗨av一区二区三区中文字幕| 国产精品自拍偷拍a| 欧美特级特黄a大片免费| 经典亚洲伊人第一页| 精品国产成人亚洲午夜| 亚洲福利精品福利精品福利| 亚洲第一伊人天堂网| 婷婷色国产黑丝少妇勾搭AV| 亚洲天堂精品久久久| 亚洲无码一区在线影院| 亚洲人妻30pwc| 在线免费观看日本伦理| 蜜桃久久久久久久人妻| 亚洲综合在线视频可播放| 九色视频在线观看免费| 无码精品一区二区三区人| 日本高清成人一区二区三区| 97精品视频在线观看| 欧美少妇性一区二区三区| 日本熟女精品一区二区三区| 成人精品视频99第一页| 国产乱子伦一二三区| 婷婷久久一区二区字幕网址你懂得| 精品高跟鞋丝袜一区二区| 人人妻人人爱人人草| 亚洲自拍偷拍精品网| 亚洲成人午夜电影在线观看| 欧美另类z0z变态| 男生舔女生逼逼视频| 精品91高清在线观看| 综合一区二区三区蜜臀| 欧美精品国产综合久久| 欧美另类一区二区视频| 亚洲熟妇x久久av久久| 综合一区二区三区蜜臀| 二区中出在线观看老师| 日本韩国免费一区二区三区视频| 91欧美在线免费观看| 国产又粗又猛又爽又黄的视频在线| 国产一区av澳门在线观看| 在线免费观看日本片| 亚洲护士一区二区三区| 九色视频在线观看免费| 日本丰满熟妇大屁股久久| 午夜福利资源综合激情午夜福利资 | av黄色成人在线观看| 女同久久精品秋霞网| 亚洲午夜电影之麻豆| 熟女91pooyn熟女| 日本少妇高清视频xxxxx| 欧美精产国品一二三产品价格| 91成人精品亚洲国产| 午夜毛片不卡免费观看视频| 4个黑人操素人视频网站精品91| 日韩美女精品视频在线观看网站| 亚洲人妻av毛片在线| 亚洲一区av中文字幕在线观看| 国产欧美精品不卡在线| 日韩中文字幕精品淫| 伊人综合免费在线视频| 伊人开心婷婷国产av| 沙月文乃人妻侵犯中文字幕在线| 天天干夜夜操啊啊啊| 日本熟妇丰满厨房55| 无码精品一区二区三区人| 青青青青青操视频在线观看| 免费观看理论片完整版| 大尺度激情四射网站| 亚洲国产精品久久久久蜜桃| 少妇高潮一区二区三区| 另类av十亚洲av| 亚洲免费va在线播放| 天天操天天弄天天射| 美味人妻2在线播放| av视网站在线观看| 男人天堂av天天操| 国产av自拍偷拍盛宴| 亚洲国产成人最新资源| 国产极品精品免费视频| 在线观看的a站 最新| 91p0rny九色露脸熟女| 男女啪啪视频免费在线观看| 亚洲国产精品免费在线观看| 在线国产精品一区二区三区| 国产亚洲精品品视频在线| 国产1区,2区,3区| 日本免费午夜视频网站| 99精品久久久久久久91蜜桃| 操操网操操伊剧情片中文字幕网| 亚洲美女美妇久久字幕组| gay gay男男瑟瑟在线网站| 国产精品久久久黄网站| 青草久久视频在线观看| 51国产偷自视频在线播放| 福利视频广场一区二区| 亚洲av色香蕉一区二区三区| 91人妻精品久久久久久久网站| 亚洲专区激情在线观看视频| 色av色婷婷人妻久久久精品高清| 婷婷色国产黑丝少妇勾搭AV | 久久久精品欧洲亚洲av| 大骚逼91抽插出水视频| 99国内小视频在现欢看| 国产 在线 免费 精品| 又粗又硬又猛又爽又黄的| 激情小视频国产在线| 一区二区在线视频中文字幕| 日韩精品二区一区久久| 亚洲av第国产精品| 一区二区三区麻豆福利视频| 亚洲高清自偷揄拍自拍| 亚洲国产欧美一区二区三区…| 天天干天天爱天天色| 天堂va蜜桃一区入口| 午夜蜜桃一区二区三区| 激情小视频国产在线| 美女吃鸡巴操逼高潮视频| 日韩a级黄色小视频| 韩国爱爱视频中文字幕| 亚洲成人激情av在线| 性生活第二下硬不起来| 亚洲精品亚洲人成在线导航| 老司机欧美视频在线看| 精品久久久久久高潮| 亚洲国产精品久久久久蜜桃| 亚洲免费视频欧洲免费视频| 欧美日韩高清午夜蜜桃大香蕉| 日本熟妇一区二区x x| 可以在线观看的av中文字幕| 久草电影免费在线观看| 一区二区在线视频中文字幕| 男人靠女人的逼视频| 亚洲另类伦春色综合小| 国产成人一区二区三区电影网站| 一本久久精品一区二区| 激情小视频国产在线| 中文字幕之无码色多多| 欧美亚洲少妇福利视频| 国产在线观看黄色视频| 国产高清女主播在线| 日本成人一区二区不卡免费在线| 亚洲成人av一区在线| 成年人免费看在线视频| 欧洲亚洲欧美日韩综合| 干逼又爽又黄又免费的视频| gogo国模私拍视频| 在线国产日韩欧美视频| 日韩美女精品视频在线观看网站| 视频啪啪啪免费观看| 国产使劲操在线播放| 日韩一区二区电国产精品| 99精品视频在线观看免费播放| 97超碰免费在线视频| 国产精品伦理片一区二区| 婷婷久久久久深爱网| 亚洲精品一区二区三区老狼| 国产之丝袜脚在线一区二区三区| 亚洲国产第一页在线观看| 91免费黄片可看视频| 班长撕开乳罩揉我胸好爽| 鸡巴操逼一级黄色气| 中国视频一区二区三区| 国产精品一区二区三区蜜臀av | 天天射夜夜操综合网| 色综合久久五月色婷婷综合 | 9久在线视频只有精品| 中文字幕+中文字幕| 91亚洲国产成人精品性色| 国产高清在线在线视频| 黄网十四区丁香社区激情五月天| 中文字幕无码日韩专区免费| 91精品综合久久久久3d动漫| 国产九色91在线视频| 福利视频广场一区二区| 大胸性感美女羞爽操逼毛片| 天天做天天干天天舔| 免费在线观看污污视频网站| 久久久久91精品推荐99| 国产91精品拍在线观看| 中文字幕在线观看国产片| 蜜臀av久久久久久久| 75国产综合在线视频| 日韩加勒比东京热二区| 亚洲高清自偷揄拍自拍| 国产日韩精品一二三区久久久| 韩国AV无码不卡在线播放| 久草极品美女视频在线观看| 国产精品精品精品999| 揄拍成人国产精品免费看视频| 最新97国产在线视频| 日韩成人性色生活片| av中文字幕在线观看第三页| 中文字幕免费福利视频6| 18禁精品网站久久| 欧美xxx成人在线| japanese五十路熟女熟妇| 国产无遮挡裸体免费直播视频| 亚洲免费va在线播放| 啪啪啪操人视频在线播放| 91人妻精品久久久久久久网站| 欧美日韩高清午夜蜜桃大香蕉| 粉嫩av蜜乳av蜜臀| 宅男噜噜噜666国产| 亚洲av男人的天堂你懂的| 精品黑人一区二区三区久久国产 | 中文字幕av熟女人妻| 亚洲伊人色一综合网| 大黑人性xxxxbbbb| 欧美亚洲国产成人免费在线 | 国产精品视频欧美一区二区| 国产精品黄页网站视频| 亚洲人妻国产精品综合| 国产内射中出在线观看| 欧美综合婷婷欧美综合| 日日夜夜精品一二三| av天堂中文免费在线| 国产黄色片蝌蚪九色91| 日本黄色三级高清视频| 日韩精品中文字幕福利| 国产无遮挡裸体免费直播视频| 丁香花免费在线观看中文字幕| 亚洲综合乱码一区二区| 成人av天堂丝袜在线观看| 75国产综合在线视频| 亚洲一区二区三区久久受| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 亚洲午夜电影在线观看| av在线观看网址av| 国产精品自拍偷拍a| 欧美乱妇无乱码一区二区| 污污小视频91在线观看| 91九色国产porny蝌蚪| 亚洲一级特黄特黄黄色录像片| 99婷婷在线观看视频| 亚洲最大黄 嗯色 操 啊| 午夜久久香蕉电影网| 岛国毛片视频免费在线观看| 欧美日本aⅴ免费视频| 狠狠躁夜夜躁人人爽天天天天97| 亚洲va国产va欧美va在线| 91麻豆精品91久久久久同性| 婷婷色中文亚洲网68| 2020av天堂网在线观看| 亚洲av琪琪男人的天堂| 国产在线一区二区三区麻酥酥 | 日本特级片中文字幕| 国产在线一区二区三区麻酥酥| 干逼又爽又黄又免费的视频| 丰满的继坶3中文在线观看| 国产亚洲成人免费在线观看| 精品一区二区三区在线观看| 馒头大胆亚洲一区二区| 免费在线福利小视频| 亚洲 中文字幕在线 日韩| 夜夜操,天天操,狠狠操| 亚洲推理片免费看网站| 亚洲天堂成人在线观看视频网站| 中文字幕在线欧美精品| 91久久精品色伊人6882| 啊啊啊视频试看人妻| 唐人色亚洲av嫩草| 天天夜天天日天天日| 亚洲推理片免费看网站| 国产又粗又硬又猛的毛片视频| 5528327男人天堂| 久久久久久久久久一区二区三区| 久久久麻豆精亚洲av麻花| 扒开让我视频在线观看| 97人人妻人人澡人人爽人人精品| 阴茎插到阴道里面的视频| 亚洲成人熟妇一区二区三区 | 亚洲1区2区3区精华液| 国产精品久久久久久久女人18| 大鸡吧插逼逼视频免费看| 亚洲午夜福利中文乱码字幕| 国产亚洲精品视频合集| 91精品国产91久久自产久强 | 老司机99精品视频在线观看| 中国把吊插入阴蒂的视频| 边摸边做超爽毛片18禁色戒| 最新中文字幕乱码在线| 国产成人无码精品久久久电影| av无限看熟女人妻另类av| www天堂在线久久| 精品91高清在线观看| 又色又爽又黄的美女裸体| 日本一二三中文字幕| 大屁股肉感人妻中文字幕在线| 亚洲麻豆一区二区三区| av天堂中文免费在线| 亚洲一级av无码一级久久精品| 好吊操视频这里只有精品| 91chinese在线视频| 中国无遮挡白丝袜二区精品| 日本脱亚入欧是指什么| 青娱乐最新视频在线| 一区二区三区久久中文字幕| 久久三久久三久久三久久| 天堂v男人视频在线观看| 一级黄片久久久久久久久| 大黑人性xxxxbbbb| 国产精品国产三级麻豆| 亚洲中文字幕综合小综合| 国产熟妇一区二区三区av| 大鸡巴后入爆操大屁股美女| 57pao国产一区二区| 欲满人妻中文字幕在线| 中国熟女@视频91| 一区二区三区久久久91| 在线观看视频污一区| 在线观看免费av网址大全| 亚洲一区二区三区精品乱码| 黑人进入丰满少妇视频| 天天通天天透天天插| 成人sm视频在线观看| 一区二区三区麻豆福利视频| 日本脱亚入欧是指什么| 最新黄色av网站在线观看| 国产黄色a级三级三级三级| 久久久久只精品国产三级| 一二三中文乱码亚洲乱码one| 日本www中文字幕| 免费十精品十国产网站| 涩涩的视频在线观看视频| av天堂中文字幕最新| 欧美亚洲国产成人免费在线| 国产美女一区在线观看| 久久精品久久精品亚洲人| 国产一区二区火爆视频 | 岛国青草视频在线观看| 亚洲中文精品字幕在线观看| 天天操天天插天天色| 好吊操视频这里只有精品| 久久精品国产999| 欧美成人黄片一区二区三区| 黄色中文字幕在线播放| 日本男女操逼视频免费看| 姐姐的朋友2在线观看中文字幕| 日本18禁久久久久久| 天天射夜夜操综合网| 91人妻精品久久久久久久网站| 国产大学生援交正在播放| 男人操女人逼逼视频网站| 五月天色婷婷在线观看视频免费| 亚洲中文字幕乱码区| 9国产精品久久久久老师| 日本三极片视频网站观看| 免费在线观看视频啪啪| 亚洲综合在线观看免费| 欧美亚洲少妇福利视频| 久久久麻豆精亚洲av麻花| 亚洲人妻av毛片在线| 亚洲欧美精品综合图片小说| 精品成人啪啪18免费蜜臀| 久久久精品欧洲亚洲av| av破解版在线观看| 天天想要天天操天天干| 欧美亚洲自偷自拍 在线| 国产精品久久9999| 大香蕉伊人国产在线| 日本av熟女在线视频| 午夜影院在线观看视频羞羞羞| 亚洲欧美一区二区三区爱爱动图 | 大肉大捧一进一出好爽在线视频| 欧美一区二区三区高清不卡tv | 偷拍自拍亚洲美腿丝袜| 91精品资源免费观看| 国产又粗又猛又爽又黄的视频在线 | 亚洲成人午夜电影在线观看| 91色秘乱一区二区三区| av在线shipin| 2018最新中文字幕在线观看| 人妻少妇一区二区三区蜜桃| 日比视频老公慢点好舒服啊| 国产在线观看免费人成短视频| 欧美成人综合视频一区二区 | 99久久成人日韩欧美精品| 亚洲成a人片777777| 亚洲欧美人精品高清| 久久精品美女免费视频| 最近的中文字幕在线mv视频| 国产性色生活片毛片春晓精品| 91精品国产综合久久久蜜| 亚洲人妻视频在线网| 欧美精产国品一二三区| 偷拍自拍亚洲视频在线观看| 国产精品日韩欧美一区二区| 亚洲男人的天堂a在线| 国产精品国产三级麻豆| 欧美色婷婷综合在线| 日韩国产乱码中文字幕| 天天日天天干天天插舔舔| 91自产国产精品视频| 蜜桃久久久久久久人妻| 国产精品黄页网站视频| 青青青青青青青青青青草青青| 日本美女成人在线视频| 最新黄色av网站在线观看| 精品老妇女久久9g国产| 92福利视频午夜1000看 | 中文字幕日韩精品日本| 欧美3p在线观看一区二区三区| 大鸡巴操娇小玲珑的女孩逼| 午夜免费观看精品视频| 东京热男人的av天堂| 性色蜜臀av一区二区三区| 在线观看免费视频网| 人妻激情图片视频小说| gav成人免费播放| 自拍偷拍亚洲精品第2页| 被大鸡吧操的好舒服视频免费| 9l人妻人人爽人人爽| 欧美日韩一级黄片免费观看| 91精品视频在线观看免费| 亚洲国产精品久久久久久6| 大胆亚洲av日韩av| 欧美日韩情色在线观看| av在线shipin| 亚洲日本一区二区三区| 国产综合精品久久久久蜜臀| 国产亚洲精品视频合集| 青青青青青免费视频| av视网站在线观看| 2022国产精品视频| 大香蕉玖玖一区2区| 日本三极片视频网站观看| 被大鸡吧操的好舒服视频免费| 日本裸体熟妇区二区欧美| 白白操白白色在线免费视频| 亚洲综合图片20p| 亚洲熟妇无码一区二区三区| 日韩剧情片电影在线收看| xxx日本hd高清| 亚洲在线一区二区欧美| 2012中文字幕在线高清| 亚洲精品乱码久久久本| 99热99re在线播放| 精品国产亚洲av一淫| 成年美女黄网站18禁久久| 99精品国自产在线人| 中文字幕,亚洲人妻| 中文乱理伦片在线观看| 亚洲另类在线免费观看| 91免费观看在线网站| 人人妻人人爽人人添夜| 国语对白xxxx乱大交| 国产精品亚洲а∨天堂免| 欧美viboss性丰满| 又大又湿又爽又紧A视频| 国产亚洲视频在线观看| 欧美精品伦理三区四区 | 久久三久久三久久三久久| 男人天堂av天天操| av天堂中文字幕最新| 在线观看视频 你懂的| 75国产综合在线视频| 超级碰碰在线视频免费观看| 国产变态另类在线观看| 欧美日韩不卡一区不区二区| 99一区二区在线观看| 久久久麻豆精亚洲av麻花| 国产1区,2区,3区| 动漫美女的小穴视频| 国产夫妻视频在线观看免费| 国产日韩精品一二三区久久久| 亚洲1区2区3区精华液| 国产麻豆91在线视频| 97精品视频在线观看| 最近的中文字幕在线mv视频| 特级无码毛片免费视频播放| 搡老妇人老女人老熟女| 日本性感美女视频网站| 97人妻无码AV碰碰视频| 2022中文字幕在线| 在线观看国产免费麻豆| 日韩美女精品视频在线观看网站| 偷拍自拍亚洲美腿丝袜| 人妻丰满熟妇综合网| 97国产福利小视频合集| 91精品国产观看免费| 黑人乱偷人妻中文字幕| 日本少妇人妻xxxxxhd| 蜜桃精品久久久一区二区| wwwxxx一级黄色片| 精品久久婷婷免费视频| 在线播放国产黄色av| 韩国AV无码不卡在线播放| 日本xx片在线观看| 国产激情av网站在线观看| 黄色无码鸡吧操逼视频| 日本午夜久久女同精女女| 一区二区三区麻豆福利视频| 国产欧美精品一区二区高清| 国产高清在线观看1区2区| 亚洲中文精品字幕在线观看| 1769国产精品视频免费观看| 亚洲av香蕉一区区二区三区犇| 93精品视频在线观看| 亚洲精品国产综合久久久久久久久 | 免费观看成年人视频在线观看| 亚洲免费av在线视频| 成人高潮aa毛片免费| 日本韩国在线观看一区二区| 日比视频老公慢点好舒服啊| 人妻丰满熟妇综合网| 亚洲人一区二区中文字幕| 成人av免费不卡在线观看| 亚洲综合乱码一区二区| 午夜免费观看精品视频| 一区二区三区在线视频福利| 91色老99久久九九爱精品| 黑人乱偷人妻中文字幕| 午夜青青草原网在线观看| 久久久久久性虐视频| 国产精品国色综合久久| 女人精品内射国产99| 亚洲蜜臀av一区二区三区九色| 偷拍自拍 中文字幕| 人妻少妇av在线观看| 欧美日本aⅴ免费视频| 亚洲av日韩av网站| 人妻熟女中文字幕aⅴ在线| 男人的网址你懂的亚洲欧洲av| 久久久久五月天丁香社区| 国产亚洲欧美视频网站| 久草视频福利在线首页| 在线视频免费观看网| 日本性感美女三级视频| 精产国品久久一二三产区区别| 夜女神免费福利视频| 老司机福利精品免费视频一区二区| 在线观看日韩激情视频| 社区自拍揄拍尻屁你懂的| 亚洲精品精品国产综合| 摧残蹂躏av一二三区| 久久久精品999精品日本| 天天操天天爽天天干| 国产清纯美女al在线| 国产一区av澳门在线观看| 一区二区三区四区五区性感视频| 日韩少妇人妻精品无码专区| 黑人性生活视频免费看| 日韩人妻xxxxx| 美女福利写真在线观看视频| 青青青艹视频在线观看| 日韩剧情片电影在线收看| 亚洲av日韩精品久久久| 天堂资源网av中文字幕| 一区国内二区日韩三区欧美| 欧美精品中文字幕久久二区| 扒开让我视频在线观看| 国产性生活中老年人视频网站| 18禁美女无遮挡免费| 又粗又硬又猛又爽又黄的| 免费在线播放a级片| 久青青草视频手机在线免费观看 | 又色又爽又黄的美女裸体| 久久www免费人成一看片| 青青青国产片免费观看视频| 风流唐伯虎电视剧在线观看 | 日韩加勒比东京热二区| 91国内精品自线在拍白富美| 日本一区精品视频在线观看| 天堂av在线播放免费| 天天操天天操天天碰| 最新黄色av网站在线观看| 无码精品一区二区三区人| 99热国产精品666| 国产+亚洲+欧美+另类| 日本女大学生的黄色小视频| 欧美日本在线视频一区| 中文字幕亚洲中文字幕| 免费男阳茎伸入女阳道视频 | 国产精品成久久久久三级蜜臀av| 亚洲天堂精品福利成人av| 性感美女福利视频网站| 一区二区三区久久久91| 日美女屁股黄邑视频| 亚洲日产av一区二区在线| 色综合久久久久久久久中文| 亚洲人妻av毛片在线| 黑人借宿ntr人妻的沦陷2| 最后99天全集在线观看| 欧美美女人体视频一区| 91精品国产综合久久久蜜| 在线观看免费av网址大全| 亚洲视频在线观看高清| 激情啪啪啪啪一区二区三区| 超碰在线中文字幕一区二区| 国产内射中出在线观看| 国产一区二区欧美三区| 大香蕉日本伊人中文在线| 国产亚洲四十路五十路| 丝袜国产专区在线观看| 99久久激情婷婷综合五月天| 啊啊啊视频试看人妻| 蜜桃专区一区二区在线观看| 国产妇女自拍区在线观看| 最新国产精品网址在线观看| 国产精品一区二区久久久av| 色综合天天综合网国产成人| 涩爱综合久久五月蜜臀| 成人国产影院在线观看| 国产不卡av在线免费| 在线免费观看亚洲精品电影| 日日摸夜夜添夜夜添毛片性色av| 老司机福利精品免费视频一区二区| 天天色天天操天天透| 亚洲人妻av毛片在线| 欧美黑人与人妻精品| 黄色视频在线观看高清无码 | 青青草精品在线视频观看| 成人福利视频免费在线| 精品一区二区三区欧美| 91色秘乱一区二区三区| 换爱交换乱高清大片| 91九色porny国产蝌蚪视频| 亚洲高清视频在线不卡| 久久久91蜜桃精品ad| gay gay男男瑟瑟在线网站| 五十路人妻熟女av一区二区| 又粗又硬又猛又爽又黄的| lutube在线成人免费看| 午夜大尺度无码福利视频| 2012中文字幕在线高清| 青青伊人一精品视频| 色狠狠av线不卡香蕉一区二区| 天天色天天操天天透| chinese国产盗摄一区二区 | 国产va在线观看精品| 亚洲激情偷拍一区二区| 一区二区三区毛片国产一区| 精品av久久久久久久| 午夜精品一区二区三区福利视频 | 91精品国产观看免费| 国产在线观看免费人成短视频| 久久麻豆亚洲精品av| av手机在线观播放网站| 午夜在线观看岛国av,com| 精品亚洲国产中文自在线| 色吉吉影音天天干天天操| 亚洲 清纯 国产com| 亚洲一区二区三区精品视频在线| 中文字幕高清在线免费播放| 欧美亚洲一二三区蜜臀| 国产精品系列在线观看一区二区| 极品性荡少妇一区二区色欲| 日本性感美女三级视频| 亚洲高清国产一区二区三区| 自拍偷拍 国产资源| 精品人妻一二三区久久| 免费无码人妻日韩精品一区二区 | 2020国产在线不卡视频 | 亚洲免费av在线视频| 黄色男人的天堂视频| 免费看国产av网站| 美女 午夜 在线视频| 免费观看成年人视频在线观看| 国产美女午夜福利久久| 日韩一区二区电国产精品| 欧美视频不卡一区四区| 成人18禁网站在线播放| 亚洲一区二区三区偷拍女厕91| 亚洲1卡2卡三卡4卡在线观看| 欧美黑人性暴力猛交喷水| 做爰视频毛片下载蜜桃视频1| 搞黄色在线免费观看| 啊啊啊视频试看人妻| av在线免费观看亚洲天堂| 婷婷综合蜜桃av在线| 在线免费观看视频一二区| 一区二区三区精品日本| 9色在线视频免费观看| 欧美一区二区三区激情啪啪啪 | 日本精品一区二区三区在线视频。 | 免费无码人妻日韩精品一区二区| 97少妇精品在线观看| 欧美精品亚洲精品日韩在线| 日本a级视频老女人| 精品久久久久久久久久久a√国产| 中文字幕 码 在线视频| 亚洲av日韩高清hd| 天天操天天插天天色| 91www一区二区三区| 青草亚洲视频在线观看| 91精品国产黑色丝袜| 国产又粗又猛又爽又黄的视频在线 | 成年人啪啪视频在线观看| 国产一区二区欧美三区| 特大黑人巨大xxxx| 欧美精品免费aaaaaa| 天天射夜夜操综合网| 桃色视频在线观看一区二区| 亚洲av人人澡人人爽人人爱| 亚洲va天堂va国产va久| 大鸡吧插逼逼视频免费看| 久久久久五月天丁香社区| 爱有来生高清在线中文字幕| 少妇一区二区三区久久久| 中文字幕视频一区二区在线观看 | 精品av国产一区二区三区四区| 91综合久久亚洲综合| 天天操夜夜骑日日摸| 日本乱人一区二区三区| 激情人妻校园春色亚洲欧美 | 真实国模和老外性视频| 国产精品日韩欧美一区二区| 青青青国产免费视频| 第一福利视频在线观看| 亚洲av日韩精品久久久久久hd| 在线免费观看黄页视频| 亚洲天堂成人在线观看视频网站| 天天做天天干天天操天天射| 在线视频精品你懂的| 免费十精品十国产网站| 国产午夜亚洲精品不卡在线观看 | 亚洲中文字幕人妻一区| 亚洲2021av天堂| 午夜精品福利一区二区三区p | 韩国爱爱视频中文字幕| 日本性感美女三级视频| 91久久综合男人天堂| 国产高清97在线观看视频| 这里有精品成人国产99| 日本午夜久久女同精女女| 中文字幕1卡1区2区3区| 国产黄色高清资源在线免费观看| 欧美在线偷拍视频免费看| 亚洲av自拍偷拍综合| 亚洲av无码成人精品区辽| 早川濑里奈av黑人番号| 男女啪啪啪啪啪的网站| 人妻爱爱 中文字幕| 亚洲图库另类图片区| 老司机免费福利视频网| 精品美女在线观看视频在线观看| 男女啪啪啪啪啪的网站| 欧美在线偷拍视频免费看| 中文字幕日韩无敌亚洲精品| 国产又粗又硬又猛的毛片视频| 亚洲公开视频在线观看| 日韩亚洲高清在线观看| 91精品激情五月婷婷在线| 亚洲欧美综合另类13p| 免费费一级特黄真人片 | 老司机免费视频网站在线看| 40道精品招牌菜特色| 人妻自拍视频中国大陆| 亚洲午夜电影之麻豆| 自拍偷拍,中文字幕| 亚洲精品一线二线在线观看 | rct470中文字幕在线| 午夜精品在线视频一区| 一区二区三区 自拍偷拍| 色婷婷综合激情五月免费观看| 亚洲最大黄了色网站| 亚洲偷自拍高清视频| 色伦色伦777国产精品| av老司机亚洲一区二区| av在线免费中文字幕| 鸡巴操逼一级黄色气| chinese国产盗摄一区二区| 女生自摸在线观看一区二区三区| 精品国产乱码一区二区三区乱| 欧美久久久久久三级网| 视频在线免费观看你懂得| 亚洲伊人av天堂有码在线| 久久久精品999精品日本| 东游记中文字幕版哪里可以看到| 天天操天天干天天插| 无码精品一区二区三区人 | 亚洲熟妇久久无码精品| 欧美视频一区免费在线| 天天日天天舔天天射进去| 午夜精品福利91av| 亚洲国产精品中文字幕网站| 国产欧美精品一区二区高清| 黑人解禁人妻叶爱071| 91 亚洲视频在线观看| 黑人大几巴狂插日本少妇| 精品国产乱码一区二区三区乱| 亚洲福利午夜久久久精品电影网| 色综合久久五月色婷婷综合| 动色av一区二区三区| 日本一本午夜在线播放| 成年午夜免费无码区| 亚洲一区二区久久久人妻| 中文字幕日韩91人妻在线| 国产高清97在线观看视频| 99久久99一区二区三区| 日韩成人综艺在线播放| 91精品国产综合久久久蜜| 国产麻豆国语对白露脸剧情| 精品黑人一区二区三区久久国产| 国产麻豆剧传媒精品国产av蜜桃| 2022精品久久久久久中文字幕| 91色网站免费在线观看| 国产av国片精品一区二区| 国产超码片内射在线| 久久久精品999精品日本| 免费国产性生活视频| huangse网站在线观看| 久久免费看少妇高潮完整版| 播放日本一区二区三区电影| 国产精品久久久久久久精品视频| 成人av免费不卡在线观看| 天天艹天天干天天操| 黄色视频成年人免费观看| av森泽佳奈在线观看| 97香蕉碰碰人妻国产樱花| 亚洲一区二区三区偷拍女厕91| 国产大鸡巴大鸡巴操小骚逼小骚逼| 好吊视频—区二区三区| 91香蕉成人app下载| 日本三极片中文字幕| 懂色av之国产精品| 国产又粗又猛又爽又黄的视频在线| 丝袜亚洲另类欧美变态| 亚洲精品亚洲人成在线导航| 9色在线视频免费观看| 女生被男生插的视频网站| 欧美日韩一区二区电影在线观看| 亚洲中文精品字幕在线观看| 免费在线看的黄片视频| 欧美一区二区三区四区性视频| 91p0rny九色露脸熟女| 午夜精品一区二区三区城中村| 伊人日日日草夜夜草| 欧美日韩人妻久久精品高清国产| 狍和女人的王色毛片| 黑人变态深video特大巨大| 天堂中文字幕翔田av| 男人操女人逼逼视频网站| 亚洲自拍偷拍精品网| 亚洲图库另类图片区| 超pen在线观看视频公开97| 日本欧美视频在线观看三区| 国产成人精品一区在线观看| 91九色porny国产在线| 亚洲av无乱一区二区三区性色| 91精品资源免费观看| 天天操夜夜操天天操天天操 | 成人高清在线观看视频| 日韩在线视频观看有码在线| 亚洲中文字幕人妻一区| 亚洲黄色av网站免费播放| 18禁无翼鸟成人在线 | 无码国产精品一区二区高潮久久4|