3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

postgresql索引_PostgreSQL中的索引— 9(BRIN)

發(fā)布時(shí)間:2023/12/16 数据库 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 postgresql索引_PostgreSQL中的索引— 9(BRIN) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

postgresql索引

indexing engine, the interface of access methods, and the following methods: 索引引擎 ,訪問方法的接口以及以下方法: hash indexes, 哈希索引 , B-trees, B樹 , GiST, GiST , SP-GiST, SP-GiST , GIN, and GIN和RUM. The topic of this article is BRIN indexes.RUM 。 本文的主題是BRIN索引。

布林 (BRIN)

一般概念 (General concept)

Unlike indexes with which we've already got acquainted, the idea of BRIN is to avoid looking through definitely unsuited rows rather than quickly find the matching ones. This is always an inaccurate index: it does not contain TIDs of table rows at all.

與我們已經(jīng)熟悉的索引不同,BRIN的想法是避免瀏覽絕對不合適的行,而不是快速找到匹配的行。 這始終是一個(gè)不準(zhǔn)確的索引:它根本不包含表行的TID。

Simplistically, BRIN works fine for columns where values correlate with their physical location in the table. In other words, if a query without ORDER BY clause returns the column values virtually in the increasing or decreasing order (and there are no indexes on that column).

簡而言之,對于值與表中物理位置相關(guān)的列,BRIN可以很好地工作。 換句話說,如果沒有ORDER BY子句的查詢實(shí)際上以升序或降序返回列值(并且該列上沒有索引)。

This access method was created in scope of Axle, the European project for extremely large analytical databases, with an eye on tables that are several terabyte or dozens of terabytes large. An important feature of BRIN that enables us to create indexes on such tables is a small size and minimal overhead costs of maintenance.

這種訪問方法是在Axle的范圍內(nèi)創(chuàng)建的, Axle是用于大型分析數(shù)據(jù)庫的歐洲項(xiàng)目,著眼于幾TB或數(shù)十TB的表。 BRIN的一項(xiàng)重要功能使我們能夠在此類表上創(chuàng)建索引,它的體積小且維護(hù)開銷最小。

This works as follows. The table is split into ranges that are several pages large (or several blocks large, which is the same) — hence the name: Block Range Index, BRIN. The index stores summary information on the data in each range. As a rule, this is the minimal and maximal values, but it happens to be different, as shown further. Assume that a query is performed that contains the condition for a column; if the sought values do not get into the interval, the whole range can be skipped; but if they do get, all rows in all blocks will have to be looked through to choose the matching ones among them.

其工作原理如下。 表被分成多個(gè)顯示頁面大(或幾個(gè)塊大,這是相同的) 的范圍 -故名:塊范圍索引,布林。 索引存儲有關(guān)每個(gè)范圍中數(shù)據(jù)的摘要信息 。 通常,這是最小值和最大值,但碰巧是不同的,如進(jìn)一步所示。 假設(shè)執(zhí)行的查詢包含列的條件; 如果所搜索的值未進(jìn)入該間隔,則可以跳過整個(gè)范圍; 但如果確實(shí)獲得,則必須仔細(xì)檢查所有塊中的所有行,以在其中選擇匹配的行。

It will not be a mistake to treat BRIN not as an index, but as an accelerator of sequential scan. We can regard BRIN as an alternative to partitioning if we consider each range as a ?virtual? partition.

將BRIN視為索引,而不是順序掃描的加速器,這不是錯(cuò)誤的。 如果我們將每個(gè)范圍視為“虛擬”分區(qū),則可以將BRIN視為分區(qū)的替代方案。

Now let's discuss the structure of the index in more detail.

現(xiàn)在讓我們更詳細(xì)地討論索引的結(jié)構(gòu)。

結(jié)構(gòu)體 (Structure)

The first (more exactly, zero) page contains the metadata.

第一頁(更確切地說是零)包含元數(shù)據(jù)。

Pages with the summary information are located at a certain offset from the metadata. Each index row on those pages contains summary information on one range.

帶有摘要信息的頁面與元數(shù)據(jù)之間有一定的偏移量。 這些頁面上的每個(gè)索引行都包含一個(gè)范圍的摘要信息。

Between the meta page and summary data, pages with the reverse range map (abbreviated as ?revmap?) are located. Actually, this is an array of pointers (TIDs) to the corresponding index rows.

在元頁面和摘要數(shù)據(jù)之間,找到具有反向范圍圖 (簡稱為“ revmap”)的頁面。 實(shí)際上,這是指向相應(yīng)索引行的指針(TID)的數(shù)組。

For some ranges, the pointer in ?revmap? can lead to no index row (one is marked in gray in the figure). In such a case, the range is considered to have no summary information yet.

對于某些范圍,?revmap?中的指針可能不會導(dǎo)致索引行(圖中的灰色標(biāo)記為一個(gè))。 在這種情況下,該范圍被認(rèn)為還沒有摘要信息。

掃描索引 (Scanning the index)

How is the index used if it does not contain references to table rows? This access method certainly cannot return rows TID by TID, but it can build a bitmap. There can be two kinds of bitmap pages: accurate, to the row, and inaccurate, to the page. It's an inaccurate bitmap that is used.

如果索引不包含對表行的引用,該如何使用? 這種訪問方法當(dāng)然不能按TID逐行返回TID,但可以構(gòu)建位圖。 位圖頁面可以有兩種:精確到位的頁面和不精確的頁面。 使用的是不正確的位圖。

The algorithm is simple. The map of ranges is sequentially scanned (that is, the ranges are went through in the order of their location in the table). The pointers are used to determine index rows with summary information on each range. If a range does not contain the value sought, it is skipped, and if it can contain the value (or summary information is unavailable), all pages of the range are added to the bitmap. The resulting bitmap is then used as usual.

該算法很簡單。 依次掃描范圍圖(即,范圍按照表中位置的順序進(jìn)行瀏覽)。 指針用于確定帶有每個(gè)范圍的摘要信息的索引行。 如果范圍不包含所尋求的值,則將其跳過,并且如果范圍可以包含該值(或摘要信息不可用),則該范圍的所有頁面都將添加到位圖中。 然后,照常使用生成的位圖。

更新索引 (Updating the index)

It is more interesting how the index is updated when the table is changed.

更改表時(shí)如何更新索引更有趣。

When adding a new version of a row to a table page, we determine which range it is contained in and use the map of ranges to find the index row with the summary information. All these are simple arithmetic operations. Let, for instance, the size of a range be four and on page 13, a row version with the value of 42 occur. The number of the range (starting with zero) is 13?/?4?=?3, therefore, in ?revmap? we take the pointer with the offset of 3 (its order number is four).

當(dāng)新版本的行添加到表頁面時(shí),我們確定該行包含在哪個(gè)范圍中,并使用范圍圖查找包含摘要信息的索引行。 所有這些都是簡單的算術(shù)運(yùn)算。 例如,假設(shè)范圍的大小為4,然后在第13頁上,出現(xiàn)值為42的行版本。 范圍的數(shù)字(從零開始)是13/4 = 3,因此,在《 revmap》中,我們采用偏移量為3的指針(其順序號為4)。

The minimal value for this range is 31, and the maximal one is 40. Since the new value of 42 is out of the interval, we update the maximal value (see the figure). But if the new value is still within the stored limits, the index does not need to be updated.

此范圍的最小值為31,最大值為40。由于新值42不在間隔內(nèi),因此我們更新最大值(請參見圖)。 但是,如果新值仍在存儲的限制內(nèi),則無需更新索引。

All this relates to the situation when the new version of the page occurs in a range for which the summary information is available. When the index is created, the summary information is computed for all ranges available, but while the table is further expanded, new pages can occur that fall out of the limits. Two options are available here:

所有這些都與頁面的新版本出現(xiàn)在可使用摘要信息的范圍內(nèi)的情況有關(guān)。 創(chuàng)建索引時(shí),將為所有可用范圍計(jì)算摘要信息,但是在進(jìn)一步擴(kuò)展表時(shí),可能會出現(xiàn)超出限制的新頁面。 這里有兩個(gè)選項(xiàng):

  • Usually the index is not updated immediately. This is not a big deal: as already mentioned, when scanning the index, the whole range will be looked through. Actual update is done during ?vacuum?, or it can be done manually by calling ?brin_summarize_new_values? function.

    通常,索引不會立即更新。 沒什么大不了的:如前所述,在掃描索引時(shí),將瀏覽整個(gè)范圍。 實(shí)際更新是在“真空”期間完成的,也可以通過調(diào)用“ brin_summarize_new_values”函數(shù)手動(dòng)完成。
  • If we create the index with ?autosummarize? parameter, the update will be done immediately. But when pages of the range are populated with new values, updates can happen too often, therefore, this parameter is turned off by default.

    如果我們使用?autosummarize?參數(shù)創(chuàng)建索引,則更新將立即完成。 但是,當(dāng)使用新值填充范圍頁面時(shí),更新可能會經(jīng)常發(fā)生,因此,默認(rèn)情況下此參數(shù)處于關(guān)閉狀態(tài)。
  • When new ranges occur, the size of ?revmap? can increase. Whenever the map, located between the meta page and summary data, needs to be extended by another page, existing row versions are moved to some other pages. So, the map of ranges is always located between the meta page and summary data.

    當(dāng)出現(xiàn)新范圍時(shí),?revmap?的大小可能會增加。 每當(dāng)位于元頁面和摘要數(shù)據(jù)之間的地圖需要由另一頁面擴(kuò)展時(shí),現(xiàn)有行版本就會移至其他頁面。 因此,范圍圖始終位于元頁面和摘要數(shù)據(jù)之間。

    When a row is deleted,… nothing happens. We can notice that sometimes the minimal or maximal value will be deleted, in which case the interval could be reduced. But to detect this, we would have to read all values in the range, and this is costly.

    當(dāng)刪除一行時(shí),…什么也沒有發(fā)生。 我們可以注意到,有時(shí)最小值或最大值將被刪除,在這種情況下可以減小間隔。 但是要檢測到這一點(diǎn),我們將必須讀取該范圍內(nèi)的所有值,這是昂貴的。

    The correctness of the index is not affected, but search may require looking through more ranges than is actually needed. In general, summary information can be manually recalculated for such a zone (by calling ?brin_desummarize_range? and ?brin_summarize_new_values? functions), but how can we detect such a need? Anyway, no conventional procedure is available to this end.

    索引的正確性不受影響,但是搜索可能需要查看比實(shí)際需要更多的范圍。 通常,可以手動(dòng)重新計(jì)算此類區(qū)域的摘要信息(通過調(diào)用?brin_desummarize_range?和?brin_summarize_new_values?函數(shù)),但是我們?nèi)绾螜z測到這種需求? 無論如何,沒有常規(guī)的程序可用于此目的。

    Finally, updating a row is just a deletion of the outdated version and addition of a new one.

    最后, 更新一行只是刪除過時(shí)的版本,而增加新的版本。

    (Example)

    Let's try to build our own mini data warehouse for the data from tables of the demo database. Let's assume that for the purpose of BI reporting, a denormalized table is needed to reflect the flights departed from an airport or landed in the airport to the accuracy of a seat in the cabin. The data for each airport will be added to the table once a day, when it is midnight in the appropriate time zone. The data will be neither updated nor deleted.

    讓我們嘗試為演示數(shù)據(jù)庫表中的數(shù)據(jù)構(gòu)建自己的小型數(shù)據(jù)倉庫。 假設(shè)出于BI報(bào)告的目的,需要使用非規(guī)范化表格來反映從機(jī)場起飛或降落在機(jī)場的航班到機(jī)艙座位的準(zhǔn)確性。 每個(gè)機(jī)場的數(shù)據(jù)每天都會在適當(dāng)時(shí)區(qū)的午夜12點(diǎn)添加到表中。 數(shù)據(jù)將不會被更新或刪除。

    The table will look as follows:

    該表如下所示:

    demo=# create table flights_bi(airport_code char(3),airport_coord point, -- geo coordinates of airportairport_utc_offset interval, -- time zoneflight_no char(6), -- flight numberflight_type text. -- flight type: departure / arrival scheduled_time timestamptz, -- scheduled departure/arrival time of flightactual_time timestamptz, -- actual time of flightaircraft_code char(3),seat_no varchar(4), -- seat numberfare_conditions varchar(10), -- travel classpassenger_id varchar(20),passenger_name text );

    We can simulate the procedure of loading the data using nested loops: an external one — by days (we will consider a?large database, therefore 365 days), and an internal loop — by time zones (from UTC+02 to UTC+12). The query is pretty long and not of particular interest, so I'll hide it under the spoiler.

    我們可以模擬使用嵌套循環(huán)加載數(shù)據(jù)的過程:一個(gè)外部循環(huán)-按天(我們將考慮一個(gè)大型數(shù)據(jù)庫 ,因此為365天),一個(gè)內(nèi)部循環(huán)-按時(shí)區(qū)(從UTC + 02到UTC + 12) 。 該查詢很長,并且沒有特別的興趣,因此我將其隱藏在擾流器下。

    模擬將數(shù)據(jù)加載到存儲中 (Simulation of loading the data to the storage)

    DO $$ <<local>> DECLAREcurdate date := (SELECT min(scheduled_departure) FROM flights);utc_offset interval; BEGINWHILE (curdate <= bookings.now()::date) LOOPutc_offset := interval '12 hours';WHILE (utc_offset >= interval '2 hours') LOOPINSERT INTO flights_biWITH flight (airport_code,airport_coord,flight_id,flight_no,scheduled_time,actual_time,aircraft_code,flight_type) AS (-- прибытияSELECT a.airport_code,a.coordinates,f.flight_id,f.flight_no,f.scheduled_departure,f.actual_departure,f.aircraft_code,'departure'FROM airports a,flights f,pg_timezone_names tznWHERE a.airport_code = f.departure_airportAND f.actual_departure IS NOT NULLAND tzn.name = a.timezoneAND tzn.utc_offset = local.utc_offsetAND timezone(a.timezone, f.actual_departure)::date = curdateUNION ALL-- вылетыSELECT a.airport_code,a.coordinates,f.flight_id,f.flight_no,f.scheduled_arrival,f.actual_arrival,f.aircraft_code,'arrival'FROM airports a,flights f,pg_timezone_names tznWHERE a.airport_code = f.arrival_airportAND f.actual_arrival IS NOT NULLAND tzn.name = a.timezoneAND tzn.utc_offset = local.utc_offsetAND timezone(a.timezone, f.actual_arrival)::date = curdate)SELECT f.airport_code,f.airport_coord,local.utc_offset,f.flight_no,f.flight_type,f.scheduled_time,f.actual_time,f.aircraft_code,s.seat_no,s.fare_conditions,t.passenger_id,t.passenger_nameFROM flight fJOIN seats sON s.aircraft_code = f.aircraft_codeLEFT JOIN boarding_passes bpON bp.flight_id = f.flight_idAND bp.seat_no = s.seat_noLEFT JOIN ticket_flights tfON tf.ticket_no = bp.ticket_noAND tf.flight_id = bp.flight_idLEFT JOIN tickets tON t.ticket_no = tf.ticket_no;RAISE NOTICE '%, %', curdate, utc_offset;utc_offset := utc_offset - interval '1 hour';END LOOP;curdate := curdate + 1;END LOOP; END; $$;demo=# select count(*) from flights_bi;count ----------30517076 (1 row)demo=# select pg_size_pretty(pg_total_relation_size('flights_bi'));pg_size_pretty ----------------4127 MB (1 row)

    We get 30 million rows and 4?GB. Not so large a size, but good enough for a laptop: sequential scan took me about 10?seconds.

    我們得到3000萬行和4 GB。 尺寸不算大,但足以用于筆記本電腦:順序掃描花了我大約10秒鐘。

    我們應(yīng)該在哪些列上創(chuàng)建索引? (On what columns should we create the index?)

    Since BRIN indexes have a small size and moderate overhead costs and updates happen infrequently, if any, a rare opportunity arises to build many indexes ?just in case?, for example, on all fields on which analyst users can create their ad-hoc queries. Won't come useful — never mind, but even an index that is not very efficient will work better than sequential scan for sure. Of course, there are fields on which it is absolutely useless to build an index; pure common sense will prompt them.

    由于BRIN索引的大小小且管理費(fèi)用適中,并且更新很少發(fā)生(如果有的話),因此出現(xiàn)了難得的機(jī)會(例如,以防萬一)建立許多索引,例如,在分析師用戶可以創(chuàng)建其臨時(shí)查詢的所有字段上。 不會有用-沒關(guān)系,但是即使是效率不高的索引也肯定會比順序掃描更好。 當(dāng)然,在某些字段上建立索引絕對是沒有用的。 純粹的常識會提示他們。

    But it should be odd to limit ourselves to this piece of advice, therefore, let's try to state a more accurate criterion.

    但是將自己限制在這條建議上應(yīng)該很奇怪,因此,讓我們嘗試提出一個(gè)更準(zhǔn)確的標(biāo)準(zhǔn)。

    We've already mentioned that the data must somewhat correlate with its physical location. Here it makes sense to remember that PostgreSQL gathers table column statistics, which include the correlation value. The planner uses this value to select between a regular index scan and bitmap scan, and we can use it to estimate the applicability of BRIN index.

    我們已經(jīng)提到,數(shù)據(jù)必須與其物理位置有所關(guān)聯(lián)。 這里要記住,PostgreSQL收集表列統(tǒng)計(jì)信息,其中包括相關(guān)值。 計(jì)劃者使用此值在常規(guī)索引掃描和位圖掃描之間進(jìn)行選擇,我們可以使用它來估計(jì)BRIN索引的適用性。

    In the above example, the data is evidently ordered by days (by ?scheduled_time?, as well as by ?actual_time? — there is no much difference). This is because when rows are added to the table (without deletions and updates), they are laid out in the file one after another. In the simulation of data loading we did not even use ORDER BY clause, therefore, dates within a day can be, in general, mixed up in an arbitrary way, but ordering must be in place. Let's check this:

    在上面的示例中,數(shù)據(jù)顯然按天排序(按“ scheduled_time”和“ actual_time”排序-差別不大)。 這是因?yàn)閷⑿刑砑拥奖碇?沒有刪除和更新)時(shí),它們在文件中一個(gè)接一個(gè)地排列。 在數(shù)據(jù)加載的模擬中,我們甚至沒有使用ORDER BY子句,因此,通常一天內(nèi)的日期可以以任意方式混合,但是必須有序。 讓我們檢查一下:

    demo=# analyze flights_bi;demo=# select attname, correlation from pg_stats where tablename='flights_bi' order by correlation desc nulls last;attname | correlation --------------------+-------------scheduled_time | 0.999994actual_time | 0.999994fare_conditions | 0.796719flight_type | 0.495937airport_utc_offset | 0.438443aircraft_code | 0.172262airport_code | 0.0543143flight_no | 0.0121366seat_no | 0.00568042passenger_name | 0.0046387passenger_id | -0.00281272airport_coord | (12 rows)

    The value that is not too close to zero (ideally, near plus-minus one, as in this case), tells us that BRIN index will be appropriate.

    該值不太接近零(在這種情況下,理想情況下,接近正負(fù)1)告訴我們BRIN指數(shù)是合適的。

    The travel class ?fare_condition? (the column contains three unique values) and type of the flight ?flight_type? (two unique values) unexpectedly appeared to be in the second and third places. This is an illusion: formally the correlation is high, while actually on several successive pages all possible values will be encountered for sure, which means that BRIN won't do any good.

    出差航班類別“ fare_condition?(該列包含三個(gè)唯一值)和航班類型“ flight_type?(兩個(gè)唯一值)出乎意料地位于第二和第三位。 這是一種錯(cuò)覺:形式上的相關(guān)性很高,而實(shí)際上在幾個(gè)連續(xù)的頁面上肯定會遇到所有可能的值,這意味著BRIN不會發(fā)揮任何作用。

    The time zone ?airport_utc_offset? goes next: in the considered example, within a day cycle, airports are ordered by time zones ?by construction?.

    接下來是時(shí)區(qū)“ airport_utc_offset”:在所考慮的示例中,在一天周期內(nèi),按時(shí)區(qū)“按構(gòu)造”對機(jī)場進(jìn)行了排序。

    It's these two fields, time and time zone, that we will further experiment with.

    我們將進(jìn)一步試驗(yàn)這兩個(gè)字段(時(shí)間和時(shí)區(qū))。

    可能削弱相關(guān)性 (Possible weakening of the correlation)

    The correlation that is place ?by construction? can be easily weakened when the data is changed. And the matter here is not in a change to a particular value, but in the structure of the multiversion concurrency control: the outdated row version is deleted on one page, but a new version may be inserted wherever free space is available. Due to this, whole rows get mixed up during updates.

    更改數(shù)據(jù)時(shí),很容易削弱“構(gòu)造”位置的相關(guān)性。 此處的問題不是更改特定值,而是多版本并發(fā)控件的結(jié)構(gòu):過時(shí)的行版本在一頁上被刪除,但是只要有可用空間,就可以插入新版本。 因此,整個(gè)行在更新期間會混合在一起。

    We can partially control this effect by reducing the value of ?fillfactor? storage parameter and this way leaving free space on a page for future updates. But do we want to increase the size of an already huge table? Besides, this does not resolve the issue of deletions: they also ?set traps? for new rows by freeing the space somewhere inside existing pages. Due to this, rows that otherwise would get to the end of file, will be inserted at some arbitrary place.

    我們可以通過減小?fillfactor?存儲參數(shù)的值來部分控制此效果,并通過這種方式在頁面上留下可用空間以供將來更新。 但是,我們是否要增加已經(jīng)很大的桌子的大小? 此外,這不能解決刪除問題:它們還通過釋放現(xiàn)有頁面內(nèi)某處的空間來為新行“設(shè)置陷阱”。 因此,否則將到達(dá)文件末尾的行將插入到任意位置。

    By the way, this is a curious fact. Since BRIN index does not contain references to table rows, its availability should not hinder HOT updates at all, but it does.

    順便說一句,這是一個(gè)奇怪的事實(shí)。 由于BRIN索引不包含對表行的引用,因此它的可用性不應(yīng)完全阻止HOT更新,但它確實(shí)可以。

    So, BRIN is mainly designed for tables of large and even huge sizes that are either not updated at all or updated very slightly. However, it perfectly copes with the addition of new rows (to the end of the table). This is not surprising since this access method was created with a view to data warehouses and analytical reporting.

    因此,BRIN主要設(shè)計(jì)用于甚至根本不更新或更新很小的大型甚至大型表。 但是,它完美地應(yīng)對了新行的增加(到表的末尾)。 這并不奇怪,因?yàn)閯?chuàng)建此訪問方法是為了查看數(shù)據(jù)倉庫和分析報(bào)告。

    我們需要選擇什么大小的范圍? (What size of a range do we need to select?)

    If we deal with a terabyte table, our main concern when selecting the size of a range will probably be not to make BRIN index too large. However, in our situation, we can afford analyzing data more accurately.

    如果處理一個(gè)TB的表,那么在選擇范圍大小時(shí),我們主要關(guān)心的可能不是使BRIN索引太大。 但是,在我們的情況下,我們可以提供更準(zhǔn)確的數(shù)據(jù)分析能力。

    To do this, we can select unique values of a column and see on how many pages they occur. Localization of the values increases the chances of success in applying BRIN index. Moreover, the found number of pages will prompt the size of a range. But if the value is ?spread? over all pages, BRIN is useless.

    為此,我們可以選擇列的唯一值,并查看它們出現(xiàn)在多少頁上。 值的本地化增加了成功應(yīng)用BRIN指數(shù)的機(jī)會。 此外,找到的頁數(shù)將提示范圍的大小。 但是,如果該值在所有頁面上都“傳播”,則BRIN是無用的。

    Of course, we should use this technique keeping a watchful eye on an internal structure of the data. For example, it makes no sense to consider each date (more exactly, a timestamp, also including time) as a unique value — we need to round it to days.

    當(dāng)然,我們應(yīng)該使用這種技術(shù)來密切注意數(shù)據(jù)的內(nèi)部結(jié)構(gòu)。 例如,將每個(gè)日期(更確切地說是時(shí)間戳,還包括時(shí)間)視為唯一值是沒有意義的-我們需要將其舍入為幾天。

    Technically, this analysis can be done by looking at the value of the hidden ?ctid? column, which provides the pointer to a row version (TID): the number of the page and the number of the row inside the page. Unfortunately, there is no conventional technique to decompose TID into its two components, therefore, we have to cast types through the text representation:

    從技術(shù)上講,可以通過查看隱藏的“ ctid”列的值來完成此分析,該值提供了指向行版本(TID)的指針:頁面數(shù)和頁面內(nèi)行數(shù)。 不幸的是,沒有傳統(tǒng)的技術(shù)可以將TID分解為兩個(gè)部分,因此,我們必須通過文本表示來轉(zhuǎn)換類型:

    demo=# select min(numblk), round(avg(numblk)) avg, max(numblk) from ( select count(distinct (ctid::text::point)[0]) numblkfrom flights_bigroup by scheduled_time::date ) t;min | avg | max ------+------+------1192 | 1500 | 1796 (1 row)demo=# select relpages from pg_class where relname = 'flights_bi';relpages ----------528172 (1 row)

    We can see that each day is distributed across pages pretty evenly, and days are slightly mixed up with each other (1500?&times 365?= 547500, which is only a little larger than the number of pages in the table 528172). This is actually clear ?by construction? anyway.

    我們可以看到,每天幾乎均勻地分布在頁面上,并且天彼此之間略有混淆(1500&times 365 = 547500,這僅比表528172中的頁面數(shù)大一點(diǎn))。 無論如何,這實(shí)際上是“通過建設(shè)”明確的。

    Valuable information here is a specific number of pages. With a conventional range size of 128 pages, each day will populate 9–14 ranges. This seems realistic: with a query for a specific day, we can expect an error around 10%.

    此處的重要信息是特定數(shù)量的頁面。 傳統(tǒng)的范圍大小為128頁,每天將填充9-14個(gè)范圍。 這似乎很現(xiàn)實(shí):查詢特定的一天,我們可以預(yù)期出現(xiàn)10%左右的錯(cuò)誤。

    Let's try:

    我們試試吧:

    demo=# create index on flights_bi using brin(scheduled_time);

    The size of the index is as small as 184?KB:

    索引的大小小至184 KB:

    demo=# select pg_size_pretty(pg_total_relation_size('flights_bi_scheduled_time_idx'));pg_size_pretty ----------------184 kB (1 row)

    In this case, it hardly makes sense to increase the size of a range at the cost of losing the accuracy. But we can reduce the size if required, and the accuracy will, on the contrary, increase (along with the size of the index).

    在這種情況下,以損失精度為代價(jià)增加范圍的大小幾乎沒有意義。 但是如果需要,我們可以減小大小,相反,準(zhǔn)確性會提高(以及索引的大小)。

    Now let's look at time zones. Here we cannot use a brute-force approach either. All values should be divided by the number of day cycles instead since the distribution is repeated within each day. Besides, since there are few time zones only, we can look at the entire distribution:

    現(xiàn)在讓我們看一下時(shí)區(qū)。 在這里,我們也不能使用暴力手段。 所有值都應(yīng)除以天周期數(shù),而不是因?yàn)槊刻於紩貜?fù)分配。 此外,由于只有幾個(gè)時(shí)區(qū),我們可以查看整個(gè)分布:

    demo=# select airport_utc_offset, count(distinct (ctid::text::point)[0])/365 numblk from flights_bi group by airport_utc_offset order by 2;airport_utc_offset | numblk --------------------+--------12:00:00 | 606:00:00 | 802:00:00 | 1011:00:00 | 1308:00:00 | 2809:00:00 | 2910:00:00 | 4004:00:00 | 4707:00:00 | 11005:00:00 | 23103:00:00 | 932 (11 rows)

    On average, the data for each time zone populates 133?pages a day, but the distribution is highly non-uniform: Petropavlovsk-Kamchatskiy and Anadyr fit as few as six pages, while Moscow and its neighborhood require hundreds of them. The default size of a range is no good here; let's, for example, set it to four pages.

    平均而言,每個(gè)時(shí)區(qū)的數(shù)據(jù)每天填充133頁,但分布高度不均勻:Petropavlovsk-Kamchatskiy和Anadyr僅有六頁,而莫斯科及其附近地區(qū)則需要數(shù)百頁。 范圍的默認(rèn)大小在這里不合適。 例如,將其設(shè)置為四個(gè)頁面。

    demo=# create index on flights_bi using brin(airport_utc_offset) with (pages_per_range=4);demo=# select pg_size_pretty(pg_total_relation_size('flights_bi_airport_utc_offset_idx'));pg_size_pretty ----------------6528 kB (1 row)

    執(zhí)行計(jì)劃 (Execution plan)

    Let's look at how our indexes work. Let's select some day, say, a week ago (in the demo database, ?today? is determined by ?booking.now? function):

    讓我們看一下索引的工作方式。 讓我們選擇某天,例如一周前(在演示數(shù)據(jù)庫中,“今天”由“ booking.now”函數(shù)確定):

    demo=# \set d 'bookings.now()::date - interval \'7 days\''demo=# explain (costs off,analyze)select *from flights_biwhere scheduled_time >= :d and scheduled_time < :d + interval '1 day';QUERY PLAN --------------------------------------------------------------------------------Bitmap Heap Scan on flights_bi (actual time=10.282..94.328 rows=83954 loops=1)Recheck Cond: ...Rows Removed by Index Recheck: 12045Heap Blocks: lossy=1664-> Bitmap Index Scan on flights_bi_scheduled_time_idx(actual time=3.013..3.013 rows=16640 loops=1)Index Cond: ...Planning time: 0.375 msExecution time: 97.805 ms

    As we can see, the planner used the index created. How accurate is it? The ratio of the number of rows that meet the query conditions (?rows? of Bitmap Heap Scan node) to the total number of rows returned using the index (the same value plus Rows Removed by Index Recheck) tells us about this. In this case 83954?/?(83954?+?12045), which is approximately 90%, as expected (this value will change from one day to another).

    如我們所見,計(jì)劃者使用了創(chuàng)建的索引。 它有多精確? 滿足查詢條件的行數(shù)(“位圖堆掃描”節(jié)點(diǎn)的“行”)與使用索引返回的總行數(shù)(相同的值加上通過索引重新檢查刪除的行)之比告訴我們這一點(diǎn)。 在這種情況下,為83954 /(83954 + 12045),大約為預(yù)期值的90%(此值將一天到一天更改)。

    Where does the 16640 number in ?actual rows? of Bitmap Index Scan node originate from? The thing is that this node of the plan builds an inaccurate (page-by-page) bitmap and is completely unaware of how many rows the bitmap will touch, while something needs to be shown. Therefore, in despair one page is assumed to contain 10 rows. The bitmap contains 1664 pages in total (this value is shown in ?Heap Blocks: lossy=1664?); so, we just get 16640. Altogether, this is a senseless number, which we should not pay attention to.

    位圖索引掃描節(jié)點(diǎn)的“實(shí)際行”中的16640數(shù)字從何而來? 問題在于,該計(jì)劃的該節(jié)點(diǎn)將構(gòu)建不準(zhǔn)確的(逐頁)位圖,并且完全不知道該位圖將觸摸多少行,而需要顯示某些內(nèi)容。 因此,絕望地假設(shè)一頁包含10行。 位圖總共包含1664頁(此值在《堆塊:有損= 1664》中顯示); 因此,我們只得到16640。這是一個(gè)毫無意義的數(shù)字,我們不應(yīng)該注意。

    How about airports? For example, let's take the time zone of Vladivostok, which populates 28 pages a day:

    機(jī)場呢? 例如,讓我們以符拉迪沃斯托克(Vladivostok)的時(shí)區(qū)為例,該時(shí)區(qū)每天填充28頁:

    demo=# explain (costs off,analyze)select *from flights_biwhere airport_utc_offset = interval '8 hours';QUERY PLAN ----------------------------------------------------------------------------------Bitmap Heap Scan on flights_bi (actual time=75.151..192.210 rows=587353 loops=1)Recheck Cond: (airport_utc_offset = '08:00:00'::interval)Rows Removed by Index Recheck: 191318Heap Blocks: lossy=13380-> Bitmap Index Scan on flights_bi_airport_utc_offset_idx(actual time=74.999..74.999 rows=133800 loops=1)Index Cond: (airport_utc_offset = '08:00:00'::interval)Planning time: 0.168 msExecution time: 212.278 ms

    The planner again uses the BRIN index created. The accuracy is worse (about 75% in this case), but this is expected since the correlation is lower.

    計(jì)劃者再次使用創(chuàng)建的BRIN索引。 準(zhǔn)確性較差(在這種情況下約為75%),但這是可以預(yù)期的,因?yàn)橄嚓P(guān)性較低。

    Several BRIN indexes (just like any other ones) can certainly be joined at the bitmap level. For example, the following is the data on the selected time zone for a month (notice ?BitmapAnd? node):

    當(dāng)然,可以在位圖級別上連接幾個(gè)BRIN索引(就像其他索引一樣)。 例如,以下是所選時(shí)區(qū)一個(gè)月的數(shù)據(jù)(注意“ BitmapAnd”節(jié)點(diǎn)):

    demo=# \set d 'bookings.now()::date - interval \'60 days\''demo=# explain (costs off,analyze)select *from flights_biwhere scheduled_time >= :d and scheduled_time < :d + interval '30 days'and airport_utc_offset = interval '8 hours';QUERY PLAN ---------------------------------------------------------------------------------Bitmap Heap Scan on flights_bi (actual time=62.046..113.849 rows=48154 loops=1)Recheck Cond: ...Rows Removed by Index Recheck: 18856Heap Blocks: lossy=1152-> BitmapAnd (actual time=61.777..61.777 rows=0 loops=1)-> Bitmap Index Scan on flights_bi_scheduled_time_idx(actual time=5.490..5.490 rows=435200 loops=1)Index Cond: ...-> Bitmap Index Scan on flights_bi_airport_utc_offset_idx(actual time=55.068..55.068 rows=133800 loops=1)Index Cond: ...Planning time: 0.408 msExecution time: 115.475 ms

    與B樹比較 (Comparison with B-tree)

    What if we create regular B-tree index on the same field as BRIN?

    如果我們在與BRIN相同的字段上創(chuàng)建常規(guī)B樹索引,該怎么辦?

    demo=# create index flights_bi_scheduled_time_btree on flights_bi(scheduled_time);demo=# select pg_size_pretty(pg_total_relation_size('flights_bi_scheduled_time_btree'));pg_size_pretty ----------------654 MB (1 row)

    It appeared to be several thousand times larger than our BRIN! However, the query is performed a little faster: the planner used statistics to figure out that the data is physically ordered and it is not needed to build a bitmap and, mainly, that the index condition does not need to be rechecked:

    它似乎比我們的BRIN大數(shù)千倍 ! 但是,查詢的執(zhí)行速度要快一些:計(jì)劃者使用統(tǒng)計(jì)信息來確定數(shù)據(jù)是物理排序的,不需要構(gòu)建位圖,并且主要是不需要重新檢查索引條件:

    demo=# explain (costs off,analyze)select *from flights_biwhere scheduled_time >= :d and scheduled_time < :d + interval '1 day';QUERY PLAN ----------------------------------------------------------------Index Scan using flights_bi_scheduled_time_btree on flights_bi(actual time=0.099..79.416 rows=83954 loops=1)Index Cond: ...Planning time: 0.500 msExecution time: 85.044 ms

    That's what is so wonderful about BRIN: we sacrifice the efficiency, but gain very much space.

    對于BRIN而言,這真是太妙了:我們犧牲了效率,卻獲得了很大的空間。

    操作員類別 (Operator classes)

    最小最大 (minmax)

    For data types whose values can be compared with one another, summary information consists of the minimal and maximal values. Names of the corresponding operator classes contain ?minmax?, for example, ?date_minmax_ops?. Actually, these are data types that we were considering so far, and most of the types are of this kind.

    對于其值可以相互比較的數(shù)據(jù)類型,摘要信息由最小值和最大值組成。 相應(yīng)的運(yùn)算符類別的名稱包含?minmax?,例如?date_minmax_ops?。 實(shí)際上,這些是我們到目前為止正在考慮的數(shù)據(jù)類型,并且大多數(shù)類型都是這種類型。

    包括的 (inclusive)

    Comparison operators are defined not for all data types. For example, they are not defined for points (?point? type), which represent the geographical coordinates of airports. By the way, it's for this reason that the statistics do not show the correlation for this column.

    并非為所有數(shù)據(jù)類型定義比較運(yùn)算符。 例如,沒有為代表機(jī)場地理坐標(biāo)的點(diǎn)(“點(diǎn)”類型)定義它們。 順便說一下,正是由于這個(gè)原因,統(tǒng)計(jì)信息并未顯示此列的相關(guān)性。

    demo=# select attname, correlation from pg_stats where tablename='flights_bi' and attname = 'airport_coord';attname | correlation ---------------+-------------airport_coord | (1 row)

    But many of such types enable us to introduce a concept of a ?bounding area?, for example, a bounding rectangle for geometric shapes. We discussed in detail how GiST index uses this feature. Similarly, BRIN also enables gathering summary information on columns having data types like these: the bounding area for all values inside a range is just the summary value.

    但是許多這樣的類型使我們能夠引入“邊界區(qū)域”的概念,例如,幾何形狀的邊界矩形。 我們詳細(xì)討論了GiST索引如何使用此功能。 同樣,BRIN還可以收集具有以下數(shù)據(jù)類型的列的摘要信息: 范圍內(nèi)所有值的邊界區(qū)域僅是摘要值。

    Unlike for GiST, the summary value for BRIN must be of the same type as the values being indexed. Therefore, we cannot build the index for points, although it is clear that the coordinates could work in BRIN: the longitude is closely connected with the time zone. Fortunately, nothing hinders creation of the index on an expression after transforming points into degenerate rectangles. At the same time, we will set the size of a range to one page, just to show the limit case:

    與GiST不同,BRIN的摘要值必須與所索引的值具有相同的類型。 因此,盡管很明顯坐標(biāo)可以在BRIN中工作,但我們無法建立點(diǎn)的索引:經(jīng)度與時(shí)區(qū)緊密相關(guān)。 幸運(yùn)的是,在將點(diǎn)轉(zhuǎn)換為退化的矩形后,沒有任何事情會妨礙在表達(dá)式上創(chuàng)建索引。 同時(shí),我們將范圍的大小設(shè)置為一頁,以顯示極限情況:

    demo=# create index on flights_bi using brin (box(airport_coord)) with (pages_per_range=1);

    The size of the index is as small as 30?MB even in such an extreme situation:

    即使在這種極端情況下,索引的大小也只有30 MB:

    demo=# select pg_size_pretty(pg_total_relation_size('flights_bi_box_idx'));pg_size_pretty ----------------30 MB (1 row)

    Now we can make up queries that limit the airports by coordinates. For example:

    現(xiàn)在,我們可以組成通過坐標(biāo)限制機(jī)場的查詢。 例如:

    demo=# select airport_code, airport_name from airports where box(coordinates) <@ box '120,40,140,50';airport_code | airport_name --------------+-----------------KHV | Khabarovsk-NovyiVVO | Vladivostok (2 rows)

    The planner will, however, refuse to use our index.

    但是,計(jì)劃者將拒絕使用我們的索引。

    demo=# analyze flights_bi;demo=# explain select * from flights_bi where box(airport_coord) <@ box '120,40,140,50';QUERY PLAN ---------------------------------------------------------------------Seq Scan on flights_bi (cost=0.00..985928.14 rows=30517 width=111)Filter: (box(airport_coord) <@ '(140,50),(120,40)'::box)

    Why? Let's disable sequential scan and see what happens:

    為什么? 讓我們禁用順序掃描,看看會發(fā)生什么:

    demo=# set enable_seqscan = off;demo=# explain select * from flights_bi where box(airport_coord) <@ box '120,40,140,50';QUERY PLAN --------------------------------------------------------------------------------Bitmap Heap Scan on flights_bi (cost=14079.67..1000007.81 rows=30517 width=111)Recheck Cond: (box(airport_coord) <@ '(140,50),(120,40)'::box)-> Bitmap Index Scan on flights_bi_box_idx(cost=0.00..14072.04 rows=30517076 width=0)Index Cond: (box(airport_coord) <@ '(140,50),(120,40)'::box)

    It appears that the index can be used, but the planner supposes that the bitmap will have to be built on the whole table (look at ?rows? of Bitmap Index Scan node), and it is no wonder that the planner chooses sequential scan in this case. The issue here is that for geometric types, PostgreSQL does not gather any statistics, and the planner has to go blindly:

    看來可以使用索引,但是計(jì)劃者認(rèn)為位圖必須建立在整個(gè)表上(請看“位圖索引掃描”節(jié)點(diǎn)的“行”),也就不足為奇了。這個(gè)案例。 這里的問題是,對于幾何類型,PostgreSQL不會收集任何統(tǒng)計(jì)信息,并且計(jì)劃者必須盲目行動(dòng):

    demo=# select * from pg_stats where tablename = 'flights_bi_box_idx' \gx-[ RECORD 1 ]----------+------------------- schemaname | bookings tablename | flights_bi_box_idx attname | box inherited | f null_frac | 0 avg_width | 32 n_distinct | 0 most_common_vals | most_common_freqs | histogram_bounds | correlation | most_common_elems | most_common_elem_freqs | elem_count_histogram |

    Alas. But there are no complaints about the index — it does work and works fine:

    唉。 但是沒有人對該索引有任何抱怨,它確實(shí)可以正常工作:

    demo=# explain (costs off,analyze) select * from flights_bi where box(airport_coord) <@ box '120,40,140,50';QUERY PLAN ----------------------------------------------------------------------------------Bitmap Heap Scan on flights_bi (actual time=158.142..315.445 rows=781790 loops=1)Recheck Cond: (box(airport_coord) <@ '(140,50),(120,40)'::box)Rows Removed by Index Recheck: 70726Heap Blocks: lossy=14772-> Bitmap Index Scan on flights_bi_box_idx(actual time=158.083..158.083 rows=147720 loops=1)Index Cond: (box(airport_coord) <@ '(140,50),(120,40)'::box)Planning time: 0.137 msExecution time: 340.593 ms

    The conclusion must be like this: PostGIS is needed if anything nontrivial is required of the geometry. It can gather statistics anyway.

    結(jié)論必須是這樣的:如果幾何圖形有任何重要要求,則需要PostGIS。 它仍然可以收集統(tǒng)計(jì)信息。

    內(nèi)部構(gòu)造 (Internals)

    The conventional extension ?pageinspect? enables us to look inside BRIN index.

    傳統(tǒng)的擴(kuò)展名“ pageinspect”使我們能夠查看BRIN索引的內(nèi)部。

    First, the metainformation will prompt us the size of a range and how many pages are allocated for ?revmap?:

    首先,元信息將提示我們范圍的大小以及?revmap?分配了多少頁:

    demo=# select * from brin_metapage_info(get_raw_page('flights_bi_scheduled_time_idx',0));magic | version | pagesperrange | lastrevmappage ------------+---------+---------------+----------------0xA8109CFA | 1 | 128 | 3 (1 row)

    Pages 1–3 here are allocated for ?revmap?, while the rest contain summary data. From ?revmap? we can get references to summary data for each range. Say, the information on the first range, incorporating first 128 pages, is located here:

    此處的第1至3頁分配給?revmap?,其余的則包含摘要數(shù)據(jù)。 從《 revmap》中,我們可以獲得每個(gè)范圍的摘要數(shù)據(jù)的引用。 說,第一個(gè)范圍的信息(包含前128頁)位于以下位置:

    demo=# select * from brin_revmap_data(get_raw_page('flights_bi_scheduled_time_idx',1)) limit 1;pages ---------(6,197) (1 row)

    And this is the summary data itself:

    這是摘要數(shù)據(jù)本身:

    demo=# select allnulls, hasnulls, value from brin_page_items(get_raw_page('flights_bi_scheduled_time_idx',6),'flights_bi_scheduled_time_idx' ) where itemoffset = 197;allnulls | hasnulls | value ----------+----------+----------------------------------------------------f | f | {2016-08-15 02:45:00+03 .. 2016-08-15 17:15:00+03} (1 row)

    Next range:

    下一個(gè)范圍:

    demo=# select * from brin_revmap_data(get_raw_page('flights_bi_scheduled_time_idx',1)) offset 1 limit 1;pages ---------(6,198) (1 row)demo=# select allnulls, hasnulls, value from brin_page_items(get_raw_page('flights_bi_scheduled_time_idx',6),'flights_bi_scheduled_time_idx' ) where itemoffset = 198;allnulls | hasnulls | value ----------+----------+----------------------------------------------------f | f | {2016-08-15 06:00:00+03 .. 2016-08-15 18:55:00+03} (1 row)

    And so on.

    等等。

    For ?inclusion? classes, the ?value? field will display something like

    對于“包含”類,“值”字段將顯示類似

    {(94.4005966186523,69.3110961914062),(77.6600036621,51.6693992614746) .. f .. f}

    The first value is the embedding rectangle, and ?f? letters at the end denote lacking empty elements (the first one) and lacking unmergeable values (the second one). Actually, the only unmergeable values are ?IPv4? and ?IPv6? addresses (?inet? data type).

    第一個(gè)值是嵌入矩形,末尾的“ f”字母表示缺少空元素(第一個(gè))和缺少不可合并的值(第二個(gè))。 實(shí)際上,唯一不可合并的值是“ IPv4”和“ IPv6”地址(“ inet”數(shù)據(jù)類型)。

    物產(chǎn) (Properties)

    Reminding you of the queries that have already been provided.

    提醒您已經(jīng)提供的查詢。

    The following are the properties of the access method:

    以下是訪問方法的屬性:

    amname | name | pg_indexam_has_property --------+---------------+-------------------------brin | can_order | fbrin | can_unique | fbrin | can_multi_col | tbrin | can_exclude | f

    Indexes can be created on several columns. In this case, its own summary statistics are gathered for each column, but they are stored together for each range. Of course, this index makes sense if one and the same size of a range is suitable for all columns.

    可以在幾列上創(chuàng)建索引。 在這種情況下,將為每列收集其自己的摘要統(tǒng)計(jì)信息,但對于每個(gè)范圍將它們一起存儲。 當(dāng)然,如果一個(gè)且相同大小的范圍適用于所有列,則此索引才有意義。

    The following index-layer properties are available:

    以下索引層屬性可用:

    name | pg_index_has_property ---------------+-----------------------clusterable | findex_scan | fbitmap_scan | tbackward_scan | f

    Evidently, only bitmap scan is supported.

    顯然,僅支持位圖掃描。

    However, lack of clustering may seem confusing. Seemingly, since BRIN index is sensitive to physical order of rows, it would be logical to be able to cluster data according to the index. But this is not so. We can only create a ?regular? index (B-tree or GiST, depending on the data type) and cluster according to it. By the way, do you want to cluster a supposedly huge table taking into account Exclusive locks, execution time, and consumption of disk space during rebuilding?

    但是,缺乏群集似乎令人困惑。 看來,由于BRIN索引對行的物理順序很敏感,因此能夠根據(jù)索引對數(shù)據(jù)進(jìn)行聚類是合乎邏輯的。 但是事實(shí)并非如此。 我們只能創(chuàng)建一個(gè)“常規(guī)”索引(B樹或GiST,取決于數(shù)據(jù)類型)并根據(jù)它進(jìn)行聚類。 順便說一句,您是否要考慮到排他鎖,執(zhí)行時(shí)間以及重建過程中磁盤空間的消耗,來對一個(gè)據(jù)稱龐大的表進(jìn)行聚類?

    The following are the column-layer properties:

    以下是列層屬性:

    name | pg_index_column_has_property --------------------+------------------------------asc | fdesc | fnulls_first | fnulls_last | forderable | fdistance_orderable | freturnable | fsearch_array | fsearch_nulls | t

    The only available property is the ability to manipulate NULLs.

    唯一可用的屬性是操作NULL的能力。

    Read on.繼續(xù)閱讀 。

    翻譯自: https://habr.com/en/company/postgrespro/blog/452900/

    postgresql索引

    總結(jié)

    以上是生活随笔為你收集整理的postgresql索引_PostgreSQL中的索引— 9(BRIN)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    亚洲精品国产精品乱码不卡 | 亚洲一区二区观看播放 | 成在人线av无码免观看麻豆 | 小泽玛莉亚一区二区视频在线 | 成人aaa片一区国产精品 | 婷婷五月综合缴情在线视频 | 国产热a欧美热a在线视频 | 亚洲国产精品毛片av不卡在线 | av无码电影一区二区三区 | 久久综合狠狠综合久久综合88 | 亚洲日韩av一区二区三区中文 | 人人妻人人澡人人爽欧美一区 | 4hu四虎永久在线观看 | 久久久中文字幕日本无吗 | 成人综合网亚洲伊人 | 国产av无码专区亚洲a∨毛片 | 强开小婷嫩苞又嫩又紧视频 | 东京热无码av男人的天堂 | 日韩成人一区二区三区在线观看 | 亚洲成在人网站无码天堂 | 天堂无码人妻精品一区二区三区 | 亚洲伊人久久精品影院 | 亚洲精品欧美二区三区中文字幕 | 精品无码国产一区二区三区av | 波多野结衣av一区二区全免费观看 | 久久97精品久久久久久久不卡 | 婷婷丁香六月激情综合啪 | 欧美黑人巨大xxxxx | 国产色在线 | 国产 | 日韩欧美中文字幕在线三区 | 天堂а√在线中文在线 | 久久精品国产亚洲精品 | 亚洲另类伦春色综合小说 | 欧美第一黄网免费网站 | 亚洲精品中文字幕久久久久 | 国产成人无码专区 | 国产av无码专区亚洲a∨毛片 | 粗大的内捧猛烈进出视频 | 日韩欧美成人免费观看 | 啦啦啦www在线观看免费视频 | 一本久久伊人热热精品中文字幕 | 国产成人无码区免费内射一片色欲 | 偷窥日本少妇撒尿chinese | 中文无码成人免费视频在线观看 | 无码毛片视频一区二区本码 | 大肉大捧一进一出好爽视频 | 玩弄少妇高潮ⅹxxxyw | 欧美日韩视频无码一区二区三 | 中文字幕人妻无码一夲道 | 九九在线中文字幕无码 | 日日摸夜夜摸狠狠摸婷婷 | 国产av一区二区精品久久凹凸 | 131美女爱做视频 | 国产人妻大战黑人第1集 | 国产精品久久福利网站 | 人人妻人人澡人人爽欧美一区 | 成人影院yy111111在线观看 | 久久久久久久女国产乱让韩 | 中文字幕 人妻熟女 | 内射老妇bbwx0c0ck | 国产一区二区三区影院 | 在线播放无码字幕亚洲 | 国产日产欧产精品精品app | www国产亚洲精品久久久日本 | 亚洲国产av美女网站 | 亚洲人成无码网www | 国产美女精品一区二区三区 | 无码午夜成人1000部免费视频 | 妺妺窝人体色www在线小说 | 日韩精品无码一本二本三本色 | 日韩少妇白浆无码系列 | 未满小14洗澡无码视频网站 | 亚洲成在人网站无码天堂 | 黑人巨大精品欧美黑寡妇 | 亚洲精品一区二区三区四区五区 | 精品无码国产自产拍在线观看蜜 | 国产精品无码mv在线观看 | 18精品久久久无码午夜福利 | 亚洲欧美日韩国产精品一区二区 | 欧美日本日韩 | 国产精品.xx视频.xxtv | 学生妹亚洲一区二区 | 曰韩无码二三区中文字幕 | 亚洲 激情 小说 另类 欧美 | 色婷婷综合激情综在线播放 | 精品无码成人片一区二区98 | 人人澡人人透人人爽 | 天堂一区人妻无码 | 日本xxxx色视频在线观看免费 | 蜜臀av在线播放 久久综合激激的五月天 | 欧美日韩综合一区二区三区 | 国产三级精品三级男人的天堂 | 国产精品久久久久9999小说 | 久久天天躁狠狠躁夜夜免费观看 | 成人免费视频视频在线观看 免费 | 亚洲爆乳无码专区 | 麻花豆传媒剧国产免费mv在线 | 久久久久成人片免费观看蜜芽 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | a片免费视频在线观看 | 成人性做爰aaa片免费看不忠 | 久久人人爽人人爽人人片av高清 | 日产精品高潮呻吟av久久 | 亚洲小说春色综合另类 | 久久伊人色av天堂九九小黄鸭 | 国产精品va在线播放 | 亚洲欧美日韩国产精品一区二区 | av人摸人人人澡人人超碰下载 | 精品无码国产自产拍在线观看蜜 | 亚洲成av人在线观看网址 | 久久精品中文字幕大胸 | 人人澡人人透人人爽 | 一区二区三区乱码在线 | 欧洲 | 伊人久久大香线焦av综合影院 | 在教室伦流澡到高潮hnp视频 | 亚洲国产成人a精品不卡在线 | 国产福利视频一区二区 | 麻豆国产人妻欲求不满 | 国产精品人人爽人人做我的可爱 | 青青青爽视频在线观看 | 亚洲天堂2017无码 | 131美女爱做视频 | 日本丰满熟妇videos | 人妻少妇被猛烈进入中文字幕 | 日本一卡2卡3卡四卡精品网站 | 18禁止看的免费污网站 | 欧美日韩一区二区免费视频 | 亚洲阿v天堂在线 | 精品无码成人片一区二区98 | 黑人粗大猛烈进出高潮视频 | 免费网站看v片在线18禁无码 | 亚洲人成影院在线无码按摩店 | 国产精品-区区久久久狼 | 伊人久久大香线焦av综合影院 | 97人妻精品一区二区三区 | 欧美日本日韩 | 国产凸凹视频一区二区 | 国产真实伦对白全集 | 一本色道婷婷久久欧美 | 内射老妇bbwx0c0ck | 国产亚洲精品精品国产亚洲综合 | 少妇性l交大片 | 久久熟妇人妻午夜寂寞影院 | 啦啦啦www在线观看免费视频 | 亚洲国产精品一区二区美利坚 | 欧美亚洲日韩国产人成在线播放 | 日本一本二本三区免费 | 免费人成网站视频在线观看 | 久久精品女人天堂av免费观看 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲日本一区二区三区在线 | 强伦人妻一区二区三区视频18 | www国产亚洲精品久久网站 | 亚洲狠狠色丁香婷婷综合 | 国产精品第一国产精品 | 香蕉久久久久久av成人 | 欧美日韩一区二区综合 | 一二三四社区在线中文视频 | 伦伦影院午夜理论片 | 免费看少妇作爱视频 | 狠狠色噜噜狠狠狠狠7777米奇 | 欧美肥老太牲交大战 | 久久精品中文字幕大胸 | 成熟女人特级毛片www免费 | 免费男性肉肉影院 | 国精产品一品二品国精品69xx | 国产精品a成v人在线播放 | 激情内射亚州一区二区三区爱妻 | 国产精品久久福利网站 | 欧美freesex黑人又粗又大 | 中文亚洲成a人片在线观看 | 国内丰满熟女出轨videos | 欧美高清在线精品一区 | 亚洲精品国产精品乱码视色 | 久精品国产欧美亚洲色aⅴ大片 | 曰韩少妇内射免费播放 | 亚洲精品国产精品乱码不卡 | 国产午夜精品一区二区三区嫩草 | 国语自产偷拍精品视频偷 | 午夜肉伦伦影院 | 成人试看120秒体验区 | 精品 日韩 国产 欧美 视频 | 国产农村妇女高潮大叫 | 久久久久se色偷偷亚洲精品av | 无码国模国产在线观看 | 国产真实乱对白精彩久久 | 国内精品九九久久久精品 | 国产在线无码精品电影网 | 久久精品人人做人人综合 | 人妻少妇被猛烈进入中文字幕 | 欧美日韩色另类综合 | 狠狠色丁香久久婷婷综合五月 | 国产莉萝无码av在线播放 | 亚洲精品鲁一鲁一区二区三区 | 中文字幕无码免费久久9一区9 | 日日噜噜噜噜夜夜爽亚洲精品 | 天天躁夜夜躁狠狠是什么心态 | 亚洲欧美日韩成人高清在线一区 | 人妻少妇精品无码专区动漫 | а√资源新版在线天堂 | 国产精品爱久久久久久久 | 国产亚洲美女精品久久久2020 | 清纯唯美经典一区二区 | 精品久久久久久人妻无码中文字幕 | 国产在线一区二区三区四区五区 | 无套内谢的新婚少妇国语播放 | yw尤物av无码国产在线观看 | 亚洲精品综合一区二区三区在线 | 九九久久精品国产免费看小说 | 午夜精品一区二区三区在线观看 | 在线а√天堂中文官网 | 欧美国产日韩亚洲中文 | 中文字幕人妻无码一区二区三区 | 少妇高潮一区二区三区99 | 免费国产成人高清在线观看网站 | www国产亚洲精品久久网站 | 亚洲色偷偷偷综合网 | 熟妇女人妻丰满少妇中文字幕 | 亚洲精品成人福利网站 | 欧美人与物videos另类 | 波多野结衣一区二区三区av免费 | 亚洲欧美色中文字幕在线 | 亚洲精品鲁一鲁一区二区三区 | 2019nv天堂香蕉在线观看 | 久久久久久久人妻无码中文字幕爆 | 日日碰狠狠丁香久燥 | 久久久久久久人妻无码中文字幕爆 | a国产一区二区免费入口 | 欧美 丝袜 自拍 制服 另类 | 午夜免费福利小电影 | 久在线观看福利视频 | 亚洲一区二区三区在线观看网站 | 黑人巨大精品欧美一区二区 | 精品久久久久久人妻无码中文字幕 | 欧美丰满熟妇xxxx性ppx人交 | 国产黑色丝袜在线播放 | 亚洲国产成人a精品不卡在线 | 亚洲毛片av日韩av无码 | 又大又紧又粉嫩18p少妇 | 东京热男人av天堂 | 欧美精品一区二区精品久久 | 无码人妻出轨黑人中文字幕 | 午夜成人1000部免费视频 | 国产成人精品优优av | av无码电影一区二区三区 | 国产亲子乱弄免费视频 | 亚洲成在人网站无码天堂 | 日本乱人伦片中文三区 | 日本丰满熟妇videos | 国产香蕉尹人视频在线 | 午夜丰满少妇性开放视频 | 天堂亚洲2017在线观看 | 国产精品久久久av久久久 | 未满小14洗澡无码视频网站 | 性生交大片免费看l | av香港经典三级级 在线 | 未满小14洗澡无码视频网站 | 最新版天堂资源中文官网 | 天天综合网天天综合色 | 少妇久久久久久人妻无码 | 内射老妇bbwx0c0ck | 未满成年国产在线观看 | 久久人人爽人人人人片 | 波多野结衣一区二区三区av免费 | 国产免费无码一区二区视频 | 小鲜肉自慰网站xnxx | 久久婷婷五月综合色国产香蕉 | 色婷婷久久一区二区三区麻豆 | 奇米影视7777久久精品 | 久久无码专区国产精品s | 又大又紧又粉嫩18p少妇 | 国产成人精品久久亚洲高清不卡 | 国产激情一区二区三区 | 国内精品九九久久久精品 | 男人的天堂av网站 | 亚洲人成网站色7799 | 欧洲熟妇精品视频 | 亚洲综合另类小说色区 | 少妇久久久久久人妻无码 | 成 人 网 站国产免费观看 | 精品国产一区二区三区四区在线看 | 国产深夜福利视频在线 | 欧美亚洲国产一区二区三区 | 99riav国产精品视频 | 300部国产真实乱 | 国产99久久精品一区二区 | 亚洲精品国产精品乱码视色 | 亚洲欧美综合区丁香五月小说 | 午夜成人1000部免费视频 | 国产精品久久久午夜夜伦鲁鲁 | 久精品国产欧美亚洲色aⅴ大片 | 大地资源中文第3页 | 久久天天躁夜夜躁狠狠 | 无码人妻丰满熟妇区毛片18 | 国产精品亚洲一区二区三区喷水 | 国内精品人妻无码久久久影院 | 国产精品永久免费视频 | 丰满人妻被黑人猛烈进入 | 亚洲a无码综合a国产av中文 | 亚洲综合无码久久精品综合 | 免费无码午夜福利片69 | 十八禁真人啪啪免费网站 | 欧洲精品码一区二区三区免费看 | 宝宝好涨水快流出来免费视频 | 亚洲精品午夜无码电影网 | 久久精品人妻少妇一区二区三区 | 欧美自拍另类欧美综合图片区 | 欧美日本免费一区二区三区 | 亚洲精品国产精品乱码不卡 | 装睡被陌生人摸出水好爽 | 国产午夜无码精品免费看 | 日本爽爽爽爽爽爽在线观看免 | 国产疯狂伦交大片 | 粉嫩少妇内射浓精videos | 999久久久国产精品消防器材 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 麻豆精品国产精华精华液好用吗 | 国产精品无码久久av | 一区二区三区高清视频一 | 欧美真人作爱免费视频 | 乱人伦人妻中文字幕无码久久网 | 最新国产麻豆aⅴ精品无码 | 日本一卡2卡3卡四卡精品网站 | 欧美自拍另类欧美综合图片区 | 人妻体内射精一区二区三四 | 18精品久久久无码午夜福利 | 波多野结衣乳巨码无在线观看 | 国产成人精品久久亚洲高清不卡 | 国产精品人人妻人人爽 | 人妻插b视频一区二区三区 | 东京热无码av男人的天堂 | 男人和女人高潮免费网站 | 亚洲 欧美 激情 小说 另类 | 精品国产aⅴ无码一区二区 | 性欧美videos高清精品 | 四虎国产精品免费久久 | 特黄特色大片免费播放器图片 | 亚洲午夜福利在线观看 | 亚洲国产高清在线观看视频 | 国产精品嫩草久久久久 | 亚洲成色在线综合网站 | 午夜成人1000部免费视频 | 精品久久久无码中文字幕 | 鲁大师影院在线观看 | 亚洲精品www久久久 | 亚洲成av人片在线观看无码不卡 | 永久免费观看美女裸体的网站 | 麻豆国产丝袜白领秘书在线观看 | 初尝人妻少妇中文字幕 | 九九热爱视频精品 | 无码成人精品区在线观看 | 国产av一区二区精品久久凹凸 | 麻豆国产97在线 | 欧洲 | 中文字幕无码日韩专区 | 99久久精品午夜一区二区 | 无码人妻精品一区二区三区不卡 | 久久亚洲国产成人精品性色 | 久久99热只有频精品8 | 国产情侣作爱视频免费观看 | 国产香蕉97碰碰久久人人 | 无码一区二区三区在线 | 六月丁香婷婷色狠狠久久 | 综合激情五月综合激情五月激情1 | 久久久久亚洲精品中文字幕 | 强开小婷嫩苞又嫩又紧视频 | 日本高清一区免费中文视频 | 在线看片无码永久免费视频 | 国产成人无码a区在线观看视频app | 久久久久亚洲精品中文字幕 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | av在线亚洲欧洲日产一区二区 | av在线亚洲欧洲日产一区二区 | 亚洲精品国产a久久久久久 | 欧美日韩人成综合在线播放 | 国产成人综合在线女婷五月99播放 | 国产精品久久久久9999小说 | 亚洲 另类 在线 欧美 制服 | 国内精品九九久久久精品 | 极品嫩模高潮叫床 | 国产精品久久久av久久久 | 大肉大捧一进一出视频出来呀 | 欧美日本免费一区二区三区 | 国产亚洲欧美在线专区 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲日韩精品欧美一区二区 | 国产午夜福利亚洲第一 | 中文字幕人妻无码一夲道 | 久久久久免费精品国产 | 樱花草在线社区www | 欧美精品在线观看 | 人妻插b视频一区二区三区 | 性欧美牲交xxxxx视频 | 亚洲 日韩 欧美 成人 在线观看 | 无码国模国产在线观看 | 无码人妻出轨黑人中文字幕 | 国产午夜手机精彩视频 | 久久99精品国产麻豆蜜芽 | 3d动漫精品啪啪一区二区中 | 伊人久久大香线蕉亚洲 | 欧美黑人乱大交 | 色婷婷av一区二区三区之红樱桃 | 日韩av无码一区二区三区不卡 | 国产精品视频免费播放 | 久9re热视频这里只有精品 | 鲁大师影院在线观看 | 午夜熟女插插xx免费视频 | 国产麻豆精品一区二区三区v视界 | 十八禁视频网站在线观看 | 亚洲色大成网站www | 四十如虎的丰满熟妇啪啪 | 少妇人妻偷人精品无码视频 | 欧美阿v高清资源不卡在线播放 | 欧美大屁股xxxxhd黑色 | 动漫av一区二区在线观看 | 中文字幕+乱码+中文字幕一区 | 日本爽爽爽爽爽爽在线观看免 | а√天堂www在线天堂小说 | 无码人妻出轨黑人中文字幕 | 牲欲强的熟妇农村老妇女视频 | 亚洲人亚洲人成电影网站色 | 99久久精品午夜一区二区 | 亚洲精品国产精品乱码不卡 | 妺妺窝人体色www在线小说 | av无码不卡在线观看免费 | 亚洲综合久久一区二区 | 少女韩国电视剧在线观看完整 | 日本成熟视频免费视频 | av香港经典三级级 在线 | 中文字幕乱码中文乱码51精品 | 日欧一片内射va在线影院 | aⅴ在线视频男人的天堂 | 白嫩日本少妇做爰 | 3d动漫精品啪啪一区二区中 | 精品成在人线av无码免费看 | 亚洲欧美中文字幕5发布 | 精品偷拍一区二区三区在线看 | 中国女人内谢69xxxx | 精品国产aⅴ无码一区二区 | 最近的中文字幕在线看视频 | 亚洲精品一区三区三区在线观看 | 国产在线精品一区二区高清不卡 | 欧美xxxxx精品 | 久久综合给久久狠狠97色 | yw尤物av无码国产在线观看 | 成人免费视频一区二区 | 麻豆国产97在线 | 欧洲 | 久久人人爽人人爽人人片av高清 | 97无码免费人妻超级碰碰夜夜 | 精品偷自拍另类在线观看 | 久久久久99精品成人片 | 性欧美牲交在线视频 | 任你躁国产自任一区二区三区 | 国产人妻大战黑人第1集 | 亚洲区欧美区综合区自拍区 | 无码中文字幕色专区 | 久久99精品国产.久久久久 | 欧美性黑人极品hd | 亚洲日本一区二区三区在线 | 亚洲色欲色欲天天天www | 国产亚洲美女精品久久久2020 | 欧美成人家庭影院 | 熟女体下毛毛黑森林 | 国产美女极度色诱视频www | 国产午夜精品一区二区三区嫩草 | 少妇厨房愉情理9仑片视频 | 小sao货水好多真紧h无码视频 | 伊人久久大香线蕉午夜 | 日韩精品a片一区二区三区妖精 | 国产肉丝袜在线观看 | 中文字幕无码视频专区 | 亚洲中文字幕va福利 | 亚洲日本va午夜在线电影 | 一本久久伊人热热精品中文字幕 | 国产乱人伦偷精品视频 | 无人区乱码一区二区三区 | 久久久精品国产sm最大网站 | 色综合久久久久综合一本到桃花网 | 色综合久久久无码网中文 | 性色av无码免费一区二区三区 | 55夜色66夜色国产精品视频 | 精品欧美一区二区三区久久久 | 亚洲 激情 小说 另类 欧美 | 亚洲精品综合一区二区三区在线 | 无码帝国www无码专区色综合 | 啦啦啦www在线观看免费视频 | 久久国产精品二国产精品 | 欧美性生交活xxxxxdddd | 牲欲强的熟妇农村老妇女 | 日韩人妻无码中文字幕视频 | 在线观看欧美一区二区三区 | 国产精品久久久久影院嫩草 | 亚洲а∨天堂久久精品2021 | 国产偷抇久久精品a片69 | 婷婷色婷婷开心五月四房播播 | 奇米影视7777久久精品 | 成人综合网亚洲伊人 | 亚洲精品国产第一综合99久久 | 欧美激情内射喷水高潮 | 一本久道久久综合婷婷五月 | 成人无码精品一区二区三区 | 99精品无人区乱码1区2区3区 | 亚洲成av人在线观看网址 | 内射巨臀欧美在线视频 | 高中生自慰www网站 | 亚洲成av人片天堂网无码】 | 精品久久久久久人妻无码中文字幕 | 亚洲精品中文字幕 | 曰本女人与公拘交酡免费视频 | 亚洲七七久久桃花影院 | 国产成人精品一区二区在线小狼 | 中文字幕精品av一区二区五区 | 国产午夜福利100集发布 | 国产精品人人爽人人做我的可爱 | 国产深夜福利视频在线 | 亚洲精品国产精品乱码不卡 | 日本一区二区更新不卡 | 国产情侣作爱视频免费观看 | 领导边摸边吃奶边做爽在线观看 | 亚洲成a人一区二区三区 | 国产精品内射视频免费 | 亚洲国产欧美日韩精品一区二区三区 | 无码国模国产在线观看 | 亚洲色大成网站www国产 | 精品久久久无码中文字幕 | 亚洲一区二区观看播放 | 国产精品免费大片 | 精品少妇爆乳无码av无码专区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲男人av天堂午夜在 | 中文字幕乱码亚洲无线三区 | 国产亚洲欧美日韩亚洲中文色 | 午夜理论片yy44880影院 | 久久综合给久久狠狠97色 | 精品久久久无码人妻字幂 | 久久久久久国产精品无码下载 | 无码帝国www无码专区色综合 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲熟悉妇女xxx妇女av | 极品嫩模高潮叫床 | 51国偷自产一区二区三区 | 国产精品久免费的黄网站 | 精品偷自拍另类在线观看 | 久久久精品456亚洲影院 | 性生交大片免费看l | 对白脏话肉麻粗话av | 2019午夜福利不卡片在线 | 欧美人与动性行为视频 | 国产亚洲欧美在线专区 | 3d动漫精品啪啪一区二区中 | 久久精品人人做人人综合 | 亚洲欧美日韩综合久久久 | 国产午夜亚洲精品不卡 | 麻豆果冻传媒2021精品传媒一区下载 | 日日噜噜噜噜夜夜爽亚洲精品 | 蜜桃av抽搐高潮一区二区 | 中文字幕无码免费久久99 | 国产精品欧美成人 | 亚洲综合无码一区二区三区 | 国产人妻精品午夜福利免费 | a片在线免费观看 | 国产在线精品一区二区高清不卡 | 亚洲精品综合一区二区三区在线 | 亚洲欧美中文字幕5发布 | 久久国产精品偷任你爽任你 | 少妇无码av无码专区在线观看 | 久久99热只有频精品8 | 内射后入在线观看一区 | 精品国精品国产自在久国产87 | 亚洲综合色区中文字幕 | 国产xxx69麻豆国语对白 | 久久人人97超碰a片精品 | 无码毛片视频一区二区本码 | 理论片87福利理论电影 | 午夜无码人妻av大片色欲 | 国产成人精品优优av | 精品亚洲韩国一区二区三区 | 久久精品中文字幕一区 | 男人扒开女人内裤强吻桶进去 | 中文字幕乱码人妻无码久久 | 日韩人妻无码一区二区三区久久99 | 国产人妻大战黑人第1集 | 日韩亚洲欧美中文高清在线 | 国产精品资源一区二区 | 欧美阿v高清资源不卡在线播放 | 欧美成人家庭影院 | 国产成人无码一二三区视频 | 中文字幕人妻丝袜二区 | 亚洲国产精品一区二区美利坚 | 中文字幕精品av一区二区五区 | 国产精品第一区揄拍无码 | 人妻少妇被猛烈进入中文字幕 | 日本精品少妇一区二区三区 | 国产成人一区二区三区别 | 最近的中文字幕在线看视频 | 粉嫩少妇内射浓精videos | 久久久久久九九精品久 | 亚洲成色在线综合网站 | 18禁黄网站男男禁片免费观看 | 中文字幕av伊人av无码av | 国产精品18久久久久久麻辣 | 国产精品福利视频导航 | 中文无码伦av中文字幕 | 国产国产精品人在线视 | 欧美三级a做爰在线观看 | 人妻天天爽夜夜爽一区二区 | 精品aⅴ一区二区三区 | 99久久精品午夜一区二区 | 亚洲综合无码久久精品综合 | 国产9 9在线 | 中文 | 天天燥日日燥 | 男女猛烈xx00免费视频试看 | 人妻夜夜爽天天爽三区 | 鲁鲁鲁爽爽爽在线视频观看 | 大地资源网第二页免费观看 | 九九久久精品国产免费看小说 | 亚洲七七久久桃花影院 | 亚洲 另类 在线 欧美 制服 | 国产后入清纯学生妹 | 初尝人妻少妇中文字幕 | 欧美野外疯狂做受xxxx高潮 | 福利一区二区三区视频在线观看 | 精品偷拍一区二区三区在线看 | 国产成人无码a区在线观看视频app | 国产区女主播在线观看 | 亚洲国产综合无码一区 | 久久www免费人成人片 | 好男人www社区 | 天海翼激烈高潮到腰振不止 | 欧美性色19p | 国产精品无码成人午夜电影 | 人人妻人人澡人人爽欧美一区九九 | 久久久亚洲欧洲日产国码αv | 窝窝午夜理论片影院 | 亚无码乱人伦一区二区 | 麻豆果冻传媒2021精品传媒一区下载 | 玩弄中年熟妇正在播放 | 伊人久久大香线焦av综合影院 | 亚无码乱人伦一区二区 | 波多野42部无码喷潮在线 | 波多野结衣乳巨码无在线观看 | 人人妻人人澡人人爽人人精品浪潮 | 国产精品免费大片 | 曰韩无码二三区中文字幕 | 丝袜美腿亚洲一区二区 | 九九热爱视频精品 | 奇米影视888欧美在线观看 | 偷窥村妇洗澡毛毛多 | 国产无套粉嫩白浆在线 | 久久97精品久久久久久久不卡 | 国产在线一区二区三区四区五区 | 国产精品久久久久久无码 | 人妻插b视频一区二区三区 | 国产色在线 | 国产 | 久久精品99久久香蕉国产色戒 | 久久精品一区二区三区四区 | 精品一区二区三区波多野结衣 | 大色综合色综合网站 | 青青青手机频在线观看 | 欧美日韩人成综合在线播放 | 一本色道婷婷久久欧美 | 亚洲日韩乱码中文无码蜜桃臀网站 | 俺去俺来也www色官网 | 国产精品久久久久影院嫩草 | 波多野结衣高清一区二区三区 | 久久精品女人天堂av免费观看 | 中文字幕人妻无码一区二区三区 | 亚洲午夜久久久影院 | 国产人妻久久精品二区三区老狼 | 色狠狠av一区二区三区 | 久久精品国产一区二区三区 | 奇米影视7777久久精品 | 午夜熟女插插xx免费视频 | 亚洲中文字幕久久无码 | 国产午夜视频在线观看 | 色综合久久中文娱乐网 | 无套内谢的新婚少妇国语播放 | 亚洲成av人影院在线观看 | 欧美国产日韩久久mv | 在线观看国产一区二区三区 | 国产办公室秘书无码精品99 | 东京热无码av男人的天堂 | 免费人成在线观看网站 | 国产av一区二区精品久久凹凸 | 精品国产麻豆免费人成网站 | 无码精品人妻一区二区三区av | 啦啦啦www在线观看免费视频 | 国产精品亚洲а∨无码播放麻豆 | 国产在热线精品视频 | 十八禁真人啪啪免费网站 | 午夜熟女插插xx免费视频 | 日日摸夜夜摸狠狠摸婷婷 | 国产色xx群视频射精 | 牲欲强的熟妇农村老妇女 | 国产农村乱对白刺激视频 | 色五月五月丁香亚洲综合网 | 久久精品丝袜高跟鞋 | 水蜜桃色314在线观看 | 日本肉体xxxx裸交 | 亚洲区小说区激情区图片区 | 久久国产36精品色熟妇 | 色综合久久网 | 国产另类ts人妖一区二区 | 婷婷五月综合缴情在线视频 | 亚洲欧洲日本无在线码 | 中文字幕人妻无码一区二区三区 | 亚洲熟妇色xxxxx亚洲 | 又大又硬又爽免费视频 | 一区二区传媒有限公司 | 国产精品国产自线拍免费软件 | 三上悠亚人妻中文字幕在线 | 精品 日韩 国产 欧美 视频 | 300部国产真实乱 | 成人欧美一区二区三区 | 嫩b人妻精品一区二区三区 | 亚洲中文字幕久久无码 | 狠狠躁日日躁夜夜躁2020 | 老熟女重囗味hdxx69 | 青草视频在线播放 | 久久午夜夜伦鲁鲁片无码免费 | 中国女人内谢69xxxx | 亚洲成a人一区二区三区 | 国产亚洲精品久久久久久久 | 东京一本一道一二三区 | 久久综合九色综合97网 | 国产免费久久精品国产传媒 | 久久精品国产99久久6动漫 | 色老头在线一区二区三区 | 人妻体内射精一区二区三四 | 亚洲人成网站免费播放 | 伊在人天堂亚洲香蕉精品区 | 噜噜噜亚洲色成人网站 | 性欧美牲交xxxxx视频 | 一本精品99久久精品77 | 欧美日韩一区二区免费视频 | 18禁黄网站男男禁片免费观看 | 亚洲精品国产a久久久久久 | 亚洲一区二区三区无码久久 | 久久国产精品偷任你爽任你 | 99久久久国产精品无码免费 | 高清无码午夜福利视频 | 成人欧美一区二区三区 | 欧洲vodafone精品性 | 色妞www精品免费视频 | 18禁黄网站男男禁片免费观看 | 国产黑色丝袜在线播放 | 久久精品中文闷骚内射 | 影音先锋中文字幕无码 | 在线欧美精品一区二区三区 | 亚洲中文字幕无码中文字在线 | 97夜夜澡人人双人人人喊 | 国产成人一区二区三区在线观看 | 狠狠躁日日躁夜夜躁2020 | 日本大乳高潮视频在线观看 | 97精品国产97久久久久久免费 | 国产精品久免费的黄网站 | 精品亚洲成av人在线观看 | 中文字幕+乱码+中文字幕一区 | 麻豆人妻少妇精品无码专区 | 嫩b人妻精品一区二区三区 | 男女作爱免费网站 | 荡女精品导航 | 狠狠cao日日穞夜夜穞av | 乱码av麻豆丝袜熟女系列 | 久久亚洲精品中文字幕无男同 | 成人性做爰aaa片免费看不忠 | 狂野欧美激情性xxxx | 一区二区三区高清视频一 | www国产亚洲精品久久久日本 | 午夜成人1000部免费视频 | 在线欧美精品一区二区三区 | 久久99久久99精品中文字幕 | 人妻中文无码久热丝袜 | 亚洲色大成网站www国产 | 激情人妻另类人妻伦 | 久久久久亚洲精品男人的天堂 | 成人片黄网站色大片免费观看 | 日韩精品一区二区av在线 | 午夜福利试看120秒体验区 | 四虎影视成人永久免费观看视频 | 伊人久久大香线蕉亚洲 | 奇米影视7777久久精品人人爽 | 97夜夜澡人人爽人人喊中国片 | 无码免费一区二区三区 | 亚洲大尺度无码无码专区 | 亚洲啪av永久无码精品放毛片 | 国产成人精品三级麻豆 | 中文字幕亚洲情99在线 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 99久久婷婷国产综合精品青草免费 | 国产手机在线αⅴ片无码观看 | 日本大乳高潮视频在线观看 | 麻豆国产丝袜白领秘书在线观看 | 色婷婷香蕉在线一区二区 | 国产午夜无码视频在线观看 | 2019午夜福利不卡片在线 | 亚洲精品一区二区三区在线观看 | 免费无码av一区二区 | 色五月丁香五月综合五月 | 欧美三级a做爰在线观看 | 俺去俺来也在线www色官网 | 又大又硬又爽免费视频 | www成人国产高清内射 | 男女性色大片免费网站 | 超碰97人人做人人爱少妇 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产精品内射视频免费 | 久久久久成人片免费观看蜜芽 | 精品日本一区二区三区在线观看 | 少妇人妻av毛片在线看 | 在线а√天堂中文官网 | 国产黑色丝袜在线播放 | 六月丁香婷婷色狠狠久久 | 国产又爽又猛又粗的视频a片 | 牛和人交xxxx欧美 | 老司机亚洲精品影院 | 丰满护士巨好爽好大乳 | 装睡被陌生人摸出水好爽 | 国产精品久久久av久久久 | 在线亚洲高清揄拍自拍一品区 | a片免费视频在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 麻豆蜜桃av蜜臀av色欲av | 欧美人与动性行为视频 | 午夜福利一区二区三区在线观看 | 99久久无码一区人妻 | 在线成人www免费观看视频 | 未满成年国产在线观看 | 亚洲精品成人av在线 | 永久免费精品精品永久-夜色 | 国产精品亚洲专区无码不卡 | 亚洲色大成网站www国产 | 色婷婷综合中文久久一本 | 亚洲色www成人永久网址 | 国产九九九九九九九a片 | 欧美黑人性暴力猛交喷水 | 牲欲强的熟妇农村老妇女视频 | 野狼第一精品社区 | 精品无码国产自产拍在线观看蜜 | 成人亚洲精品久久久久 | 高潮毛片无遮挡高清免费 | 婷婷丁香五月天综合东京热 | 亚洲中文字幕在线观看 | 无码人妻出轨黑人中文字幕 | 天堂一区人妻无码 | 人人爽人人澡人人高潮 | 久久久久亚洲精品中文字幕 | 综合网日日天干夜夜久久 | 中文字幕中文有码在线 | 无码人妻久久一区二区三区不卡 | 丝袜足控一区二区三区 | 日韩在线不卡免费视频一区 | 色偷偷人人澡人人爽人人模 | 色欲久久久天天天综合网精品 | 亚洲中文无码av永久不收费 | 精品国产一区二区三区四区 | 正在播放东北夫妻内射 | 欧美人与禽zoz0性伦交 | 中文字幕无线码 | 精品成人av一区二区三区 | 图片区 小说区 区 亚洲五月 | 日本爽爽爽爽爽爽在线观看免 | 98国产精品综合一区二区三区 | 啦啦啦www在线观看免费视频 | 人妻少妇被猛烈进入中文字幕 | 特大黑人娇小亚洲女 | 久久综合给久久狠狠97色 | 久久久久久国产精品无码下载 | 欧洲欧美人成视频在线 | 国产精品久久久久久久影院 | 国产精品久久久久9999小说 | 国内精品人妻无码久久久影院蜜桃 | 亚洲成av人综合在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 久久99久久99精品中文字幕 | 伊人久久大香线蕉午夜 | 在线a亚洲视频播放在线观看 | 狠狠色噜噜狠狠狠7777奇米 | 国产亚洲人成在线播放 | 大地资源网第二页免费观看 | 国产亚洲日韩欧美另类第八页 | 亚洲人交乣女bbw | 一个人免费观看的www视频 | 国产成人无码a区在线观看视频app | 亚洲狠狠色丁香婷婷综合 | 成人精品一区二区三区中文字幕 | 中文字幕 人妻熟女 | 国产成人午夜福利在线播放 | 无码人妻av免费一区二区三区 | 国产特级毛片aaaaaaa高清 | 内射后入在线观看一区 | 成人无码影片精品久久久 | 中文字幕无码乱人伦 | 国产精品va在线播放 | 国产精品igao视频网 | 亚洲精品综合一区二区三区在线 | 精品国产乱码久久久久乱码 | 国产真实乱对白精彩久久 | aⅴ亚洲 日韩 色 图网站 播放 | 免费乱码人妻系列无码专区 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲一区二区三区偷拍女厕 | 精品无码成人片一区二区98 | 久久午夜无码鲁丝片午夜精品 | 精品国产精品久久一区免费式 | 欧美性色19p | 奇米影视7777久久精品 | 老熟女乱子伦 | 国产黄在线观看免费观看不卡 | 中国女人内谢69xxxx | 久久99精品久久久久久动态图 | 亚洲日本va午夜在线电影 | 国产sm调教视频在线观看 | 午夜精品久久久内射近拍高清 | 人人妻人人澡人人爽欧美精品 | 久久精品人人做人人综合试看 | 国产亚洲欧美日韩亚洲中文色 | 无码人妻精品一区二区三区下载 | 国内精品久久久久久中文字幕 | 无码一区二区三区在线观看 | 四虎国产精品免费久久 | 国产熟妇另类久久久久 | 国产另类ts人妖一区二区 | 中文字幕无线码 | av无码不卡在线观看免费 | 国内揄拍国内精品人妻 | 中国女人内谢69xxxxxa片 | 一本一道久久综合久久 | 亚洲精品国偷拍自产在线观看蜜桃 | 亚洲日韩av一区二区三区中文 | 日韩成人一区二区三区在线观看 | 荫蒂被男人添的好舒服爽免费视频 | 国产精品-区区久久久狼 | 国产精品二区一区二区aⅴ污介绍 | 永久免费观看美女裸体的网站 | 国产成人久久精品流白浆 | 国产成人无码av一区二区 | 天海翼激烈高潮到腰振不止 | 国产精品久久久一区二区三区 | 日韩人妻少妇一区二区三区 | 欧美成人午夜精品久久久 | 亚洲の无码国产の无码影院 | 日本精品高清一区二区 | 日韩欧美成人免费观看 | 国产成人无码一二三区视频 | 97人妻精品一区二区三区 | 俺去俺来也在线www色官网 | 亚洲一区二区三区香蕉 | 色综合久久久无码中文字幕 | 亚洲成a人片在线观看无码3d | 久久综合九色综合欧美狠狠 | 无码国产乱人伦偷精品视频 | 国产精品久久久久无码av色戒 | 亚洲中文字幕va福利 | 国产成人人人97超碰超爽8 | 欧美一区二区三区视频在线观看 | 国产又粗又硬又大爽黄老大爷视 | 亚洲欧美综合区丁香五月小说 | 精品无码成人片一区二区98 | 国产精品va在线播放 | 婷婷丁香六月激情综合啪 | 撕开奶罩揉吮奶头视频 | 亚洲一区av无码专区在线观看 | 国产午夜无码精品免费看 | 国产成人精品久久亚洲高清不卡 | 中文字幕无码人妻少妇免费 | 国内精品人妻无码久久久影院蜜桃 | 国产疯狂伦交大片 | 熟女体下毛毛黑森林 | 亚洲欧美日韩国产精品一区二区 | 欧美高清在线精品一区 | 久久99精品国产.久久久久 | 在线а√天堂中文官网 | 国产sm调教视频在线观看 | 国产精品嫩草久久久久 | 丰满人妻被黑人猛烈进入 | 纯爱无遮挡h肉动漫在线播放 | 国产精品久久国产三级国 | 人妻有码中文字幕在线 | 亚洲毛片av日韩av无码 | av在线亚洲欧洲日产一区二区 | 久久97精品久久久久久久不卡 | 在线看片无码永久免费视频 | 久久久久人妻一区精品色欧美 | 成人精品视频一区二区三区尤物 | 亚洲人成网站色7799 | 久久国语露脸国产精品电影 | 国产区女主播在线观看 | 精品久久久无码中文字幕 | 中文字幕色婷婷在线视频 | 捆绑白丝粉色jk震动捧喷白浆 | 女人被男人爽到呻吟的视频 | 国内精品久久毛片一区二区 | 蜜桃臀无码内射一区二区三区 | 六十路熟妇乱子伦 | 男女猛烈xx00免费视频试看 | 日本熟妇人妻xxxxx人hd | 欧美怡红院免费全部视频 | 久久精品国产大片免费观看 | 高潮喷水的毛片 | 成人精品视频一区二区三区尤物 | 熟女少妇人妻中文字幕 | 麻豆av传媒蜜桃天美传媒 | 奇米影视888欧美在线观看 | 精品一区二区三区无码免费视频 | 三上悠亚人妻中文字幕在线 | 麻豆蜜桃av蜜臀av色欲av | 国产成人无码一二三区视频 | 好屌草这里只有精品 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 曰韩无码二三区中文字幕 | 亚洲国产精品无码一区二区三区 | 亚洲综合色区中文字幕 | 国产乱人偷精品人妻a片 | 亚洲精品一区二区三区大桥未久 | 精品无码成人片一区二区98 | 亚洲精品综合五月久久小说 | 蜜臀av无码人妻精品 | 国产精品亚洲lv粉色 | 国产香蕉尹人视频在线 | 美女毛片一区二区三区四区 | 久久亚洲中文字幕无码 | 亚洲综合精品香蕉久久网 | 日产精品99久久久久久 | 色综合视频一区二区三区 | 六十路熟妇乱子伦 | 麻豆md0077饥渴少妇 | 久久久久亚洲精品男人的天堂 | 中文久久乱码一区二区 | 狂野欧美性猛交免费视频 | 男女猛烈xx00免费视频试看 | 免费看男女做好爽好硬视频 | 欧美变态另类xxxx | 丝袜足控一区二区三区 | 99在线 | 亚洲 | 国产精品igao视频网 | 激情亚洲一区国产精品 | 男女作爱免费网站 | 丰满人妻翻云覆雨呻吟视频 | 欧美性生交活xxxxxdddd | 欧美人与禽zoz0性伦交 | 麻豆蜜桃av蜜臀av色欲av | 国产在线无码精品电影网 | 少妇性俱乐部纵欲狂欢电影 | 一本久道久久综合狠狠爱 | 色婷婷综合中文久久一本 | 国产人妻人伦精品 | 精品一二三区久久aaa片 | 永久免费观看国产裸体美女 | 国产精品高潮呻吟av久久 | 亚洲精品久久久久久一区二区 | 无码福利日韩神码福利片 | 未满成年国产在线观看 | 俺去俺来也在线www色官网 | 国产亚洲精品久久久久久国模美 | 亚洲国产成人av在线观看 | 日韩 欧美 动漫 国产 制服 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 激情国产av做激情国产爱 | 领导边摸边吃奶边做爽在线观看 | 欧美野外疯狂做受xxxx高潮 | 亚洲人成网站免费播放 | 欧美老熟妇乱xxxxx | 无码人妻丰满熟妇区毛片18 | 三上悠亚人妻中文字幕在线 | 久久综合九色综合欧美狠狠 | 妺妺窝人体色www在线小说 | 妺妺窝人体色www婷婷 | 人妻有码中文字幕在线 | 亚洲狠狠色丁香婷婷综合 | 免费看少妇作爱视频 | 欧美阿v高清资源不卡在线播放 | 欧美日韩人成综合在线播放 | 久久久成人毛片无码 | 中文无码伦av中文字幕 | 久久熟妇人妻午夜寂寞影院 | 丰满人妻精品国产99aⅴ | 国产精品永久免费视频 | 美女黄网站人色视频免费国产 | 在线а√天堂中文官网 | 玩弄人妻少妇500系列视频 | 国产人妻久久精品二区三区老狼 | 国产成人综合色在线观看网站 | 欧美日韩色另类综合 | 中文字幕无码乱人伦 | 无遮挡啪啪摇乳动态图 | 夜先锋av资源网站 | 国产成人无码av片在线观看不卡 | 人妻人人添人妻人人爱 | 久久无码专区国产精品s | 少妇厨房愉情理9仑片视频 | 精品熟女少妇av免费观看 | 2019nv天堂香蕉在线观看 | 精品国产一区av天美传媒 | 午夜免费福利小电影 | av香港经典三级级 在线 | 国产在线一区二区三区四区五区 | 久久熟妇人妻午夜寂寞影院 | 人人妻人人澡人人爽人人精品浪潮 | 国内少妇偷人精品视频免费 | 亚洲 激情 小说 另类 欧美 | 国产精品亚洲专区无码不卡 | 精品欧洲av无码一区二区三区 | 久久久久成人片免费观看蜜芽 | 成熟女人特级毛片www免费 | 亚洲国产欧美国产综合一区 | 亚洲人成影院在线无码按摩店 | 国产亚洲欧美日韩亚洲中文色 | 国产在线无码精品电影网 | 西西人体www44rt大胆高清 | 久久成人a毛片免费观看网站 | 狠狠综合久久久久综合网 | 精品一二三区久久aaa片 | 婷婷色婷婷开心五月四房播播 | 无遮挡啪啪摇乳动态图 | 欧美日韩精品 | 国产精品国产三级国产专播 | 丰满少妇熟乱xxxxx视频 | 中文字幕精品av一区二区五区 | 国产成人精品视频ⅴa片软件竹菊 | 内射白嫩少妇超碰 | 无码人妻av免费一区二区三区 | 成熟女人特级毛片www免费 | 国产亚洲欧美在线专区 | 无人区乱码一区二区三区 | 亚洲精品国产品国语在线观看 | 无码人妻av免费一区二区三区 | 国内综合精品午夜久久资源 | 国产av剧情md精品麻豆 | 内射白嫩少妇超碰 | 国产明星裸体无码xxxx视频 | 好男人社区资源 | 十八禁真人啪啪免费网站 | 色综合久久久无码中文字幕 | 免费播放一区二区三区 | 中文字幕人妻无码一夲道 | 免费男性肉肉影院 | 中文字幕乱妇无码av在线 | 亚洲a无码综合a国产av中文 | 蜜臀av在线播放 久久综合激激的五月天 | 亚洲一区二区三区偷拍女厕 | 99久久人妻精品免费一区 | 97精品国产97久久久久久免费 | 久久无码人妻影院 | 国内精品人妻无码久久久影院 | 人人妻人人澡人人爽欧美一区九九 | 红桃av一区二区三区在线无码av | 午夜无码区在线观看 | 国产麻豆精品精东影业av网站 | 一个人看的www免费视频在线观看 | 国产成人无码a区在线观看视频app | 青草视频在线播放 | 国产九九九九九九九a片 | 亚洲欧洲无卡二区视頻 | 一个人看的www免费视频在线观看 | 国产精品嫩草久久久久 | 亚洲欧洲日本综合aⅴ在线 | 亚洲中文字幕无码中字 | 欧美日韩人成综合在线播放 | 亚洲精品久久久久久一区二区 | 亚洲国产欧美日韩精品一区二区三区 | 对白脏话肉麻粗话av | 性欧美疯狂xxxxbbbb | 亚洲 激情 小说 另类 欧美 | 99久久精品国产一区二区蜜芽 | 欧美成人高清在线播放 | 夜夜夜高潮夜夜爽夜夜爰爰 | 奇米影视7777久久精品人人爽 | 国产综合久久久久鬼色 | 日韩欧美中文字幕在线三区 | 青青草原综合久久大伊人精品 | av小次郎收藏 | 久久精品国产一区二区三区 | 欧美zoozzooz性欧美 | 久久国产精品偷任你爽任你 | 日本爽爽爽爽爽爽在线观看免 | 最新国产麻豆aⅴ精品无码 | 人妻夜夜爽天天爽三区 | 国产又爽又黄又刺激的视频 | 秋霞成人午夜鲁丝一区二区三区 | 牲欲强的熟妇农村老妇女 | 国产做国产爱免费视频 | 色综合久久久久综合一本到桃花网 | 永久免费精品精品永久-夜色 | 亚洲成色www久久网站 | 图片区 小说区 区 亚洲五月 | 色欲久久久天天天综合网精品 | 久久久久久久久蜜桃 | 人妻天天爽夜夜爽一区二区 | www国产精品内射老师 | 夜夜高潮次次欢爽av女 | 欧美野外疯狂做受xxxx高潮 | 亚洲精品一区二区三区婷婷月 | 久久97精品久久久久久久不卡 | 少妇无码av无码专区在线观看 | 特级做a爰片毛片免费69 | 国产又粗又硬又大爽黄老大爷视 | 成在人线av无码免费 | 欧美午夜特黄aaaaaa片 | 青青青手机频在线观看 | 少妇高潮一区二区三区99 | 强伦人妻一区二区三区视频18 | aⅴ在线视频男人的天堂 | 国产激情一区二区三区 | 亚洲色在线无码国产精品不卡 | 麻豆蜜桃av蜜臀av色欲av | 麻豆精品国产精华精华液好用吗 | 九九久久精品国产免费看小说 | av小次郎收藏 | 樱花草在线社区www | 国产深夜福利视频在线 | 国产亚洲精品久久久久久大师 | 中文无码伦av中文字幕 | 国产综合在线观看 | 蜜臀av在线播放 久久综合激激的五月天 | 免费播放一区二区三区 | 亚洲中文字幕无码中字 | 国产午夜手机精彩视频 | 日产国产精品亚洲系列 | 亚洲国产成人av在线观看 | 亚洲精品无码国产 | 大肉大捧一进一出好爽视频 | 十八禁视频网站在线观看 | 国产一区二区三区四区五区加勒比 | 欧美亚洲国产一区二区三区 | 久久国语露脸国产精品电影 | 国产成人综合色在线观看网站 | 麻豆av传媒蜜桃天美传媒 | 国产精品久久久午夜夜伦鲁鲁 | 无码午夜成人1000部免费视频 | 久久久精品人妻久久影视 | аⅴ资源天堂资源库在线 | 狠狠色丁香久久婷婷综合五月 | 久久99热只有频精品8 | 樱花草在线社区www | 亚洲精品无码人妻无码 | 又湿又紧又大又爽a视频国产 | 动漫av网站免费观看 | 人妻无码αv中文字幕久久琪琪布 | 亚洲国产成人a精品不卡在线 | 给我免费的视频在线观看 | 99久久亚洲精品无码毛片 | 少妇无码av无码专区在线观看 | 久久久久久a亚洲欧洲av冫 | 日本又色又爽又黄的a片18禁 | 久久精品人妻少妇一区二区三区 | 成人欧美一区二区三区黑人 | 性色欲情网站iwww九文堂 | 无套内谢的新婚少妇国语播放 | 99久久精品日本一区二区免费 | 亚洲乱码日产精品bd | 鲁鲁鲁爽爽爽在线视频观看 | 国产亚洲精品久久久久久久 | 亚洲日韩中文字幕在线播放 | 国产精品无码mv在线观看 | 国产一区二区三区精品视频 | 国产真人无遮挡作爱免费视频 | 对白脏话肉麻粗话av | 强奷人妻日本中文字幕 | 欧美丰满熟妇xxxx | 久久人妻内射无码一区三区 | 亚洲精品一区二区三区婷婷月 | 极品嫩模高潮叫床 | 国产区女主播在线观看 | 午夜精品久久久内射近拍高清 | 性做久久久久久久免费看 | 日本熟妇浓毛 | 欧美xxxx黑人又粗又长 | 无套内谢的新婚少妇国语播放 | 一本色道久久综合狠狠躁 | 麻豆国产人妻欲求不满 | 综合网日日天干夜夜久久 | 黑人玩弄人妻中文在线 | 久久人妻内射无码一区三区 | 未满成年国产在线观看 | 中文无码成人免费视频在线观看 | 亚洲中文字幕无码一久久区 | 亚洲中文字幕久久无码 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产精品-区区久久久狼 | 国产人妻人伦精品 | 人妻天天爽夜夜爽一区二区 | 亚洲 另类 在线 欧美 制服 | 亚洲欧美日韩成人高清在线一区 | 久久精品中文字幕大胸 | 波多野结衣aⅴ在线 | 强伦人妻一区二区三区视频18 | 色爱情人网站 | 免费观看的无遮挡av | 台湾无码一区二区 | 中文字幕无码av激情不卡 | 亚洲中文字幕在线无码一区二区 | 鲁鲁鲁爽爽爽在线视频观看 | 国产偷自视频区视频 | 午夜无码人妻av大片色欲 | 久久亚洲精品成人无码 | 久久久久se色偷偷亚洲精品av | 精品欧美一区二区三区久久久 | 国产艳妇av在线观看果冻传媒 | 国产凸凹视频一区二区 | 国产精品免费大片 | 波多野结衣一区二区三区av免费 | 婷婷综合久久中文字幕蜜桃三电影 | 国产国产精品人在线视 | 天天综合网天天综合色 | 午夜男女很黄的视频 | 久久午夜无码鲁丝片秋霞 | 一本久久a久久精品vr综合 | 人人澡人摸人人添 | 久久综合给久久狠狠97色 | 99久久精品日本一区二区免费 | 久久天天躁狠狠躁夜夜免费观看 | 久久zyz资源站无码中文动漫 | 午夜福利不卡在线视频 | 亚洲成av人片在线观看无码不卡 | 黑森林福利视频导航 | 综合激情五月综合激情五月激情1 | 国产suv精品一区二区五 | 国产热a欧美热a在线视频 | 国产人妻久久精品二区三区老狼 | 精品aⅴ一区二区三区 | 一本无码人妻在中文字幕免费 | 欧美猛少妇色xxxxx | 亚洲中文字幕在线观看 | 一本久久a久久精品亚洲 | 乱码av麻豆丝袜熟女系列 | 国产午夜手机精彩视频 | 久久久久se色偷偷亚洲精品av | 亚洲爆乳大丰满无码专区 | 人妻体内射精一区二区三四 | 亚洲人成网站色7799 | 黑人玩弄人妻中文在线 | 国精产品一区二区三区 | 国产精品无套呻吟在线 | 午夜精品久久久久久久久 | 九月婷婷人人澡人人添人人爽 | 中文字幕乱码亚洲无线三区 | 亚洲精品久久久久中文第一幕 | 国精品人妻无码一区二区三区蜜柚 | 无码人妻精品一区二区三区下载 | 亚洲国产精品成人久久蜜臀 | 成熟女人特级毛片www免费 | 亚洲国产精品久久人人爱 | 在线观看欧美一区二区三区 | 国产成人综合色在线观看网站 | 国产免费久久精品国产传媒 | 久久久久亚洲精品男人的天堂 | 男人的天堂av网站 | 青青久在线视频免费观看 | 中文毛片无遮挡高清免费 | 波多野结衣高清一区二区三区 | 国产免费无码一区二区视频 | 沈阳熟女露脸对白视频 | 国产香蕉97碰碰久久人人 | 国产精品99久久精品爆乳 | 特大黑人娇小亚洲女 | 成人女人看片免费视频放人 | 国产激情无码一区二区app | 黑人粗大猛烈进出高潮视频 | 一本久道久久综合婷婷五月 | 亚洲啪av永久无码精品放毛片 | 国产成人精品视频ⅴa片软件竹菊 | 97色伦图片97综合影院 | 日本肉体xxxx裸交 | 国产精品-区区久久久狼 | 欧美性色19p | 久久zyz资源站无码中文动漫 | 亚洲国产av精品一区二区蜜芽 | 在线播放免费人成毛片乱码 | 精品日本一区二区三区在线观看 | 国产熟妇高潮叫床视频播放 | 亚洲综合无码久久精品综合 | 久久精品国产精品国产精品污 | 黑人大群体交免费视频 | 疯狂三人交性欧美 | 亚洲一区二区三区四区 | 波多野结衣一区二区三区av免费 | 无码午夜成人1000部免费视频 | 狂野欧美激情性xxxx | 日日天干夜夜狠狠爱 | 日日橹狠狠爱欧美视频 | 噜噜噜亚洲色成人网站 | 色欲综合久久中文字幕网 | 99久久久国产精品无码免费 | 久久国产自偷自偷免费一区调 | 国产真实乱对白精彩久久 | 人人妻人人澡人人爽精品欧美 | 国产精品久久久久久久影院 | 久久这里只有精品视频9 | 55夜色66夜色国产精品视频 | 日韩欧美中文字幕公布 | 色欲综合久久中文字幕网 | 大肉大捧一进一出视频出来呀 | 精品一区二区三区波多野结衣 | 一区二区三区乱码在线 | 欧洲 | 人妻无码αv中文字幕久久琪琪布 | 最近的中文字幕在线看视频 | 成人精品视频一区二区 | 国产免费无码一区二区视频 | 蜜桃视频插满18在线观看 | 狠狠噜狠狠狠狠丁香五月 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 亚洲中文字幕在线观看 | 岛国片人妻三上悠亚 | 久久久亚洲欧洲日产国码αv | 久久国语露脸国产精品电影 | 99久久无码一区人妻 | 中文字幕久久久久人妻 | 精品 日韩 国产 欧美 视频 | 无码任你躁久久久久久久 | 成人动漫在线观看 | 国产精品久久久久久久影院 | 四虎影视成人永久免费观看视频 | 国产精品第一区揄拍无码 | 成人毛片一区二区 | 久久久婷婷五月亚洲97号色 | 欧美精品一区二区精品久久 | 97精品人妻一区二区三区香蕉 | 青青青手机频在线观看 | 十八禁真人啪啪免费网站 | 18黄暴禁片在线观看 | 无套内谢的新婚少妇国语播放 | 女人色极品影院 | 亚洲综合在线一区二区三区 | 国产网红无码精品视频 | 亚洲中文字幕久久无码 | 少妇久久久久久人妻无码 | 日韩欧美成人免费观看 | 国产精品亚洲一区二区三区喷水 | 亚洲精品www久久久 | 超碰97人人做人人爱少妇 | 久久久久亚洲精品中文字幕 | 丰满人妻被黑人猛烈进入 | 丰满少妇熟乱xxxxx视频 | 中文字幕+乱码+中文字幕一区 | 欧美日韩一区二区综合 | 亚洲成a人片在线观看无码3d | 中文字幕亚洲情99在线 | 色诱久久久久综合网ywww | 亚洲日韩一区二区三区 | 亚洲国产av美女网站 | 国产激情无码一区二区app | 老熟女重囗味hdxx69 | 日韩亚洲欧美精品综合 | 中文字幕无码热在线视频 | a国产一区二区免费入口 | 四十如虎的丰满熟妇啪啪 | 天天拍夜夜添久久精品 | 久久久久久久久888 | 性欧美熟妇videofreesex | 老熟女乱子伦 | 日本乱偷人妻中文字幕 | 国产亚洲人成在线播放 | 东京热无码av男人的天堂 | 少妇性l交大片欧洲热妇乱xxx | 国产精品久久久av久久久 | 国产一区二区不卡老阿姨 | 又黄又爽又色的视频 | 久久伊人色av天堂九九小黄鸭 | 日韩人妻系列无码专区 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 久久国内精品自在自线 | 97se亚洲精品一区 | 成人毛片一区二区 | 精品无码成人片一区二区98 | 亚洲春色在线视频 | 欧美日韩综合一区二区三区 | 精品人妻人人做人人爽 | 日韩精品一区二区av在线 | 强伦人妻一区二区三区视频18 | 国产成人精品视频ⅴa片软件竹菊 | 欧美精品免费观看二区 | 国产一区二区三区日韩精品 | 天天躁夜夜躁狠狠是什么心态 | 人妻天天爽夜夜爽一区二区 | 国产精品第一国产精品 | 在线播放免费人成毛片乱码 | 精品国产精品久久一区免费式 | 国产一区二区三区日韩精品 | 性欧美疯狂xxxxbbbb | 国产熟妇另类久久久久 | 亚洲人成影院在线无码按摩店 | 999久久久国产精品消防器材 | 99在线 | 亚洲 | 夜夜高潮次次欢爽av女 | 国内丰满熟女出轨videos | 亚洲一区二区三区在线观看网站 | 呦交小u女精品视频 | 亚洲区小说区激情区图片区 | 精品久久久久久亚洲精品 | 国产艳妇av在线观看果冻传媒 | 久久精品中文字幕一区 | 精品国产乱码久久久久乱码 | av在线亚洲欧洲日产一区二区 | 国产免费久久精品国产传媒 | 噜噜噜亚洲色成人网站 | 欧洲美熟女乱又伦 | 精品欧美一区二区三区久久久 | 日韩精品无码一本二本三本色 | 永久免费精品精品永久-夜色 | 精品国产一区二区三区四区在线看 | 无码帝国www无码专区色综合 | 久久精品中文字幕一区 | 久久久久久国产精品无码下载 | 欧美人与善在线com | 国产乡下妇女做爰 | 成 人 网 站国产免费观看 | 露脸叫床粗话东北少妇 | 色综合久久中文娱乐网 | 麻豆精品国产精华精华液好用吗 | 国精品人妻无码一区二区三区蜜柚 | 97人妻精品一区二区三区 | 女人被男人爽到呻吟的视频 | 激情内射亚州一区二区三区爱妻 | 18禁止看的免费污网站 | 疯狂三人交性欧美 | 国内精品人妻无码久久久影院 | 亚洲人成网站免费播放 | 老熟女乱子伦 | 骚片av蜜桃精品一区 | 麻豆精产国品 | 色欲av亚洲一区无码少妇 | 精品无人区无码乱码毛片国产 | 九一九色国产 | 俺去俺来也在线www色官网 | 久久综合香蕉国产蜜臀av | 国精产品一区二区三区 | 欧美老妇交乱视频在线观看 | 久久国语露脸国产精品电影 | 牲欲强的熟妇农村老妇女 | 国产人妻精品一区二区三区不卡 | 特级做a爰片毛片免费69 | 精品熟女少妇av免费观看 | 无套内谢的新婚少妇国语播放 | 午夜熟女插插xx免费视频 | 日本精品人妻无码77777 天堂一区人妻无码 | 波多野结衣高清一区二区三区 | 乌克兰少妇性做爰 | 国产激情综合五月久久 | 久久午夜无码鲁丝片 | 午夜免费福利小电影 | 精品成在人线av无码免费看 | 国产人妻人伦精品1国产丝袜 | 精品人妻人人做人人爽夜夜爽 | 青草青草久热国产精品 | 久久99精品国产麻豆蜜芽 | 午夜精品久久久内射近拍高清 | 300部国产真实乱 | 任你躁国产自任一区二区三区 | 国产av剧情md精品麻豆 | 亚洲国产欧美国产综合一区 | 蜜桃视频插满18在线观看 | 欧美成人午夜精品久久久 | 日本精品少妇一区二区三区 | 精品一区二区三区无码免费视频 | 在线播放亚洲第一字幕 | 国产亚洲精品久久久久久 | 一本久久a久久精品亚洲 | 精品一区二区三区无码免费视频 | 欧美亚洲日韩国产人成在线播放 | 亚洲成色www久久网站 | 亚洲国产高清在线观看视频 | 欧美 丝袜 自拍 制服 另类 | 熟妇激情内射com | 色一情一乱一伦一区二区三欧美 | 久久熟妇人妻午夜寂寞影院 | 好男人www社区 | 人妻无码久久精品人妻 | 亚洲 日韩 欧美 成人 在线观看 | 精品熟女少妇av免费观看 | 亚洲人成人无码网www国产 | 自拍偷自拍亚洲精品10p | 日本一卡二卡不卡视频查询 | 亚洲一区av无码专区在线观看 | 伊在人天堂亚洲香蕉精品区 | 亚洲精品一区二区三区婷婷月 | 国产suv精品一区二区五 | 国产精品亚洲一区二区三区喷水 | 99麻豆久久久国产精品免费 | 亚洲综合无码一区二区三区 | yw尤物av无码国产在线观看 | 日本一区二区三区免费高清 | 国产9 9在线 | 中文 | 99久久亚洲精品无码毛片 | 久久综合网欧美色妞网 | 一本久久a久久精品vr综合 | 国产精品99久久精品爆乳 | 性生交大片免费看女人按摩摩 | 亚洲爆乳大丰满无码专区 | 老熟妇仑乱视频一区二区 | 女人高潮内射99精品 | 夜夜高潮次次欢爽av女 | 日本熟妇大屁股人妻 | 久久99精品久久久久久 | 久久久久久国产精品无码下载 | 人人妻人人澡人人爽欧美精品 | 欧美老熟妇乱xxxxx | 亚洲精品美女久久久久久久 | 全黄性性激高免费视频 | 精品久久综合1区2区3区激情 | 在线精品国产一区二区三区 | 精品少妇爆乳无码av无码专区 | 久久久久久a亚洲欧洲av冫 | 98国产精品综合一区二区三区 | 性开放的女人aaa片 | a在线观看免费网站大全 | 国产欧美亚洲精品a | 久久久精品人妻久久影视 | 婷婷六月久久综合丁香 | 国产黑色丝袜在线播放 | 一本久久a久久精品亚洲 | 国产亚洲人成a在线v网站 | 东京热男人av天堂 | 窝窝午夜理论片影院 | 大乳丰满人妻中文字幕日本 | 成人免费视频视频在线观看 免费 | 精品无码国产一区二区三区av | 色综合天天综合狠狠爱 | 好屌草这里只有精品 | 玩弄少妇高潮ⅹxxxyw | 99久久精品日本一区二区免费 | 国产精品久久久久7777 | 国产精品无码一区二区桃花视频 | 婷婷五月综合激情中文字幕 | 成人免费视频在线观看 | 国产精品99久久精品爆乳 | 国产精品久免费的黄网站 | 精品欧洲av无码一区二区三区 | 最新版天堂资源中文官网 | 国产成人亚洲综合无码 | 中文字幕人妻无码一夲道 | 妺妺窝人体色www在线小说 | 久久99热只有频精品8 | 亚洲国产成人a精品不卡在线 | 青青青爽视频在线观看 | 波多野结衣 黑人 | 无码成人精品区在线观看 | 熟女少妇在线视频播放 | 中文字幕人妻丝袜二区 | 国产内射老熟女aaaa | 老子影院午夜伦不卡 | 国产精品无码mv在线观看 | 少妇一晚三次一区二区三区 | 久久久中文字幕日本无吗 | 亚洲 日韩 欧美 成人 在线观看 | 国产精品理论片在线观看 | 5858s亚洲色大成网站www | 国产精品久久久久久久影院 | 欧美成人高清在线播放 | 人妻人人添人妻人人爱 | 未满小14洗澡无码视频网站 | 在教室伦流澡到高潮hnp视频 | 国产无遮挡又黄又爽又色 | 国产午夜无码精品免费看 | 国产麻豆精品精东影业av网站 | 亚洲中文字幕无码一久久区 | 99国产欧美久久久精品 | 国产成人精品久久亚洲高清不卡 | 理论片87福利理论电影 | 久久精品无码一区二区三区 | 久久久中文字幕日本无吗 | 亚洲区小说区激情区图片区 | 国产精品-区区久久久狼 | 黑人粗大猛烈进出高潮视频 | 婷婷五月综合缴情在线视频 | 麻豆av传媒蜜桃天美传媒 | 精品人人妻人人澡人人爽人人 | 熟妇人妻中文av无码 | 天海翼激烈高潮到腰振不止 | 亚洲熟妇自偷自拍另类 | 亚洲の无码国产の无码影院 | 国产舌乚八伦偷品w中 | 最新版天堂资源中文官网 | 在线播放亚洲第一字幕 | 男女下面进入的视频免费午夜 | 国产香蕉尹人综合在线观看 | 无码人中文字幕 |