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

海量數(shù)據(jù)庫(kù)的查詢(xún)優(yōu)化及分頁(yè)算法方案

 更新時(shí)間:2007年03月16日 00:00:00   作者:  
海量數(shù)據(jù)庫(kù)的查詢(xún)優(yōu)化及分頁(yè)算法方案 
原出處不詳
摘自:www.21php.com
隨著“金盾工程”建設(shè)的逐步深入和公安信息化的高速發(fā)展,公安計(jì)算機(jī)應(yīng)用系統(tǒng)被廣泛應(yīng)用在各警種、各部門(mén)。與此同時(shí),應(yīng)用系統(tǒng)體系的核心、系統(tǒng)數(shù)據(jù)的存放地――數(shù)據(jù)庫(kù)也隨著實(shí)際應(yīng)用而急劇膨脹,一些大規(guī)模的系統(tǒng),如人口系統(tǒng)的數(shù)據(jù)甚至超過(guò)了1000萬(wàn)條,可謂海量。那么,如何實(shí)現(xiàn)快速地從這些超大容量的數(shù)據(jù)庫(kù)中提取數(shù)據(jù)(查詢(xún))、分析、統(tǒng)計(jì)以及提取數(shù)據(jù)后進(jìn)行數(shù)據(jù)分頁(yè)已成為各地系統(tǒng)管理員和數(shù)據(jù)庫(kù)管理員亟待解決的難題。
在以下的文章中,我將以“辦公自動(dòng)化”系統(tǒng)為例,探討如何在有著1000萬(wàn)條數(shù)據(jù)的MS SQL SERVER數(shù)據(jù)庫(kù)中實(shí)現(xiàn)快速的數(shù)據(jù)提取和數(shù)據(jù)分頁(yè)。以下代碼說(shuō)明了我們實(shí)例中數(shù)據(jù)庫(kù)的“紅頭文件”一表的部分?jǐn)?shù)據(jù)結(jié)構(gòu):
CREATE TABLE [dbo].[TGongwen] ( --TGongwen是紅頭文件表名
[Gid] [int] IDENTITY (1, 1) NOT NULL ,
--本表的id號(hào),也是主鍵
[title] [varchar] (80) COLLATE Chinese_PRC_CI_AS NULL , 
--紅頭文件的標(biāo)題
[fariqi] [datetime] NULL ,
--發(fā)布日期
[neibuYonghu] [varchar] (70) COLLATE Chinese_PRC_CI_AS NULL ,
--發(fā)布用戶(hù)
[reader] [varchar] (900) COLLATE Chinese_PRC_CI_AS NULL ,
--需要瀏覽的用戶(hù)。每個(gè)用戶(hù)中間用分隔符“,”分開(kāi)
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
下面,我們來(lái)往數(shù)據(jù)庫(kù)中添加1000萬(wàn)條數(shù)據(jù):
declare @i int
set @i=1
while @i<=250000
begin
insert into Tgongwen(fariqi,neibuyonghu,reader,title) values('2004-2-5','通信科','通信科,辦公室,王局長(zhǎng),劉局長(zhǎng),張局長(zhǎng),admin,刑偵支隊(duì),特勤支隊(duì),交巡警支隊(duì),經(jīng)偵支隊(duì), 戶(hù)政科,治安支隊(duì),外事科','這是最先的25萬(wàn)條記錄')
set @i=@i+1
end
GO
declare @i int
set @i=1
while @i<=250000
begin
insert into Tgongwen(fariqi,neibuyonghu,reader,title) values('2004-9-16','辦公室','辦公室,通信科,王局長(zhǎng),劉局長(zhǎng),張局長(zhǎng),admin,刑偵支隊(duì),特勤支隊(duì),交巡警支隊(duì),經(jīng)偵支隊(duì),戶(hù)政科,外事科','這是中間的25萬(wàn)條記錄')
set @i=@i+1
end
GO
declare @h int
set @h=1
while @h<=100
begin
declare @i int
set @i=2002
while @i<=2003
begin
declare @j int
set @j=0
while @j<50
begin
declare @k int
set @k=0
while @k<50
begin
insert into Tgongwen(fariqi,neibuyonghu,reader,title) values(cast(@i as varchar(4))+'-8-15 3:'+cast(@j as varchar(2))+':'+cast(@j as varchar(2)),'通信科','辦公室,通信科,王局長(zhǎng),劉局長(zhǎng),張局長(zhǎng),admin,刑偵支隊(duì),特勤支隊(duì),交巡警支隊(duì),經(jīng)偵支隊(duì),戶(hù)政科,外事科','這是最后的50萬(wàn)條記錄')
set @k=@k+1
end
set @j=@j+1
end
set @i=@i+1
end
set @h=@h+1
end
GO
declare @i int
set @i=1
while @i<=9000000
begin
insert into Tgongwen(fariqi,neibuyonghu,reader,title) values('2004-5-5','通信科','通信科,辦公室,王局長(zhǎng),劉局長(zhǎng),張局長(zhǎng),admin,刑偵支隊(duì),特勤支隊(duì),交巡警支隊(duì),經(jīng)偵支隊(duì), 戶(hù)政科,治安支隊(duì),外事科','這是最后添加的900萬(wàn)條記錄')
set @i=@i+1000000
end
GO
通過(guò)以上語(yǔ)句,我們創(chuàng)建了25萬(wàn)條由通信科于2004年2月5日發(fā)布的記錄,25萬(wàn)條由辦公室于2004年9月6日發(fā)布的記錄,2002年和 2003年各100個(gè)2500條相同日期、不同分秒的由通信科發(fā)布的記錄(共50萬(wàn)條),還有由通信科于2004年5月5日發(fā)布的900萬(wàn)條記錄,合計(jì) 1000萬(wàn)條。
一、因情制宜,建立“適當(dāng)”的索引
建立“適當(dāng)”的索引是實(shí)現(xiàn)查詢(xún)優(yōu)化的首要前提。
索引(index)是除表之外另一重要的、用戶(hù)定義的存儲(chǔ)在物理介質(zhì)上的數(shù)據(jù)結(jié)構(gòu)。當(dāng)根據(jù)索引碼的值搜索數(shù)據(jù)時(shí),索引提供了對(duì)數(shù)據(jù)的快速訪(fǎng)問(wèn)。事實(shí)上,沒(méi)有索引,數(shù)據(jù)庫(kù)也能根據(jù)SELECT語(yǔ)句成功地檢索到結(jié)果,但隨著表變得越來(lái)越大,使用“適當(dāng)”的索引的效果就越來(lái)越明顯。注意,在這句話(huà)中,我們用了“適當(dāng)”這個(gè)詞,這是因?yàn)?,如果使用索引時(shí)不認(rèn)真考慮其實(shí)現(xiàn)過(guò)程,索引既可以提高也會(huì)破壞數(shù)據(jù)庫(kù)的工作性能。
(一)深入淺出理解索引結(jié)構(gòu)
實(shí)際上,您可以把索引理解為一種特殊的目錄。微軟的SQL SERVER提供了兩種索引:聚集索引(clustered index,也稱(chēng)聚類(lèi)索引、簇集索引)和非聚集索引(nonclustered index,也稱(chēng)非聚類(lèi)索引、非簇集索引)。下面,我們舉例來(lái)說(shuō)明一下聚集索引和非聚集索引的區(qū)別:
其實(shí),我們的漢語(yǔ)字典的正文本身就是一個(gè)聚集索引。比如,我們要查“安”字,就會(huì)很自然地翻開(kāi)字典的前幾頁(yè),因?yàn)椤鞍病钡钠匆羰恰癮n”,而按照拼音排序漢字的字典是以英文字母“a”開(kāi)頭并以“z”結(jié)尾的,那么“安”字就自然地排在字典的前部。如果您翻完了所有以“a”開(kāi)頭的部分仍然找不到這個(gè)字,那么就說(shuō)明您的字典中沒(méi)有這個(gè)字;同樣的,如果查“張”字,那您也會(huì)將您的字典翻到最后部分,因?yàn)椤皬垺钡钠匆羰恰皕hang”。也就是說(shuō),字典的正文部分本身就是一個(gè)目錄,您不需要再去查其他目錄來(lái)找到您需要找的內(nèi)容。
我們把這種正文內(nèi)容本身就是一種按照一定規(guī)則排列的目錄稱(chēng)為“聚集索引”。
如果您認(rèn)識(shí)某個(gè)字,您可以快速地從自動(dòng)中查到這個(gè)字。但您也可能會(huì)遇到您不認(rèn)識(shí)的字,不知道它的發(fā)音,這時(shí)候,您就不能按照剛才的方法找到您要查的字,而需要去根據(jù)“偏旁部首”查到您要找的字,然后根據(jù)這個(gè)字后的頁(yè)碼直接翻到某頁(yè)來(lái)找到您要找的字。但您結(jié)合“部首目錄”和“檢字表”而查到的字的排序并不是真正的正文的排序方法,比如您查“張”字,我們可以看到在查部首之后的檢字表中“張”的頁(yè)碼是672頁(yè),檢字表中“張”的上面是“馳”字,但頁(yè)碼卻是63頁(yè),“張”的下面是“弩”字,頁(yè)面是390頁(yè)。很顯然,這些字并不是真正的分別位于“張”字的上下方,現(xiàn)在您看到的連續(xù)的“馳、張、弩”三字實(shí)際上就是他們?cè)诜蔷奂饕械呐判颍亲值湔闹械淖衷诜蔷奂饕械挠成?。我們可以通過(guò)這種方式來(lái)找到您所需要的字,但它需要兩個(gè)過(guò)程,先找到目錄中的結(jié)果,然后再翻到您所需要的頁(yè)碼。
我們把這種目錄純粹是目錄,正文純粹是正文的排序方式稱(chēng)為“非聚集索引”。
通過(guò)以上例子,我們可以理解到什么是“聚集索引”和“非聚集索引”。
進(jìn)一步引申一下,我們可以很容易的理解:每個(gè)表只能有一個(gè)聚集索引,因?yàn)槟夸浿荒馨凑找环N方法進(jìn)行排序。
(二)何時(shí)使用聚集索引或非聚集索引
下面的表總結(jié)了何時(shí)使用聚集索引或非聚集索引(很重要)。
動(dòng)作描述
使用聚集索引
使用非聚集索引
列經(jīng)常被分組排序
應(yīng)
應(yīng)
返回某范圍內(nèi)的數(shù)據(jù)
應(yīng)
不應(yīng)
一個(gè)或極少不同值
不應(yīng)
不應(yīng)
小數(shù)目的不同值
應(yīng)
不應(yīng)
大數(shù)目的不同值
不應(yīng)
應(yīng)
頻繁更新的列
不應(yīng)
應(yīng)
外鍵列
應(yīng)
應(yīng)
主鍵列
應(yīng)
應(yīng)
頻繁修改索引列
不應(yīng)
應(yīng)
事實(shí)上,我們可以通過(guò)前面聚集索引和非聚集索引的定義的例子來(lái)理解上表。如:返回某范圍內(nèi)的數(shù)據(jù)一項(xiàng)。比如您的某個(gè)表有一個(gè)時(shí)間列,恰好您把聚合索引建立在了該列,這時(shí)您查詢(xún)2004年1月1日至2004年10月1日之間的全部數(shù)據(jù)時(shí),這個(gè)速度就將是很快的,因?yàn)槟倪@本字典正文是按日期進(jìn)行排序的,聚類(lèi)索引只需要找到要檢索的所有數(shù)據(jù)中的開(kāi)頭和結(jié)尾數(shù)據(jù)即可;而不像非聚集索引,必須先查到目錄中查到每一項(xiàng)數(shù)據(jù)對(duì)應(yīng)的頁(yè)碼,然后再根據(jù)頁(yè)碼查到具體內(nèi)容。
(三)結(jié)合實(shí)際,談索引使用的誤區(qū)
理論的目的是應(yīng)用。雖然我們剛才列出了何時(shí)應(yīng)使用聚集索引或非聚集索引,但在實(shí)踐中以上規(guī)則卻很容易被忽視或不能根據(jù)實(shí)際情況進(jìn)行綜合分析。下面我們將根據(jù)在實(shí)踐中遇到的實(shí)際問(wèn)題來(lái)談一下索引使用的誤區(qū),以便于大家掌握索引建立的方法。
1、主鍵就是聚集索引
這種想法筆者認(rèn)為是極端錯(cuò)誤的,是對(duì)聚集索引的一種浪費(fèi)。雖然SQL SERVER默認(rèn)是在主鍵上建立聚集索引的。
通常,我們會(huì)在每個(gè)表中都建立一個(gè)ID列,以區(qū)分每條數(shù)據(jù),并且這個(gè)ID列是自動(dòng)增大的,步長(zhǎng)一般為1。我們的這個(gè)辦公自動(dòng)化的實(shí)例中的列Gid就是如此。此時(shí),如果我們將這個(gè)列設(shè)為主鍵,SQL SERVER會(huì)將此列默認(rèn)為聚集索引。這樣做有好處,就是可以讓您的數(shù)據(jù)在數(shù)據(jù)庫(kù)中按照ID進(jìn)行物理排序,但筆者認(rèn)為這樣做意義不大。
顯而易見(jiàn),聚集索引的優(yōu)勢(shì)是很明顯的,而每個(gè)表中只能有一個(gè)聚集索引的規(guī)則,這使得聚集索引變得更加珍貴。
從我們前面談到的聚集索引的定義我們可以看出,使用聚集索引的最大好處就是能夠根據(jù)查詢(xún)要求,迅速縮小查詢(xún)范圍,避免全表掃描。在實(shí)際應(yīng)用中,因?yàn)?nbsp;ID號(hào)是自動(dòng)生成的,我們并不知道每條記錄的ID號(hào),所以我們很難在實(shí)踐中用ID號(hào)來(lái)進(jìn)行查詢(xún)。這就使讓ID號(hào)這個(gè)主鍵作為聚集索引成為一種資源浪費(fèi)。其次,讓每個(gè)ID號(hào)都不同的字段作為聚集索引也不符合“大數(shù)目的不同值情況下不應(yīng)建立聚合索引”規(guī)則;當(dāng)然,這種情況只是針對(duì)用戶(hù)經(jīng)常修改記錄內(nèi)容,特別是索引項(xiàng)的時(shí)候會(huì)負(fù)作用,但對(duì)于查詢(xún)速度并沒(méi)有影響。
在辦公自動(dòng)化系統(tǒng)中,無(wú)論是系統(tǒng)首頁(yè)顯示的需要用戶(hù)簽收的文件、會(huì)議還是用戶(hù)進(jìn)行文件查詢(xún)等任何情況下進(jìn)行數(shù)據(jù)查詢(xún)都離不開(kāi)字段的是“日期”還有用戶(hù)本身的“用戶(hù)名”。
通常,辦公自動(dòng)化的首頁(yè)會(huì)顯示每個(gè)用戶(hù)尚未簽收的文件或會(huì)議。雖然我們的where語(yǔ)句可以?xún)H僅限制當(dāng)前用戶(hù)尚未簽收的情況,但如果您的系統(tǒng)已建立了很長(zhǎng)時(shí)間,并且數(shù)據(jù)量很大,那么,每次每個(gè)用戶(hù)打開(kāi)首頁(yè)的時(shí)候都進(jìn)行一次全表掃描,這樣做意義是不大的,絕大多數(shù)的用戶(hù)1個(gè)月前的文件都已經(jīng)瀏覽過(guò)了,這樣做只能徒增數(shù)據(jù)庫(kù)的開(kāi)銷(xiāo)而已。事實(shí)上,我們完全可以讓用戶(hù)打開(kāi)系統(tǒng)首頁(yè)時(shí),數(shù)據(jù)庫(kù)僅僅查詢(xún)這個(gè)用戶(hù)近3個(gè)月來(lái)未閱覽的文件,通過(guò)“日期”這個(gè)字段來(lái)限制表掃描,提高查詢(xún)速度。如果您的辦公自動(dòng)化系統(tǒng)已經(jīng)建立的2年,那么您的首頁(yè)顯示速度理論上將是原來(lái)速度8倍,甚至更快。
在這里之所以提到“理論上”三字,是因?yàn)槿绻木奂饕€是盲目地建在ID這個(gè)主鍵上時(shí),您的查詢(xún)速度是沒(méi)有這么高的,即使您在“日期”這個(gè)字段上建立的索引(非聚合索引)。下面我們就來(lái)看一下在1000萬(wàn)條數(shù)據(jù)量的情況下各種查詢(xún)的速度表現(xiàn)(3個(gè)月內(nèi)的數(shù)據(jù)為25萬(wàn)條):
(1)僅在主鍵上建立聚集索引,并且不劃分時(shí)間段:
Select gid,fariqi,neibuyonghu,title from tgongwen
用時(shí):128470毫秒(即:128秒)
(2)在主鍵上建立聚集索引,在fariq上建立非聚集索引:
select gid,fariqi,neibuyonghu,title from Tgongwen
where fariqi> dateadd(day,-90,getdate())
用時(shí):53763毫秒(54秒)
(3)將聚合索引建立在日期列(fariqi)上:
select gid,fariqi,neibuyonghu,title from Tgongwen
where fariqi> dateadd(day,-90,getdate())
用時(shí):2423毫秒(2秒)
雖然每條語(yǔ)句提取出來(lái)的都是25萬(wàn)條數(shù)據(jù),各種情況的差異卻是巨大的,特別是將聚集索引建立在日期列時(shí)的差異。事實(shí)上,如果您的數(shù)據(jù)庫(kù)真的有 1000萬(wàn)容量的話(huà),把主鍵建立在ID列上,就像以上的第1、2種情況,在網(wǎng)頁(yè)上的表現(xiàn)就是超時(shí),根本就無(wú)法顯示。這也是我摒棄ID列作為聚集索引的一個(gè)最重要的因素。
得出以上速度的方法是:在各個(gè)select語(yǔ)句前加:declare @d datetime
set @d=getdate()
并在select語(yǔ)句后加:
select [語(yǔ)句執(zhí)行花費(fèi)時(shí)間(毫秒)]=datediff(ms,@d,getdate())
2、只要建立索引就能顯著提高查詢(xún)速度
事實(shí)上,我們可以發(fā)現(xiàn)上面的例子中,第2、3條語(yǔ)句完全相同,且建立索引的字段也相同;不同的僅是前者在fariqi字段上建立的是非聚合索引,后者在此字段上建立的是聚合索引,但查詢(xún)速度卻有著天壤之別。所以,并非是在任何字段上簡(jiǎn)單地建立索引就能提高查詢(xún)速度。
從建表的語(yǔ)句中,我們可以看到這個(gè)有著1000萬(wàn)數(shù)據(jù)的表中fariqi字段有5003個(gè)不同記錄。在此字段上建立聚合索引是再合適不過(guò)了。在現(xiàn)實(shí)中,我們每天都會(huì)發(fā)幾個(gè)文件,這幾個(gè)文件的發(fā)文日期就相同,這完全符合建立聚集索引要求的:“既不能絕大多數(shù)都相同,又不能只有極少數(shù)相同”的規(guī)則。由此看來(lái),我們建立“適當(dāng)”的聚合索引對(duì)于我們提高查詢(xún)速度是非常重要的。
3、把所有需要提高查詢(xún)速度的字段都加進(jìn)聚集索引,以提高查詢(xún)速度
上面已經(jīng)談到:在進(jìn)行數(shù)據(jù)查詢(xún)時(shí)都離不開(kāi)字段的是“日期”還有用戶(hù)本身的“用戶(hù)名”。既然這兩個(gè)字段都是如此的重要,我們可以把他們合并起來(lái),建立一個(gè)復(fù)合索引(compound index)。
很多人認(rèn)為只要把任何字段加進(jìn)聚集索引,就能提高查詢(xún)速度,也有人感到迷惑:如果把復(fù)合的聚集索引字段分開(kāi)查詢(xún),那么查詢(xún)速度會(huì)減慢嗎?帶著這個(gè)問(wèn)題,我們來(lái)看一下以下的查詢(xún)速度(結(jié)果集都是25萬(wàn)條數(shù)據(jù)):(日期列fariqi首先排在復(fù)合聚集索引的起始列,用戶(hù)名neibuyonghu排在后列)
(1)select gid,fariqi,neibuyonghu,title from Tgongwen where fariqi>'2004-5-5'
查詢(xún)速度:2513毫秒
(2)select gid,fariqi,neibuyonghu,title from Tgongwen where fariqi>'2004-5-5' and neibuyonghu='辦公室'
查詢(xún)速度:2516毫秒
(3)select gid,fariqi,neibuyonghu,title from Tgongwen where neibuyonghu='辦公室'
查詢(xún)速度:60280毫秒
從以上試驗(yàn)中,我們可以看到如果僅用聚集索引的起始列作為查詢(xún)條件和同時(shí)用到復(fù)合聚集索引的全部列的查詢(xún)速度是幾乎一樣的,甚至比用上全部的復(fù)合索引列還要略快(在查詢(xún)結(jié)果集數(shù)目一樣的情況下);而如果僅用復(fù)合聚集索引的非起始列作為查詢(xún)條件的話(huà),這個(gè)索引是不起任何作用的。當(dāng)然,語(yǔ)句1、2的查詢(xún)速度一樣是因?yàn)椴樵?xún)的條目數(shù)一樣,如果復(fù)合索引的所有列都用上,而且查詢(xún)結(jié)果少的話(huà),這樣就會(huì)形成“索引覆蓋”,因而性能可以達(dá)到最優(yōu)。同時(shí),請(qǐng)記?。簾o(wú)論您是否經(jīng)常使用聚合索引的其他列,但其前導(dǎo)列一定要是使用最頻繁的列。
(四)其他書(shū)上沒(méi)有的索引使用經(jīng)驗(yàn)總結(jié)
1、用聚合索引比用不是聚合索引的主鍵速度快
下面是實(shí)例語(yǔ)句:(都是提取25萬(wàn)條數(shù)據(jù))
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi='2004-9-16'
使用時(shí)間:3326毫秒
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where gid<=250000
使用時(shí)間:4470毫秒
這里,用聚合索引比用不是聚合索引的主鍵速度快了近1/4。
2、用聚合索引比用一般的主鍵作order by時(shí)速度快,特別是在小數(shù)據(jù)量情況下
select gid,fariqi,neibuyonghu,reader,title from Tgongwen order by fariqi
用時(shí):12936
select gid,fariqi,neibuyonghu,reader,title from Tgongwen order by gid
用時(shí):18843
這里,用聚合索引比用一般的主鍵作order by時(shí),速度快了3/10。事實(shí)上,如果數(shù)據(jù)量很小的話(huà),用聚集索引作為排序列要比使用非聚集索引速度快得明顯的多;而數(shù)據(jù)量如果很大的話(huà),如10萬(wàn)以上,則二者的速度差別不明顯。
3、使用聚合索引內(nèi)的時(shí)間段,搜索時(shí)間會(huì)按數(shù)據(jù)占整個(gè)數(shù)據(jù)表的百分比成比例減少,而無(wú)論聚合索引使用了多少個(gè)
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi>'2004-1-1'
用時(shí):6343毫秒(提取100萬(wàn)條)
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi>'2004-6-6'
用時(shí):3170毫秒(提取50萬(wàn)條)
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi='2004-9-16'
用時(shí):3326毫秒(和上句的結(jié)果一模一樣。如果采集的數(shù)量一樣,那么用大于號(hào)和等于號(hào)是一樣的)
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi>'2004-1-1' and fariqi<'2004-6-6'
用時(shí):3280毫秒
4 、日期列不會(huì)因?yàn)橛蟹置氲妮斎攵鴾p慢查詢(xún)速度
下面的例子中,共有100萬(wàn)條數(shù)據(jù),2004年1月1日以后的數(shù)據(jù)有50萬(wàn)條,但只有兩個(gè)不同的日期,日期精確到日;之前有數(shù)據(jù)50萬(wàn)條,有5000個(gè)不同的日期,日期精確到秒。
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi>'2004-1-1' order by fariqi
用時(shí):6390毫秒
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi<'2004-1-1' order by fariqi
用時(shí):6453毫秒
(五)其他注意事項(xiàng)
“水可載舟,亦可覆舟”,索引也一樣。索引有助于提高檢索性能,但過(guò)多或不當(dāng)?shù)乃饕矔?huì)導(dǎo)致系統(tǒng)低效。因?yàn)橛脩?hù)在表中每加進(jìn)一個(gè)索引,數(shù)據(jù)庫(kù)就要做更多的工作。過(guò)多的索引甚至?xí)?dǎo)致索引碎片。
所以說(shuō),我們要建立一個(gè)“適當(dāng)”的索引體系,特別是對(duì)聚合索引的創(chuàng)建,更應(yīng)精益求精,以使您的數(shù)據(jù)庫(kù)能得到高性能的發(fā)揮。
當(dāng)然,在實(shí)踐中,作為一個(gè)盡職的數(shù)據(jù)庫(kù)管理員,您還要多測(cè)試一些方案,找出哪種方案效率最高、最為有效。
二、改善SQL語(yǔ)句
很多人不知道SQL語(yǔ)句在SQL SERVER中是如何執(zhí)行的,他們擔(dān)心自己所寫(xiě)的SQL語(yǔ)句會(huì)被SQL SERVER誤解。比如:
select * from table1 where name='zhangsan' and tID > 10000
和執(zhí)行:
select * from table1 where tID > 10000 and name='zhangsan'
一些人不知道以上兩條語(yǔ)句的執(zhí)行效率是否一樣,因?yàn)槿绻?jiǎn)單的從語(yǔ)句先后上看,這兩個(gè)語(yǔ)句的確是不一樣,如果tID是一個(gè)聚合索引,那么后一句僅僅從表的10000條以后的記錄中查找就行了;而前一句則要先從全表中查找看有幾個(gè)name='zhangsan'的,而后再根據(jù)限制條件條件 tID>10000來(lái)提出查詢(xún)結(jié)果。
事實(shí)上,這樣的擔(dān)心是不必要的。SQL SERVER中有一個(gè)“查詢(xún)分析優(yōu)化器”,它可以計(jì)算出where子句中的搜索條件并確定哪個(gè)索引能縮小表掃描的搜索空間,也就是說(shuō),它能實(shí)現(xiàn)自動(dòng)優(yōu)化。
雖然查詢(xún)優(yōu)化器可以根據(jù)where子句自動(dòng)的進(jìn)行查詢(xún)優(yōu)化,但大家仍然有必要了解一下“查詢(xún)優(yōu)化器”的工作原理,如非這樣,有時(shí)查詢(xún)優(yōu)化器就會(huì)不按照您的本意進(jìn)行快速查詢(xún)。
在查詢(xún)分析階段,查詢(xún)優(yōu)化器查看查詢(xún)的每個(gè)階段并決定限制需要掃描的數(shù)據(jù)量是否有用。如果一個(gè)階段可以被用作一個(gè)掃描參數(shù)(SARG),那么就稱(chēng)之為可優(yōu)化的,并且可以利用索引快速獲得所需數(shù)據(jù)。
SARG的定義:用于限制搜索的一個(gè)操作,因?yàn)樗ǔJ侵敢粋€(gè)特定的匹配,一個(gè)值得范圍內(nèi)的匹配或者兩個(gè)以上條件的AND連接。形式如下:
列名 操作符 <常數(shù) 或 變量>

<常數(shù) 或 變量> 操作符列名
列名可以出現(xiàn)在操作符的一邊,而常數(shù)或變量出現(xiàn)在操作符的另一邊。如:
Name='張三'
價(jià)格>5000
5000<價(jià)格
Name='張三' and 價(jià)格>5000
如果一個(gè)表達(dá)式不能滿(mǎn)足SARG的形式,那它就無(wú)法限制搜索的范圍了,也就是SQL SERVER必須對(duì)每一行都判斷它是否滿(mǎn)足WHERE子句中的所有條件。所以一個(gè)索引對(duì)于不滿(mǎn)足SARG形式的表達(dá)式來(lái)說(shuō)是無(wú)用的。
介紹完SARG后,我們來(lái)總結(jié)一下使用SARG以及在實(shí)踐中遇到的和某些資料上結(jié)論不同的經(jīng)驗(yàn):
1、Like語(yǔ)句是否屬于SARG取決于所使用的通配符的類(lèi)型
如:name like ‘張%' ,這就屬于SARG
而:name like ‘%張' ,就不屬于SARG。
原因是通配符%在字符串的開(kāi)通使得索引無(wú)法使用。
2、or 會(huì)引起全表掃描
Name='張三' and 價(jià)格>5000 符號(hào)SARG,而:Name='張三' or 價(jià)格>5000 則不符合SARG。使用or會(huì)引起全表掃描。
3、非操作符、函數(shù)引起的不滿(mǎn)足SARG形式的語(yǔ)句
不滿(mǎn)足SARG形式的語(yǔ)句最典型的情況就是包括非操作符的語(yǔ)句,如:NOT、!=、<>、!<、!>、NOT EXISTS、NOT IN、NOT LIKE等,另外還有函數(shù)。下面就是幾個(gè)不滿(mǎn)足SARG形式的例子:
ABS(價(jià)格)<5000
Name like ‘%三'
有些表達(dá)式,如:
WHERE 價(jià)格*2>5000
SQL SERVER也會(huì)認(rèn)為是SARG,SQL SERVER會(huì)將此式轉(zhuǎn)化為:
WHERE 價(jià)格>2500/2
但我們不推薦這樣使用,因?yàn)橛袝r(shí)SQL SERVER不能保證這種轉(zhuǎn)化與原始表達(dá)式是完全等價(jià)的。
4、IN 的作用相當(dāng)與OR
語(yǔ)句:
Select * from table1 where tid in (2,3)

Select * from table1 where tid=2 or tid=3
是一樣的,都會(huì)引起全表掃描,如果tid上有索引,其索引也會(huì)失效。
5、盡量少用NOT
6、exists 和 in 的執(zhí)行效率是一樣的
很多資料上都顯示說(shuō),exists要比in的執(zhí)行效率要高,同時(shí)應(yīng)盡可能的用not exists來(lái)代替not in。但事實(shí)上,我試驗(yàn)了一下,發(fā)現(xiàn)二者無(wú)論是前面帶不帶not,二者之間的執(zhí)行效率都是一樣的。因?yàn)樯婕白硬樵?xún),我們?cè)囼?yàn)這次用SQL SERVER自帶的pubs數(shù)據(jù)庫(kù)。運(yùn)行前我們可以把SQL SERVER的statistics I/O狀態(tài)打開(kāi)。
(1)select title,price from titles where title_id in (select title_id from sales where qty>30)
該句的執(zhí)行結(jié)果為:
表 'sales'。掃描計(jì)數(shù) 18,邏輯讀 56 次,物理讀 0 次,預(yù)讀 0 次。
表 'titles'。掃描計(jì)數(shù) 1,邏輯讀 2 次,物理讀 0 次,預(yù)讀 0 次。
(2)select title,price from titles where exists (select * from sales where sales.title_id=titles.title_id and qty>30)
第二句的執(zhí)行結(jié)果為:
表 'sales'。掃描計(jì)數(shù) 18,邏輯讀 56 次,物理讀 0 次,預(yù)讀 0 次。
表 'titles'。掃描計(jì)數(shù) 1,邏輯讀 2 次,物理讀 0 次,預(yù)讀 0 次。
我們從此可以看到用exists和用in的執(zhí)行效率是一樣的。
7、用函數(shù)charindex()和前面加通配符%的LIKE執(zhí)行效率一樣
前面,我們談到,如果在LIKE前面加上通配符%,那么將會(huì)引起全表掃描,所以其執(zhí)行效率是低下的。但有的資料介紹說(shuō),用函數(shù)charindex()來(lái)代替LIKE速度會(huì)有大的提升,經(jīng)我試驗(yàn),發(fā)現(xiàn)這種說(shuō)明也是錯(cuò)誤的:
select gid,title,fariqi,reader from tgongwen where charindex('刑偵支隊(duì)',reader)>0 and fariqi>'2004-5-5'
用時(shí):7秒,另外:掃描計(jì)數(shù) 4,邏輯讀 7155 次,物理讀 0 次,預(yù)讀 0 次。
select gid,title,fariqi,reader from tgongwen where reader like '%' + '刑偵支隊(duì)' + '%' and fariqi>'2004-5-5'
用時(shí):7秒,另外:掃描計(jì)數(shù) 4,邏輯讀 7155 次,物理讀 0 次,預(yù)讀 0 次。
8、union并不絕對(duì)比or的執(zhí)行效率高
我們前面已經(jīng)談到了在where子句中使用or會(huì)引起全表掃描,一般的,我所見(jiàn)過(guò)的資料都是推薦這里用union來(lái)代替or。事實(shí)證明,這種說(shuō)法對(duì)于大部分都是適用的。
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi='2004-9-16' or gid>9990000
用時(shí):68秒。掃描計(jì)數(shù) 1,邏輯讀 404008 次,物理讀 283 次,預(yù)讀 392163 次。
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi='2004-9-16'
union
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where gid>9990000
用時(shí):9秒。掃描計(jì)數(shù) 8,邏輯讀 67489 次,物理讀 216 次,預(yù)讀 7499 次。
看來(lái),用union在通常情況下比用or的效率要高的多。
但經(jīng)過(guò)試驗(yàn),筆者發(fā)現(xiàn)如果or兩邊的查詢(xún)列是一樣的話(huà),那么用union則反倒和用or的執(zhí)行速度差很多,雖然這里union掃描的是索引,而or掃描的是全表。
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi='2004-9-16' or fariqi='2004-2-5'
用時(shí):6423毫秒。掃描計(jì)數(shù) 2,邏輯讀 14726 次,物理讀 1 次,預(yù)讀 7176 次。
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi='2004-9-16'
union
select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi='2004-2-5'
用時(shí):11640毫秒。掃描計(jì)數(shù) 8,邏輯讀 14806 次,物理讀 108 次,預(yù)讀 1144 次。
9、字段提取要按照“需多少、提多少”的原則,避免“select *”
我們來(lái)做一個(gè)試驗(yàn):
select top 10000 gid,fariqi,reader,title from tgongwen order by gid desc
用時(shí):4673毫秒
select top 10000 gid,fariqi,title from tgongwen order by gid desc
用時(shí):1376毫秒
select top 10000 gid,fariqi from tgongwen order by gid desc
用時(shí):80毫秒
由此看來(lái),我們每少提取一個(gè)字段,數(shù)據(jù)的提取速度就會(huì)有相應(yīng)的提升。提升的速度還要看您舍棄的字段的大小來(lái)判斷。
10、count(*)不比count(字段)慢
某些資料上說(shuō):用*會(huì)統(tǒng)計(jì)所有列,顯然要比一個(gè)世界的列名效率低。這種說(shuō)法其實(shí)是沒(méi)有根據(jù)的。我們來(lái)看:
select count(*) from Tgongwen
用時(shí):1500毫秒
select count(gid) from Tgongwen
用時(shí):1483毫秒
select count(fariqi) from Tgongwen
用時(shí):3140毫秒
select count(title) from Tgongwen
用時(shí):52050毫秒
從以上可以看出,如果用count(*)和用count(主鍵)的速度是相當(dāng)?shù)?,而count(*)卻比其他任何除主鍵以外的字段匯總速度要快,而且字段越長(zhǎng),匯總的速度就越慢。我想,如果用count(*), SQL SERVER可能會(huì)自動(dòng)查找最小字段來(lái)匯總的。當(dāng)然,如果您直接寫(xiě)count(主鍵)將會(huì)來(lái)的更直接些。
11、order by按聚集索引列排序效率最高
我們來(lái)看:(gid是主鍵,fariqi是聚合索引列)
select top 10000 gid,fariqi,reader,title from tgongwen
用時(shí):196 毫秒。 掃描計(jì)數(shù) 1,邏輯讀 289 次,物理讀 1 次,預(yù)讀 1527 次。
select top 10000 gid,fariqi,reader,title from tgongwen order by gid asc
用時(shí):4720毫秒。 掃描計(jì)數(shù) 1,邏輯讀 41956 次,物理讀 0 次,預(yù)讀 1287 次。
select top 10000 gid,fariqi,reader,title from tgongwen order by gid desc
用時(shí):4736毫秒。 掃描計(jì)數(shù) 1,邏輯讀 55350 次,物理讀 10 次,預(yù)讀 775 次。
select top 10000 gid,fariqi,reader,title from tgongwen order by fariqi asc
用時(shí):173毫秒。 掃描計(jì)數(shù) 1,邏輯讀 290 次,物理讀 0 次,預(yù)讀 0 次。
select top 10000 gid,fariqi,reader,title from tgongwen order by fariqi desc
用時(shí):156毫秒。 掃描計(jì)數(shù) 1,邏輯讀 289 次,物理讀 0 次,預(yù)讀 0 次。
從以上我們可以看出,不排序的速度以及邏輯讀次數(shù)都是和“order by 聚集索引列” 的速度是相當(dāng)?shù)模@些都比“order by 非聚集索引列”的查詢(xún)速度是快得多的。
同時(shí),按照某個(gè)字段進(jìn)行排序的時(shí)候,無(wú)論是正序還是倒序,速度是基本相當(dāng)?shù)摹?
12、高效的TOP
事實(shí)上,在查詢(xún)和提取超大容量的數(shù)據(jù)集時(shí),影響數(shù)據(jù)庫(kù)響應(yīng)時(shí)間的最大因素不是數(shù)據(jù)查找,而是物理的I/0操作。如:
select top 10 * from (
select top 10000 gid,fariqi,title from tgongwen
where neibuyonghu='辦公室'
order by gid desc) as a
order by gid asc
這條語(yǔ)句,從理論上講,整條語(yǔ)句的執(zhí)行時(shí)間應(yīng)該比子句的執(zhí)行時(shí)間長(zhǎng),但事實(shí)相反。因?yàn)?,子句?zhí)行后返回的是10000條記錄,而整條語(yǔ)句僅返回10 條語(yǔ)句,所以影響數(shù)據(jù)庫(kù)響應(yīng)時(shí)間最大的因素是物理I/O操作。而限制物理I/O操作此處的最有效方法之一就是使用TOP關(guān)鍵詞了。TOP關(guān)鍵詞是SQL SERVER中經(jīng)過(guò)系統(tǒng)優(yōu)化過(guò)的一個(gè)用來(lái)提取前幾條或前幾個(gè)百分比數(shù)據(jù)的詞。經(jīng)筆者在實(shí)踐中的應(yīng)用,發(fā)現(xiàn)TOP確實(shí)很好用,效率也很高。但這個(gè)詞在另外一個(gè)大型數(shù)據(jù)庫(kù)ORACLE中卻沒(méi)有,這不能說(shuō)不是一個(gè)遺憾,雖然在ORACLE中可以用其他方法(如:rownumber)來(lái)解決。在以后的關(guān)于“實(shí)現(xiàn)千萬(wàn)級(jí)數(shù)據(jù)的分頁(yè)顯示存儲(chǔ)過(guò)程”的討論中,我們就將用到TOP這個(gè)關(guān)鍵詞。
到此為止,我們上面討論了如何實(shí)現(xiàn)從大容量的數(shù)據(jù)庫(kù)中快速地查詢(xún)出您所需要的數(shù)據(jù)方法。當(dāng)然,我們介紹的這些方法都是“軟”方法,在實(shí)踐中,我們還要考慮各種“硬”因素,如:網(wǎng)絡(luò)性能、服務(wù)器的性能、操作系統(tǒng)的性能,甚至網(wǎng)卡、交換機(jī)等。
三、實(shí)現(xiàn)小數(shù)據(jù)量和海量數(shù)據(jù)的通用分頁(yè)顯示存儲(chǔ)過(guò)程
建立一個(gè)web 應(yīng)用,分頁(yè)瀏覽功能必不可少。這個(gè)問(wèn)題是數(shù)據(jù)庫(kù)處理中十分常見(jiàn)的問(wèn)題。經(jīng)典的數(shù)據(jù)分頁(yè)方法是:ADO 紀(jì)錄集分頁(yè)法,也就是利用ADO自帶的分頁(yè)功能(利用游標(biāo))來(lái)實(shí)現(xiàn)分頁(yè)。但這種分頁(yè)方法僅適用于較小數(shù)據(jù)量的情形,因?yàn)橛螛?biāo)本身有缺點(diǎn):游標(biāo)是存放在內(nèi)存中,很費(fèi)內(nèi)存。游標(biāo)一建立,就將相關(guān)的記錄鎖住,直到取消游標(biāo)。游標(biāo)提供了對(duì)特定集合中逐行掃描的手段,一般使用游標(biāo)來(lái)逐行遍歷數(shù)據(jù),根據(jù)取出數(shù)據(jù)條件的不同進(jìn)行不同的操作。而對(duì)于多表和大表中定義的游標(biāo)(大的數(shù)據(jù)集合)循環(huán)很容易使程序進(jìn)入一個(gè)漫長(zhǎng)的等待甚至死機(jī)。
更重要的是,對(duì)于非常大的數(shù)據(jù)模型而言,分頁(yè)檢索時(shí),如果按照傳統(tǒng)的每次都加載整個(gè)數(shù)據(jù)源的方法是非常浪費(fèi)資源的。現(xiàn)在流行的分頁(yè)方法一般是檢索頁(yè)面大小的塊區(qū)的數(shù)據(jù),而非檢索所有的數(shù)據(jù),然后單步執(zhí)行當(dāng)前行。
最早較好地實(shí)現(xiàn)這種根據(jù)頁(yè)面大小和頁(yè)碼來(lái)提取數(shù)據(jù)的方法大概就是“俄羅斯存儲(chǔ)過(guò)程”。這個(gè)存儲(chǔ)過(guò)程用了游標(biāo),由于游標(biāo)的局限性,所以這個(gè)方法并沒(méi)有得到大家的普遍認(rèn)可。
后來(lái),網(wǎng)上有人改造了此存儲(chǔ)過(guò)程,下面的存儲(chǔ)過(guò)程就是結(jié)合我們的辦公自動(dòng)化實(shí)例寫(xiě)的分頁(yè)存儲(chǔ)過(guò)程:
CREATE procedure pagination1
(@pagesize int, --頁(yè)面大小,如每頁(yè)存儲(chǔ)20條記錄
@pageindex int --當(dāng)前頁(yè)碼
)
as
set nocount on
begin
declare @indextable table(id int identity(1,1),nid int) --定義表變量
declare @PageLowerBound int --定義此頁(yè)的底碼
declare @PageUpperBound int --定義此頁(yè)的頂碼
set @PageLowerBound=(@pageindex-1)*@pagesize
set @PageUpperBound=@PageLowerBound+@pagesize
set rowcount @PageUpperBound
insert into @indextable(nid) select gid from TGongwen where fariqi >dateadd(day,-365,getdate()) order by fariqi desc
select O.gid,O.mid,O.title,O.fadanwei,O.fariqi from TGongwen O,@indextable t where O.gid=t.nid
and t.id>@PageLowerBound and t.id<=@PageUpperBound order by t.id
end
set nocount off
以上存儲(chǔ)過(guò)程運(yùn)用了SQL SERVER的最新技術(shù)――表變量。應(yīng)該說(shuō)這個(gè)存儲(chǔ)過(guò)程也是一個(gè)非常優(yōu)秀的分頁(yè)存儲(chǔ)過(guò)程。當(dāng)然,在這個(gè)過(guò)程中,您也可以把其中的表變量寫(xiě)成臨時(shí)表: CREATE TABLE #Temp。但很明顯,在SQL SERVER中,用臨時(shí)表是沒(méi)有用表變量快的。所以筆者剛開(kāi)始使用這個(gè)存儲(chǔ)過(guò)程時(shí),感覺(jué)非常的不錯(cuò),速度也比原來(lái)的ADO的好。但后來(lái),我又發(fā)現(xiàn)了比此方法更好的方法。
筆者曾在網(wǎng)上看到了一篇小短文《從數(shù)據(jù)表中取出第n條到第m條的記錄的方法》,全文如下:
從publish 表中取出第 n 條到第 m 條的記錄:
SELECT TOP m-n+1 *
FROM publish
WHERE (id NOT IN
    (SELECT TOP n-1 id
     FROM publish))
id 為publish 表的關(guān)鍵字
我當(dāng)時(shí)看到這篇文章的時(shí)候,真的是精神為之一振,覺(jué)得思路非常得好。等到后來(lái),我在作辦公自動(dòng)化系統(tǒng)(ASP.NET+ C#+SQL SERVER)的時(shí)候,忽然想起了這篇文章,我想如果把這個(gè)語(yǔ)句改造一下,這就可能是一個(gè)非常好的分頁(yè)存儲(chǔ)過(guò)程。于是我就滿(mǎn)網(wǎng)上找這篇文章,沒(méi)想到,文章還沒(méi)找到,卻找到了一篇根據(jù)此語(yǔ)句寫(xiě)的一個(gè)分頁(yè)存儲(chǔ)過(guò)程,這個(gè)存儲(chǔ)過(guò)程也是目前較為流行的一種分頁(yè)存儲(chǔ)過(guò)程,我很后悔沒(méi)有爭(zhēng)先把這段文字改造成存儲(chǔ)過(guò)程:
CREATE PROCEDURE pagination2
(
@SQL nVARCHAR(4000), --不帶排序語(yǔ)句的SQL語(yǔ)句
@Page int, --頁(yè)碼
@RecsPerPage int, --每頁(yè)容納的記錄數(shù)
@ID VARCHAR(255), --需要排序的不重復(fù)的ID號(hào)
@Sort VARCHAR(255) --排序字段及規(guī)則
)
AS
DECLARE @Str nVARCHAR(4000)
SET @Str='SELECT TOP '+CAST(@RecsPerPage AS VARCHAR(20))+' * FROM ('+@SQL+') T WHERE T.'+@ID+'NOT IN
(SELECT TOP '+CAST((@RecsPerPage*(@Page-1)) AS VARCHAR(20))+' '+@ID+' FROM ('+@SQL+') T9 ORDER BY '+@Sort+') ORDER BY '+@Sort
PRINT @Str
EXEC sp_ExecuteSql @Str
GO
其實(shí),以上語(yǔ)句可以簡(jiǎn)化為:
SELECT TOP 頁(yè)大小 *
FROM Table1
WHERE (ID NOT IN
(SELECT TOP 頁(yè)大小*頁(yè)數(shù) id
FROM 表
ORDER BY id))
ORDER BY ID
但這個(gè)存儲(chǔ)過(guò)程有一個(gè)致命的缺點(diǎn),就是它含有NOT IN字樣。雖然我可以把它改造為:
SELECT TOP 頁(yè)大小 *
FROM Table1
WHERE not exists
(select * from (select top (頁(yè)大小*頁(yè)數(shù)) * from table1 order by id) b where b.id=a.id )
order by id
即,用not exists來(lái)代替not in,但我們前面已經(jīng)談過(guò)了,二者的執(zhí)行效率實(shí)際上是沒(méi)有區(qū)別的。
既便如此,用TOP 結(jié)合NOT IN的這個(gè)方法還是比用游標(biāo)要來(lái)得快一些。
雖然用not exists并不能挽救上個(gè)存儲(chǔ)過(guò)程的效率,但使用SQL SERVER中的TOP關(guān)鍵字卻是一個(gè)非常明智的選擇。因?yàn)榉猪?yè)優(yōu)化的最終目的就是避免產(chǎn)生過(guò)大的記錄集,而我們?cè)谇懊嬉惨呀?jīng)提到了TOP的優(yōu)勢(shì),通過(guò)TOP 即可實(shí)現(xiàn)對(duì)數(shù)據(jù)量的控制。
在分頁(yè)算法中,影響我們查詢(xún)速度的關(guān)鍵因素有兩點(diǎn):TOP和NOT IN。TOP可以提高我們的查詢(xún)速度,而NOT IN會(huì)減慢我們的查詢(xún)速度,所以要提高我們整個(gè)分頁(yè)算法的速度,就要徹底改造NOT IN,同其他方法來(lái)替代它。
我們知道,幾乎任何字段,我們都可以通過(guò)max(字段)或min(字段)來(lái)提取某個(gè)字段中的最大或最小值,所以如果這個(gè)字段不重復(fù),那么就可以利用這些不重復(fù)的字段的max或min作為分水嶺,使其成為分頁(yè)算法中分開(kāi)每頁(yè)的參照物。在這里,我們可以用操作符“>”或“<”號(hào)來(lái)完成這個(gè)使命,使查詢(xún)語(yǔ)句符合SARG形式。如:
Select top 10 * from table1 where id>200
于是就有了如下分頁(yè)方案:
select top 頁(yè)大小 *
from table1
where id>
(select max (id) from
(select top ((頁(yè)碼-1)*頁(yè)大小) id from table1 order by id) as T

order by id
在選擇即不重復(fù)值,又容易分辨大小的列時(shí),我們通常會(huì)選擇主鍵。下表列出了筆者用有著1000萬(wàn)數(shù)據(jù)的辦公自動(dòng)化系統(tǒng)中的表,在以GID(GID是主鍵,但并不是聚集索引。)為排序列、提取gid,fariqi,title字段,分別以第1、10、100、500、1000、1萬(wàn)、10萬(wàn)、25萬(wàn)、 50萬(wàn)頁(yè)為例,測(cè)試以上三種分頁(yè)方案的執(zhí)行速度:(單位:毫秒)
頁(yè) 碼
方案1
方案2
方案3
1
60
30
76
10
46
16
63
100
1076
720
130
500
540
12943
83
1000
17110
470
250
1萬(wàn)
24796
4500
140
10萬(wàn)
38326
42283
1553
25萬(wàn)
28140
128720
2330
50萬(wàn)
121686
127846
7168
從上表中,我們可以看出,三種存儲(chǔ)過(guò)程在執(zhí)行100頁(yè)以下的分頁(yè)命令時(shí),都是可以信任的,速度都很好。但第一種方案在執(zhí)行分頁(yè)1000頁(yè)以上后,速度就降了下來(lái)。第二種方案大約是在執(zhí)行分頁(yè)1萬(wàn)頁(yè)以上后速度開(kāi)始降了下來(lái)。而第三種方案卻始終沒(méi)有大的降勢(shì),后勁仍然很足。
在確定了第三種分頁(yè)方案后,我們可以據(jù)此寫(xiě)一個(gè)存儲(chǔ)過(guò)程。大家知道SQL SERVER的存儲(chǔ)過(guò)程是事先編譯好的SQL語(yǔ)句,它的執(zhí)行效率要比通過(guò)WEB頁(yè)面?zhèn)鱽?lái)的SQL語(yǔ)句的執(zhí)行效率要高。下面的存儲(chǔ)過(guò)程不僅含有分頁(yè)方案,還會(huì)根據(jù)頁(yè)面?zhèn)鱽?lái)的參數(shù)來(lái)確定是否進(jìn)行數(shù)據(jù)總數(shù)統(tǒng)計(jì)。
-- 獲取指定頁(yè)的數(shù)據(jù)
CREATE PROCEDURE pagination3
@tblName varchar(255), -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列
@fldName varchar(255)='', -- 排序的字段名
@PageSize int = 10, -- 頁(yè)尺寸
@PageIndex int = 1, -- 頁(yè)碼
@doCount bit = 0, -- 返回記錄總數(shù), 非 0 值則返回
@OrderType bit = 0, -- 設(shè)置排序類(lèi)型, 非 0 值則降序
@strWhere varchar(1500) = '' -- 查詢(xún)條件 (注意: 不要加 where)
AS
declare @strSQL varchar(5000) -- 主語(yǔ)句
declare @strTmp varchar(110) -- 臨時(shí)變量
declare @strOrder varchar(400) -- 排序類(lèi)型
if @doCount != 0
begin
if @strWhere !=''
set @strSQL = "select count(*) as Total from [" + @tblName + "] where "+@strWhere
else
set @strSQL = "select count(*) as Total from [" + @tblName + "]"
end 
--以上代碼的意思是如果@doCount傳遞過(guò)來(lái)的不是0,就執(zhí)行總數(shù)統(tǒng)計(jì)。以下的所有代碼都是@doCount為0的情況
else
begin
if @OrderType != 0
begin
set @strTmp = "<(select min"
set @strOrder = " order by [" + @fldName +"] desc"
--如果@OrderType不是0,就執(zhí)行降序,這句很重要!
end
else
begin
set @strTmp = ">(select max"
set @strOrder = " order by [" + @fldName +"] asc"
end
if @PageIndex = 1
begin
if @strWhere != '' 
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from [" + @tblName + "] where " + @strWhere + " " + @strOrder
else
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["+ @tblName + "] "+ @strOrder
--如果是第一頁(yè)就執(zhí)行以上代碼,這樣會(huì)加快執(zhí)行速度
end
else
begin
--以下代碼賦予了@strSQL以真正執(zhí)行的SQL代碼
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["+ @fldName + "] from [" + @tblName + "]" + @strOrder + ") as tblTmp)"+ @strOrder
if @strWhere != ''
set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["
+ @tblName + "] where [" + @fldName + "]" + @strTmp + "(["
+ @fldName + "]) from (select top " + str((@PageIndex-1)*@PageSize) + " ["
+ @fldName + "] from [" + @tblName + "] where " + @strWhere + " "
+ @strOrder + ") as tblTmp) and " + @strWhere + " " + @strOrder
end
end 
exec (@strSQL)
GO
上面的這個(gè)存儲(chǔ)過(guò)程是一個(gè)通用的存儲(chǔ)過(guò)程,其注釋已寫(xiě)在其中了。
在大數(shù)據(jù)量的情況下,特別是在查詢(xún)最后幾頁(yè)的時(shí)候,查詢(xún)時(shí)間一般不會(huì)超過(guò)9秒;而用其他存儲(chǔ)過(guò)程,在實(shí)踐中就會(huì)導(dǎo)致超時(shí),所以這個(gè)存儲(chǔ)過(guò)程非常適用于大容量數(shù)據(jù)庫(kù)的查詢(xún)。
筆者希望能夠通過(guò)對(duì)以上存儲(chǔ)過(guò)程的解析,能給大家?guī)?lái)一定的啟示,并給工作帶來(lái)一定的效率提升,同時(shí)希望同行提出更優(yōu)秀的實(shí)時(shí)數(shù)據(jù)分頁(yè)算法。
四、聚集索引的重要性和如何選擇聚集索引
在上一節(jié)的標(biāo)題中,筆者寫(xiě)的是:實(shí)現(xiàn)小數(shù)據(jù)量和海量數(shù)據(jù)的通用分頁(yè)顯示存儲(chǔ)過(guò)程。這是因?yàn)樵趯⒈敬鎯?chǔ)過(guò)程應(yīng)用于“辦公自動(dòng)化”系統(tǒng)的實(shí)踐中時(shí),筆者發(fā)現(xiàn)這第三種存儲(chǔ)過(guò)程在小數(shù)據(jù)量的情況下,有如下現(xiàn)象:
1、分頁(yè)速度一般維持在1秒和3秒之間。
2、在查詢(xún)最后一頁(yè)時(shí),速度一般為5秒至8秒,哪怕分頁(yè)總數(shù)只有3頁(yè)或30萬(wàn)頁(yè)。
雖然在超大容量情況下,這個(gè)分頁(yè)的實(shí)現(xiàn)過(guò)程是很快的,但在分前幾頁(yè)時(shí),這個(gè)1-3秒的速度比起第一種甚至沒(méi)有經(jīng)過(guò)優(yōu)化的分頁(yè)方法速度還要慢,借用戶(hù)的話(huà)說(shuō)就是“還沒(méi)有ACCESS數(shù)據(jù)庫(kù)速度快”,這個(gè)認(rèn)識(shí)足以導(dǎo)致用戶(hù)放棄使用您開(kāi)發(fā)的系統(tǒng)。
筆者就此分析了一下,原來(lái)產(chǎn)生這種現(xiàn)象的癥結(jié)是如此的簡(jiǎn)單,但又如此的重要:排序的字段不是聚集索引!
本篇文章的題目是:“查詢(xún)優(yōu)化及分頁(yè)算法方案”。筆者只所以把“查詢(xún)優(yōu)化”和“分頁(yè)算法”這兩個(gè)聯(lián)系不是很大的論題放在一起,就是因?yàn)槎叨夹枰粋€(gè)非常重要的東西――聚集索引。
在前面的討論中我們已經(jīng)提到了,聚集索引有兩個(gè)最大的優(yōu)勢(shì):
1、以最快的速度縮小查詢(xún)范圍。
2、以最快的速度進(jìn)行字段排序。
第1條多用在查詢(xún)優(yōu)化時(shí),而第2條多用在進(jìn)行分頁(yè)時(shí)的數(shù)據(jù)排序。
而聚集索引在每個(gè)表內(nèi)又只能建立一個(gè),這使得聚集索引顯得更加的重要。聚集索引的挑選可以說(shuō)是實(shí)現(xiàn)“查詢(xún)優(yōu)化”和“高效分頁(yè)”的最關(guān)鍵因素。
但要既使聚集索引列既符合查詢(xún)列的需要,又符合排序列的需要,這通常是一個(gè)矛盾。
筆者前面“索引”的討論中,將fariqi,即用戶(hù)發(fā)文日期作為了聚集索引的起始列,日期的精確度為“日”。這種作法的優(yōu)點(diǎn),前面已經(jīng)提到了,在進(jìn)行劃時(shí)間段的快速查詢(xún)中,比用ID主鍵列有很大的優(yōu)勢(shì)。
但在分頁(yè)時(shí),由于這個(gè)聚集索引列存在著重復(fù)記錄,所以無(wú)法使用max或min來(lái)最為分頁(yè)的參照物,進(jìn)而無(wú)法實(shí)現(xiàn)更為高效的排序。而如果將ID主鍵列作為聚集索引,那么聚集索引除了用以排序之外,沒(méi)有任何用處,實(shí)際上是浪費(fèi)了聚集索引這個(gè)寶貴的資源。
為解決這個(gè)矛盾,筆者后來(lái)又添加了一個(gè)日期列,其默認(rèn)值為getdate()。用戶(hù)在寫(xiě)入記錄時(shí),這個(gè)列自動(dòng)寫(xiě)入當(dāng)時(shí)的時(shí)間,時(shí)間精確到毫秒。即使這樣,為了避免可能性很小的重合,還要在此列上創(chuàng)建UNIQUE約束。將此日期列作為聚集索引列。
有了這個(gè)時(shí)間型聚集索引列之后,用戶(hù)就既可以用這個(gè)列查找用戶(hù)在插入數(shù)據(jù)時(shí)的某個(gè)時(shí)間段的查詢(xún),又可以作為唯一列來(lái)實(shí)現(xiàn)max或min,成為分頁(yè)算法的參照物。
經(jīng)過(guò)這樣的優(yōu)化,筆者發(fā)現(xiàn),無(wú)論是大數(shù)據(jù)量的情況下還是小數(shù)據(jù)量的情況下,分頁(yè)速度一般都是幾十毫秒,甚至0毫秒。而用日期段縮小范圍的查詢(xún)速度比原來(lái)也沒(méi)有任何遲鈍。
聚集索引是如此的重要和珍貴,所以筆者總結(jié)了一下,一定要將聚集索引建立在:
1、您最頻繁使用的、用以縮小查詢(xún)范圍的字段上;
2、您最頻繁使用的、需要排序的字段上。
結(jié)束語(yǔ):
本篇文章匯集了筆者近段在使用數(shù)據(jù)庫(kù)方面的心得,是在做“辦公自動(dòng)化”系統(tǒng)時(shí)實(shí)踐經(jīng)驗(yàn)的積累。希望這篇文章不僅能夠給大家的工作帶來(lái)一定的幫助,也希望能讓大家能夠體會(huì)到分析問(wèn)題的方法;最重要的是,希望這篇文章能夠拋磚引玉,掀起大家的學(xué)習(xí)和討論的興趣,以共同促進(jìn),共同為公安科技強(qiáng)警事業(yè)和金盾工程做出自己最大的努力。
最后需要說(shuō)明的是,在試驗(yàn)中,我發(fā)現(xiàn)用戶(hù)在進(jìn)行大數(shù)據(jù)量查詢(xún)的時(shí)候,對(duì)數(shù)據(jù)庫(kù)速度影響最大的不是內(nèi)存大小,而是CPU。在我的P4 2.4機(jī)器上試驗(yàn)的時(shí)候,查看“資源管理器”,CPU經(jīng)常出現(xiàn)持續(xù)到100%的現(xiàn)象,而內(nèi)存用量卻并沒(méi)有改變或者說(shuō)沒(méi)有大的改變。即使在我們的HP ML 350 G3服務(wù)器上試驗(yàn)時(shí),CPU峰值也能達(dá)到90%,一般持續(xù)在70%左右。
本文的試驗(yàn)數(shù)據(jù)都是來(lái)自我們的HP ML 350服務(wù)器。服務(wù)器配置:雙Inter Xeon 超線(xiàn)程 CPU 2.4G,內(nèi)存1G,操作系統(tǒng)Windows Server 2003 Enterprise Edition,數(shù)據(jù)庫(kù)SQL Server 2000 SP3。 

相關(guān)文章

最新評(píng)論

色97视频在线播放| 女人精品内射国产99| 成人sm视频在线观看| 成人激情文学网人妻| 亚洲伊人av天堂有码在线| 在线网站你懂得老司机| 国产精品国色综合久久 | 一区二区三区四区中文| 亚洲av第国产精品| 2021年国产精品自拍| 自拍偷拍一区二区三区图片| 免费黄页网站4188| 中文字幕在线免费第一页| 国产在线自在拍91国语自产精品| 2020久久躁狠狠躁夜夜躁 | 亚洲精品国产久久久久久| 免费手机黄页网址大全| 亚洲1卡2卡三卡4卡在线观看 | 全国亚洲男人的天堂| 好吊操视频这里只有精品| 看一级特黄a大片日本片黑人| 在线观看av2025| 亚洲va国产va欧美va在线| av高潮迭起在线观看| 中国黄色av一级片| 天天插天天色天天日| 国产精彩对白一区二区三区| 国产97视频在线精品| 97精品人妻一区二区三区精品| 欧美精产国品一二三区| 日本少妇人妻xxxxx18| 青青青激情在线观看视频| 一色桃子久久精品亚洲| 欧美香蕉人妻精品一区二区| 精品区一区二区三区四区人妻 | 欧美在线精品一区二区三区视频 | 999久久久久999| 亚洲成人熟妇一区二区三区 | 黄色资源视频网站日韩| 蜜桃视频17c在线一区二区| 亚洲av午夜免费观看| 国产夫妻视频在线观看免费| 性欧美激情久久久久久久| 巨乳人妻日下部加奈被邻居中出 | 欧美viboss性丰满| 中文字幕免费在线免费| 99久久中文字幕一本人| 老司机深夜免费福利视频在线观看| 老鸭窝日韩精品视频观看| 国产日本精品久久久久久久| 国产一区av澳门在线观看| 日韩二区视频一线天婷婷五| 欧美日韩熟女一区二区三区| 成人av在线资源网站| 久久久精品999精品日本| 中出中文字幕在线观看 | av乱码一区二区三区| 北条麻妃av在线免费观看| 亚洲一区二区三区偷拍女厕91| 国产午夜无码福利在线看| 亚洲 欧美 精品 激情 偷拍| 日日夜夜大香蕉伊人| 午夜精品一区二区三区4| 亚洲青青操骚货在线视频| 国产精品国产三级国产午| 色哟哟在线网站入口| 亚洲成人情色电影在线观看| 少妇一区二区三区久久久| 岛国一区二区三区视频在线| av老司机亚洲一区二区| 美女大bxxxx内射| 亚洲免费在线视频网站| 亚洲1069综合男同| 精品高跟鞋丝袜一区二区| 天天插天天色天天日| 六月婷婷激情一区二区三区| 视频二区在线视频观看| 日本午夜福利免费视频| 国产日韩欧美美利坚蜜臀懂色| 超碰在线观看免费在线观看| 成人久久精品一区二区三区| 男女啪啪视频免费在线观看| 粉嫩小穴流水视频在线观看| 天天日夜夜干天天操| 天天操夜夜骑日日摸| 日韩成人综艺在线播放| 国产精品熟女久久久久浪潮| 午夜毛片不卡在线看| 亚洲色偷偷综合亚洲AV伊人| 亚洲精品ww久久久久久| 亚洲精品国品乱码久久久久| 亚洲最大黄 嗯色 操 啊| 97青青青手机在线视频| 欧美伊人久久大香线蕉综合| 最新91九色国产在线观看| 中文乱理伦片在线观看| 香蕉91一区二区三区| 青青操免费日综合视频观看| 日韩精品一区二区三区在线播放| 日韩av大胆在线观看| 污污小视频91在线观看| 超级碰碰在线视频免费观看| 亚洲综合另类欧美久久| 2019av在线视频| 蜜桃臀av蜜桃臀av| 超鹏97历史在线观看| 红杏久久av人妻一区| 国产精品久久久久网| 中文字幕一区二 区二三区四区 | 亚洲一级美女啪啪啪| 亚洲视频在线观看高清| 日韩北条麻妃一区在线| 年轻的人妻被夫上司侵犯| 91极品新人『兔兔』精品新作| 适合午夜一个人看的视频| 亚洲色偷偷综合亚洲AV伊人| 天天干狠狠干天天操| 成年人中文字幕在线观看| 欧美日韩人妻久久精品高清国产| 日本一区精品视频在线观看| 三上悠亚和黑人665番号| 99精品一区二区三区的区| 欧洲欧美日韩国产在线| 国产亚洲视频在线观看| 欧美精品免费aaaaaa| 亚洲一区自拍高清免费视频| 免费看国产又粗又猛又爽又黄视频| 亚洲一区二区三区久久受| 日本av在线一区二区三区| 精品视频一区二区三区四区五区| 欧美精产国品一二三区| 91福利视频免费在线观看| 欧美一级色视频美日韩| gav成人免费播放| 又粗又硬又猛又黄免费30| av网站色偷偷婷婷网男人的天堂| 黄色大片免费观看网站| 国产va精品免费观看| 丝袜肉丝一区二区三区四区在线| 99热久久极品热亚洲| 欧美一区二区中文字幕电影 | 欧美黑人性猛交xxxxⅹooo| 免费看国产又粗又猛又爽又黄视频 | 100%美女蜜桃视频| 国产精品久久9999| 青草亚洲视频在线观看| 国产一区二区欧美三区 | 超级福利视频在线观看| 亚洲午夜电影在线观看| 精品一区二区三区三区色爱| 精品老妇女久久9g国产| 91麻豆精品传媒国产黄色片| 18禁污污污app下载| 最新91九色国产在线观看| 国产精品成久久久久三级蜜臀av | 天天日天天做天天日天天做| 自拍偷拍日韩欧美亚洲| 中文字幕欧美日韩射射一| 日比视频老公慢点好舒服啊| 欧美一级片免费在线成人观看| 在线免费观看国产精品黄色| 一区二区视频在线观看免费观看| 国产真实乱子伦a视频| 人妻凌辱欧美丰满熟妇| 91大神福利视频网| 国产精品国产三级国产午| 国产精品视频欧美一区二区| 国产亚洲四十路五十路| 日韩成人性色生活片| 福利国产视频在线观看| 亚洲另类伦春色综合小| 精品久久久久久久久久中文蒉| 2012中文字幕在线高清| 最新国产精品网址在线观看| 经典亚洲伊人第一页| 一区二区三区av高清免费| 久久久精品欧洲亚洲av| 80电影天堂网官网| 男生舔女生逼逼视频| 日本高清成人一区二区三区| asmr福利视频在线观看| 偷拍自拍福利视频在线观看| 韩国一级特黄大片做受| 亚洲午夜伦理视频在线| 四川乱子伦视频国产vip| 欧美专区第八页一区在线播放| 成人动漫大肉棒插进去视频| 亚洲 清纯 国产com| 欧美精品免费aaaaaa| 啪啪啪操人视频在线播放| 精品乱子伦一区二区三区免费播| 美女福利写真在线观看视频| 狠狠嗨日韩综合久久| 亚洲免费av在线视频| 人人妻人人澡欧美91精品| 大香蕉日本伊人中文在线| 黄色视频在线观看高清无码| 福利片区一区二体验区| 最新97国产在线视频| 免费观看理论片完整版| av在线免费观看亚洲天堂| 日韩中文字幕精品淫| 成人影片高清在线观看| 日韩欧美制服诱惑一区在线| 精品成人午夜免费看| 精品久久久久久高潮| 国产黄色a级三级三级三级| 人妻熟女中文字幕aⅴ在线| 老司机午夜精品视频资源| 国产精品视频男人的天堂| 欧美另类z0z变态| 国产精品成久久久久三级蜜臀av | 中国熟女@视频91| 91小伙伴中女熟女高潮| 黄色片一级美女黄色片| 亚洲公开视频在线观看| 色天天天天射天天舔| 日本成人一区二区不卡免费在线| 亚洲国产香蕉视频在线播放| 91在线视频在线精品3| 色哟哟在线网站入口| 99热99re在线播放| 在线国产精品一区二区三区| 男女啪啪视频免费在线观看| 天天日夜夜操天天摸| 搞黄色在线免费观看| 成人伊人精品色xxxx视频| 成人免费毛片aaaa| 日韩av大胆在线观看| 国产精品手机在线看片| 精品久久久久久久久久久a√国产| 国产高清精品一区二区三区| wwwxxx一级黄色片| 亚洲中文字幕综合小综合| 国产露脸对白在线观看| 超碰97免费人妻麻豆| 亚洲av自拍天堂网| 黄色片年轻人在线观看| v888av在线观看视频| 婷婷综合蜜桃av在线| 日本午夜爽爽爽爽爽视频在线观看 | 国产又色又刺激在线视频| 午夜精品福利91av| 亚洲免费av在线视频| 国产视频精品资源网站| 狠狠躁夜夜躁人人爽天天久天啪| 天天干天天操天天玩天天射| 天天插天天色天天日| 亚洲人妻国产精品综合| 久久精品亚洲国产av香蕉| 2021久久免费视频| 天天日天天透天天操| 顶级尤物粉嫩小尤物网站| 大鸡八强奸视频在线观看| 少妇ww搡性bbb91| 国产美女午夜福利久久| 中文字幕av一区在线观看 | 亚洲国产精品美女在线观看| 少妇一区二区三区久久久| 五十路熟女av天堂| 在线免费观看国产精品黄色| 成人24小时免费视频| 1024久久国产精品| 中文字幕 码 在线视频| 天天干夜夜操天天舔| 精品亚洲国产中文自在线| 国产a级毛久久久久精品| 最新97国产在线视频| 青青青视频手机在线观看| 天天干夜夜操天天舔| 在线观看的黄色免费网站| 91快播视频在线观看| 国产大学生援交正在播放| 亚洲日产av一区二区在线| 少妇人妻真实精品视频| 日本免费视频午夜福利视频| 亚洲av男人天堂久久| 第一福利视频在线观看| 一区二区熟女人妻视频| 大胸性感美女羞爽操逼毛片| 日本脱亚入欧是指什么| 91国产在线视频免费观看| 精品一区二区三区午夜| 日本韩国亚洲综合日韩欧美国产| 欧美成人综合视频一区二区| 特级无码毛片免费视频播放| 国产女人叫床高潮大片视频| 早川濑里奈av黑人番号| 亚洲欧美在线视频第一页| 91av中文视频在线| 国产精品久久综合久久| 在线视频免费观看网| 三上悠亚和黑人665番号| 日本三极片视频网站观看| 55夜色66夜色国产精品站| 精品国产在线手机在线| 激情色图一区二区三区| 欧美日本国产自视大全| 天天干天天操天天扣| 999热精品视频在线| 欧美另类重口味极品在线观看| 日韩在线视频观看有码在线| 99热久久极品热亚洲| 亚洲成人激情视频免费观看了| 99热这里只有国产精品6| 国产欧美精品一区二区高清 | 大香蕉大香蕉在线有码 av| 久久艹在线观看视频| 97超碰国语国产97超碰| 蜜臀av久久久久久久| 快点插进来操我逼啊视频| huangse网站在线观看| 国产中文精品在线观看| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 亚洲最大黄了色网站| 亚洲av日韩高清hd| 国产一区二区三免费视频| 成年人中文字幕在线观看| 青青草人人妻人人妻| 五十路老熟女码av| 不卡精品视频在线观看| 国产成人午夜精品福利| 日本特级片中文字幕| 黄色片黄色片wyaa| 国产白袜脚足J棉袜在线观看| 国产黄色片在线收看| 午夜精品一区二区三区更新| 国产男女视频在线播放| 亚洲 国产 成人 在线| 日本中文字幕一二区视频| 亚洲另类综合一区小说| 人人妻人人澡人人爽人人dvl| 九色精品视频在线播放| 女同性ⅹxx女同hd| 美女少妇亚洲精选av| 国产精品3p和黑人大战| 日本最新一二三区不卡在线| 日韩成人免费电影二区| 少妇被强干到高潮视频在线观看| 日本女人一级免费片| 天天日天天透天天操| 玩弄人妻熟妇性色av少妇| 国产成人午夜精品福利| 在线观看国产免费麻豆| 欧美xxx成人在线| 亚洲变态另类色图天堂网| 首之国产AV医生和护士小芳| 337p日本大胆欧美人| 五十路息与子猛烈交尾视频| 自拍偷区二区三区麻豆| 2019av在线视频| 亚洲男人在线天堂网| 国产成人精品久久二区91| 日本午夜爽爽爽爽爽视频在线观看 | 男人靠女人的逼视频| 日韩a级精品一区二区| 自拍偷拍,中文字幕| 不卡一区一区三区在线| 黄色片黄色片wyaa| 色哟哟在线网站入口| 黄色片黄色片wyaa| 丝袜美腿欧美另类 中文字幕| 久久这里只有精品热视频| av手机在线免费观看日韩av| 日本av熟女在线视频| 国产av国片精品一区二区| 91av精品视频在线| 蜜桃久久久久久久人妻| 又粗又长 明星操逼小视频 | 综合激情网激情五月天| 成人24小时免费视频| av破解版在线观看| 国产一区二区三免费视频| 精品欧美一区二区vr在线观看| gay gay男男瑟瑟在线网站| 日本一二三中文字幕| 又粗又长 明星操逼小视频| 国产极品美女久久久久久| 2022国产精品视频| 午夜av一区二区三区 | 国产精品国产三级国产午| 欧美viboss性丰满| 被大鸡吧操的好舒服视频免费| 91福利在线视频免费观看| 人妻丰满熟妇综合网| 日本性感美女写真视频| 天天干天天爱天天色| 丰满熟女午夜福利视频| 久久机热/这里只有| 夫妻在线观看视频91| 100%美女蜜桃视频| aaa久久久久久久久| 人妻久久久精品69系列| 青青青青青手机视频| 男生舔女生逼逼的视频| 久久精品亚洲成在人线a| 天天做天天干天天操天天射| 亚洲av琪琪男人的天堂| av视网站在线观看| 色呦呦视频在线观看视频| 不卡一不卡二不卡三| 青青操免费日综合视频观看| 91九色porny国产在线| 综合一区二区三区蜜臀| 亚洲另类综合一区小说| 天天干天天爱天天色| 老司机深夜免费福利视频在线观看| 国产日韩精品免费在线| 夏目彩春在线中文字幕| 国产亚州色婷婷久久99精品| 色爱av一区二区三区| 中文亚洲欧美日韩无线码| 91免费观看在线网站| 天天夜天天日天天日| 777奇米久久精品一区| 熟女国产一区亚洲中文字幕| 偷拍自拍视频图片免费| 亚洲av日韩av第一区二区三区| 国产精品黄片免费在线观看| 中文人妻AV久久人妻水| 中文字幕第1页av一天堂网| 亚洲精品国产在线电影| 久久这里有免费精品| 亚洲欧美另类手机在线 | 日韩欧美制服诱惑一区在线| 日韩av中文在线免费观看| 亚洲午夜电影之麻豆| 久久这里有免费精品| 久草福利电影在线观看| 精品一区二区亚洲欧美| 天天射,天天操,天天说| 午夜精品久久久久麻豆影视| 青青青青在线视频免费观看| 亚洲一区二区三区uij| 中文字幕在线免费第一页| 一区二区视频视频视频| 日韩亚国产欧美三级涩爱| 少妇露脸深喉口爆吞精| 亚洲精品久久综合久| 精品高跟鞋丝袜一区二区| 欧美日韩v中文在线| 久久麻豆亚洲精品av| 99re6热在线精品| 欧美天堂av无线av欧美| 一区二区三区激情在线| 午夜频道成人在线91| 干逼又爽又黄又免费的视频| 久久久久久9999久久久久| 91成人在线观看免费视频| 青青草成人福利电影| 在线网站你懂得老司机| 日本中文字幕一二区视频| 午夜在线观看岛国av,com| 青青青青青免费视频| 又粗又长 明星操逼小视频| 日韩在线视频观看有码在线| 专门看国产熟妇的网站| 色综合久久五月色婷婷综合| 成人伊人精品色xxxx视频| 日韩成人免费电影二区| 国产精品3p和黑人大战| 久草视频中文字幕在线观看| 亚洲精品成人网久久久久久小说 | 亚洲高清免费在线观看视频| 亚洲va欧美va人人爽3p| 色综合久久五月色婷婷综合| 91综合久久亚洲综合| 任我爽精品视频在线播放| 男生用鸡操女生视频动漫| 2021国产一区二区| 在线免费观看日本片| 欧洲国产成人精品91铁牛tv| 99热久久极品热亚洲| 天堂资源网av中文字幕| 亚洲 欧美 精品 激情 偷拍 | 玖玖一区二区在线观看| 久久国产精品精品美女| 日本18禁久久久久久| 亚洲精品国偷自产在线观看蜜桃| 国产欧美精品一区二区高清| 国产中文精品在线观看| 国产成人精品福利短视频| 亚洲一区二区三区av网站| 好吊视频—区二区三区| 亚洲激情偷拍一区二区| 午夜在线观看岛国av,com| 欧美日韩不卡一区不区二区| 美女福利写真在线观看视频| 国产熟妇乱妇熟色T区| 综合页自拍视频在线播放| 日韩一区二区电国产精品| 国产视频网站国产视频| 午夜免费体验区在线观看| 一个色综合男人天堂| 2020中文字幕在线播放| 成年人黄色片免费网站| 男人和女人激情视频| 人妻少妇一区二区三区蜜桃| www骚国产精品视频| 韩国三级aaaaa高清视频| 任我爽精品视频在线播放| 九九视频在线精品播放| 色婷婷综合激情五月免费观看| 偷拍3456eee| 亚洲国产成人在线一区| 中文字幕高清免费在线人妻 | 亚洲色偷偷综合亚洲AV伊人| 亚洲成人av一区久久| 青青青青青手机视频| 91国内精品久久久久精品一| 熟女视频一区,二区,三区 | 91国产资源在线视频| 老司机你懂得福利视频| 免费成人va在线观看| 午夜精品福利91av| 日本在线一区二区不卡视频| 2022中文字幕在线| 精品欧美一区二区vr在线观看| 97国产在线观看高清| 久久这里只有精品热视频 | 动漫精品视频在线观看| 免费观看污视频网站| 欧美日韩中文字幕欧美| 在线免费观看欧美小视频| www日韩毛片av| 日韩欧美国产精品91| 1769国产精品视频免费观看| 精品美女福利在线观看| 天天躁日日躁狠狠躁躁欧美av| 婷婷综合亚洲爱久久| 日韩一个色综合导航| 午夜美女少妇福利视频| 无套猛戳丰满少妇人妻| 亚洲高清一区二区三区视频在线| 日韩二区视频一线天婷婷五| 日本男女操逼视频免费看| 免费观看成年人视频在线观看| 亚洲av日韩精品久久久久久hd| 2021久久免费视频| 91欧美在线免费观看| 在线视频免费观看网| 免费av岛国天堂网站| 国产久久久精品毛片| 日本18禁久久久久久| 中国黄色av一级片| 国产又大又黄免费观看| 国产一区二区久久久裸臀| 青青青青青操视频在线观看| 人妻丰满熟妇综合网| 日本三极片中文字幕| 国产成人无码精品久久久电影| 欧美第一页在线免费观看视频| 日本免费视频午夜福利视频| 国产精品亚洲在线观看| 视频二区在线视频观看| 91麻豆精品久久久久| 直接能看的国产av| 五十路在线观看完整版| 亚洲欧美成人综合视频| 日本免费午夜视频网站| 亚洲精品亚洲人成在线导航| 中文人妻AV久久人妻水| 中文字幕第三十八页久久 | 日噜噜噜夜夜噜噜噜天天噜噜噜| 91麻豆精品久久久久| 美女小视频网站在线| 99re国产在线精品| 国产91嫩草久久成人在线视频| 国产黄色大片在线免费播放| 风流唐伯虎电视剧在线观看| 一区二区三区四区视频在线播放| 91人妻精品一区二区在线看| 亚洲国产精品黑丝美女| 91精品资源免费观看| 亚洲伊人av天堂有码在线| 在线成人日韩av电影| 欧美偷拍亚洲一区二区| 东京干手机福利视频| 嫩草aⅴ一区二区三区| 亚洲护士一区二区三区| 日日爽天天干夜夜操| 国产熟妇人妻ⅹxxxx麻豆| 亚洲一级特黄特黄黄色录像片| 中文字幕免费福利视频6| 国产 在线 免费 精品| 亚洲国产香蕉视频在线播放| 91‖亚洲‖国产熟女| 成人国产激情自拍三区| 9l人妻人人爽人人爽| 77久久久久国产精产品| 精品日产卡一卡二卡国色天香| 国产亚洲成人免费在线观看 | 国产高清女主播在线| 亚洲人妻30pwc| 国产高清精品一区二区三区| 亚洲午夜电影在线观看| 视频一区 二区 三区 综合| 日日夜夜狠狠干视频| 日韩精品中文字幕播放| 久久www免费人成一看片| 亚洲av极品精品在线观看| 青青青国产免费视频| 91久久综合男人天堂| 女警官打开双腿沦为性奴| 国产实拍勾搭女技师av在线| 欲乱人妻少妇在线视频裸| 日本乱人一区二区三区| 日韩黄色片在线观看网站| 精品区一区二区三区四区人妻 | 91国产资源在线视频| 97超碰最新免费在线观看| 国产精品久久久久久久精品视频| 午夜在线观看一区视频| 精品91自产拍在线观看一区| 中文字幕熟女人妻久久久| 性欧美日本大妈母与子| 国产午夜亚洲精品麻豆| 久草视频首页在线观看| 五月天色婷婷在线观看视频免费| 内射久久久久综合网| 日本少妇人妻xxxxx18| 久久久人妻一区二区| 18禁网站一区二区三区四区| 人妻素人精油按摩中出| 一二三中文乱码亚洲乱码one| 337p日本大胆欧美人| 插小穴高清无码中文字幕| 天天日天天干天天搡| 国产日韩欧美美利坚蜜臀懂色| 亚洲av成人网在线观看| 久久久久久性虐视频| 亚洲av男人的天堂你懂的| 午夜精品久久久久久99热| av完全免费在线观看av| 日本性感美女写真视频| 日本一二三区不卡无| 国产精彩福利精品视频| 成年人黄色片免费网站| 欧美精品激情在线最新观看视频 | 黄色在线观看免费观看在线| 北条麻妃肉色丝袜视频| 天天射夜夜操狠狠干| 天天色天天操天天透| 中国老熟女偷拍第一页| 日韩欧美一级aa大片| 蜜桃专区一区二区在线观看| 性欧美日本大妈母与子| 青青青aaaa免费| 密臀av一区在线观看| 国产熟妇人妻ⅹxxxx麻豆| 国产日韩av一区二区在线| 91 亚洲视频在线观看| 中文字幕av第1页中文字幕| 视频在线亚洲一区二区| 日韩欧美一级aa大片| 人人人妻人人澡人人| 五月天色婷婷在线观看视频免费| 国产精品黄色的av| 国产视频网站国产视频| 天堂av狠狠操蜜桃| 老司机福利精品免费视频一区二区 | 人人妻人人爱人人草| 青娱乐在线免费视频盛宴| 欧美亚洲一二三区蜜臀| 欧美一区二区三区高清不卡tv| 91麻豆精品秘密入口在线观看| 日韩午夜福利精品试看| 国产午夜亚洲精品麻豆| 中文乱理伦片在线观看| 午夜大尺度无码福利视频| 女生被男生插的视频网站| 国产清纯美女al在线| 亚洲高清一区二区三区视频在线 | 日韩美在线观看视频黄| 中文字幕乱码人妻电影| 欧美一区二区三区乱码在线播放| 国产妇女自拍区在线观看| 日韩伦理短片在线观看| aiss午夜免费视频| 黄片大全在线观看观看| 久久久精品999精品日本 | 国产卡一卡二卡三乱码手机| 久久久麻豆精亚洲av麻花| www天堂在线久久| 日本熟妇色熟妇在线观看| 婷婷久久久久深爱网| 久久久久久cao我的性感人妻 | 国产精品久久久久久美女校花| 亚洲第一黄色在线观看| 五十路av熟女松本翔子| 亚洲国产精品中文字幕网站| 欧美成人小视频在线免费看| 亚洲国产第一页在线观看| 国产成人综合一区2区| 精品成人啪啪18免费蜜臀| 欧亚乱色一区二区三区| 国产精品欧美日韩区二区| 精品国产污污免费网站入口自| 免费一级特黄特色大片在线观看| 人人妻人人澡人人爽人人dvl| 内射久久久久综合网| 青青青aaaa免费| 在线成人日韩av电影| 日本性感美女写真视频| 天天日天天操天天摸天天舔 | 中文字幕日韩精品日本| 福利视频广场一区二区| 亚洲欧美国产综合777| 国产 在线 免费 精品| 免费在线黄色观看网站| 亚洲无码一区在线影院| 大香蕉大香蕉在线看| 中文字幕av熟女人妻| 国产精品精品精品999| 污污小视频91在线观看| 亚洲视频在线视频看视频在线| 9l人妻人人爽人人爽| 日本午夜福利免费视频| 日本少妇高清视频xxxxx| 午夜影院在线观看视频羞羞羞| av在线播放国产不卡| 深田咏美亚洲一区二区| 中文字幕最新久久久| 51精品视频免费在线观看| 中文字幕在线观看极品视频| 亚洲变态另类色图天堂网| 91国内精品久久久久精品一| 国产视频网站国产视频| 93人妻人人揉人人澡人人| 国产精品三级三级三级| 夏目彩春在线中文字幕| 青娱乐蜜桃臀av色| av俺也去在线播放| 18禁美女羞羞免费网站| 在线免费观看国产精品黄色| 国产日韩一区二区在线看 | 五月婷婷在线观看视频免费| sspd152中文字幕在线| 扒开让我视频在线观看| 亚洲熟妇无码一区二区三区| 国内资源最丰富的网站| 久草视频在线看免费| 最新中文字幕免费视频| 特大黑人巨大xxxx| 欧美一区二区三区乱码在线播放 | 国产成人精品av网站| 亚洲成人激情av在线| 最新日韩av传媒在线| 三上悠亚和黑人665番号| 大陆精品一区二区三区久久| 久久久久久久99精品| 黄色资源视频网站日韩| 亚洲欧美激情国产综合久久久| 国产女人被做到高潮免费视频| 成年人午夜黄片视频资源| 99久久中文字幕一本人| 成人网18免费视频版国产| 最新97国产在线视频| 青青社区2国产视频| 久久久麻豆精亚洲av麻花| 亚洲综合色在线免费观看| 国产精品黄大片在线播放| 国产精品三级三级三级| 免费岛国喷水视频在线观看| 11久久久久久久久久久| 国产视频网站一区二区三区| 日本xx片在线观看| 亚洲成av人无码不卡影片一| 在线观看av亚洲情色| 人妻激情图片视频小说| 天天插天天色天天日| 果冻传媒av一区二区三区| 白嫩白嫩美女极品国产在线观看| 999九九久久久精品| 亚洲欧美久久久久久久久| 夜夜嗨av蜜臀av| 女同性ⅹxx女同hd| 97人妻总资源视频| 一级黄片久久久久久久久| 天天干夜夜操天天舔| 一区二区在线视频中文字幕| 欧美男同性恋69视频| 又大又湿又爽又紧A视频| 亚洲午夜福利中文乱码字幕| 春色激情网欧美成人| 亚洲天堂成人在线观看视频网站| 精品国产污污免费网站入口自| 日韩欧美国产一区ab| 亚洲综合乱码一区二区| 日本一区二区三区免费小视频| 不卡日韩av在线观看| 色天天天天射天天舔| 韩国男女黄色在线观看| 18禁美女黄网站色大片下载| 午夜激情久久不卡一区二区 | 亚洲免费成人a v| 18禁美女羞羞免费网站| 亚洲天堂成人在线观看视频网站 | 男人的网址你懂的亚洲欧洲av| 国产精品自拍在线视频| 最新97国产在线视频| 日本少妇人妻xxxxxhd| 美女张开两腿让男人桶av| 精品久久久久久久久久中文蒉| 欧美黄色录像免费看的| 99热99re在线播放| 国产av自拍偷拍盛宴| 国产 在线 免费 精品| 91九色国产porny蝌蚪| 亚洲国产在人线放午夜| 国产av一区2区3区| 国产精品大陆在线2019不卡| 中国视频一区二区三区| 91色九色porny| 国产一区成人在线观看视频| 国产亚洲精品视频合集| 亚洲一区二区三区五区| 端庄人妻堕落挣扎沉沦| 毛片一级完整版免费| 男人的天堂av日韩亚洲| 一个人免费在线观看ww视频 | 91极品新人『兔兔』精品新作| 狠狠躁夜夜躁人人爽天天天天97| 老司机免费视频网站在线看| 另类av十亚洲av| 1024久久国产精品| 国产真实灌醉下药美女av福利| 中文字幕 亚洲av| 免费男阳茎伸入女阳道视频| 亚洲国产精品美女在线观看| 五十路在线观看完整版| 国产亚洲欧美45p| 护士小嫩嫩又紧又爽20p| 国产精品视频资源在线播放 | 国产成人午夜精品福利| 亚洲一级美女啪啪啪| 成人性爱在线看四区| 精品欧美一区二区vr在线观看| 亚洲精品国产综合久久久久久久久| 成年人黄视频在线观看| 自拍偷拍,中文字幕| 亚洲一区二区三区uij| 一区二区三区麻豆福利视频| 国产成人精品一区在线观看| chinese国产盗摄一区二区| 40道精品招牌菜特色| 中文字幕午夜免费福利视频| 日本福利午夜电影在线观看| 美女av色播在线播放| 国产精品成人xxxx| 午夜毛片不卡免费观看视频 | 欧美综合婷婷欧美综合| 激情啪啪啪啪一区二区三区| 日韩欧美亚洲熟女人妻| 天天日天天干天天要| 欲满人妻中文字幕在线| 国产精品自偷自拍啪啪啪| 人人妻人人澡人人爽人人dvl| 任你操任你干精品在线视频| 大屁股熟女一区二区三区| 日韩激情文学在线视频| 成年女人免费播放视频| 老司机免费福利视频网| 国产三级影院在线观看| 男女啪啪视频免费在线观看| 欧美成人综合色在线噜噜| 中文字幕高清免费在线人妻 | 色婷婷六月亚洲综合香蕉| 五月激情婷婷久久综合网| 九色porny九色9l自拍视频| 2017亚洲男人天堂| 青青青青青手机视频| 亚洲国产免费av一区二区三区| 欧美韩国日本国产亚洲| 国产精品国色综合久久 | 狠狠嗨日韩综合久久| 精品久久久久久久久久久99| 特级欧美插插插插插bbbbb| av破解版在线观看| 99精品亚洲av无码国产另类| 午夜蜜桃一区二区三区| 揄拍成人国产精品免费看视频| 最近的中文字幕在线mv视频| 国产黄网站在线观看播放| 3D动漫精品啪啪一区二区下载| 亚洲国产欧美国产综合在线| 大鸡巴后入爆操大屁股美女| 亚洲2021av天堂| 日本性感美女三级视频| 日韩在线视频观看有码在线| 青青草原网站在线观看| 国产97在线视频观看| 欧美香蕉人妻精品一区二区| 亚洲推理片免费看网站| 18禁美女羞羞免费网站| 亚洲人一区二区中文字幕| 亚洲福利精品福利精品福利| yy6080国产在线视频| 亚洲国产欧美国产综合在线| 粉嫩欧美美人妻小视频| 日日夜夜狠狠干视频| 成人30分钟免费视频| 亚洲激情,偷拍视频| 中文字幕一区二区三区人妻大片| 狠狠的往里顶撞h百合| 国产精品自拍偷拍a| 97资源人妻免费在线视频| 亚国产成人精品久久久| 人人人妻人人澡人人| 亚洲图片偷拍自拍区| 成年人啪啪视频在线观看| 亚洲推理片免费看网站| 亚洲一区二区三区偷拍女厕91| 成人性黑人一级av| 任你操任你干精品在线视频| 男女啪啪视频免费在线观看| 喷水视频在线观看这里只有精品| 成人伊人精品色xxxx视频| 青青草在观免费国产精品| 欧美激情电影免费在线| www日韩毛片av| 加勒比视频在线免费观看| 在线国产精品一区二区三区| 五十路老熟女码av| 全国亚洲男人的天堂| 天天日天天干天天干天天日| 日本精品视频不卡一二三| 亚洲av无女神免非久久| 女生被男生插的视频网站| 日韩欧美亚洲熟女人妻| 精品国产成人亚洲午夜| 久久三久久三久久三久久| 亚洲1卡2卡三卡4卡在线观看| 国产使劲操在线播放| 青青青爽视频在线播放| 五十路丰满人妻熟妇| 888亚洲欧美国产va在线播放| 五月激情婷婷久久综合网| 国产亚洲欧美视频网站| 欧美一级色视频美日韩| 老师让我插进去69AV| 伊人综合aⅴ在线网| 自拍偷拍vs一区二区三区| 久久精品国产亚洲精品166m| 日本av熟女在线视频| 亚洲高清自偷揄拍自拍| 高清成人av一区三区| 国产av国片精品一区二区| 午夜精品在线视频一区| 日韩欧美制服诱惑一区在线| 日日日日日日日日夜夜夜夜夜夜| 免费成人av中文字幕| 男生舔女生逼逼的视频| v888av在线观看视频| 午夜美女少妇福利视频| 91天堂天天日天天操| 熟女国产一区亚洲中文字幕| 丝袜肉丝一区二区三区四区在线 | 天天插天天色天天日| 91麻豆精品秘密入口在线观看| 欧美精品免费aaaaaa| 天天通天天透天天插| gay gay男男瑟瑟在线网站| 亚洲图库另类图片区| 91精品国产91青青碰| 亚洲欧美人精品高清| 国产又粗又硬又猛的毛片视频| 9国产精品久久久久老师| 亚洲午夜在线视频福利| 夏目彩春在线中文字幕| 在线观看国产网站资源| 午夜影院在线观看视频羞羞羞| 色伦色伦777国产精品| 黄网十四区丁香社区激情五月天| 成年午夜影片国产片| 天天操天天插天天色| 久久久超爽一二三av| 巨乳人妻日下部加奈被邻居中出| 真实国产乱子伦一区二区| 久久久超爽一二三av| 大香蕉伊人国产在线| 在线国产日韩欧美视频| 亚洲av成人免费网站| 男人的天堂av日韩亚洲| 色花堂在线av中文字幕九九| 搞黄色在线免费观看| 免费成人av中文字幕| 玩弄人妻熟妇性色av少妇| 午夜毛片不卡在线看| 91国产资源在线视频| 精品人妻一二三区久久| 中文字幕—97超碰网| 绝顶痉挛大潮喷高潮无码| 精品一区二区三区三区色爱| 爆乳骚货内射骚货内射在线| 国产综合视频在线看片| 亚洲av无码成人精品区辽| 精品久久婷婷免费视频| 黄色av网站免费在线| 换爱交换乱高清大片| 中文字幕乱码av资源| 国产又色又刺激在线视频| 超级福利视频在线观看| 欧美女同性恋免费a| 粉嫩av蜜乳av蜜臀| 亚洲精品av在线观看| 亚洲精品国产综合久久久久久久久| 欧美3p在线观看一区二区三区| av天堂中文字幕最新| 成年美女黄网站18禁久久| av中文字幕在线导航| 中文字幕综合一区二区| 新婚人妻聚会被中出| av日韩在线免费播放| 日本阿v视频在线免费观看| 天天射夜夜操狠狠干| 精品一区二区三区三区色爱| av老司机亚洲一区二区| 久久久超爽一二三av| 成人亚洲国产综合精品| 天天日天天操天天摸天天舔| 自拍偷拍vs一区二区三区| 国产91久久精品一区二区字幕| 日韩av免费观看一区| 国产熟妇乱妇熟色T区| 日本丰满熟妇大屁股久久| 亚洲中文精品人人免费| 最近中文字幕国产在线| 国产密臀av一区二区三| 午夜久久久久久久99| 亚洲成人熟妇一区二区三区| 又色又爽又黄又刺激av网站| 欧美成人综合色在线噜噜| 亚洲国产免费av一区二区三区| 中文字幕之无码色多多| 久久精品美女免费视频| 97黄网站在线观看| 久久精品亚洲国产av香蕉| 国产一级精品综合av| 91精品国产高清自在线看香蕉网| av在线播放国产不卡| 2021国产一区二区| 久草极品美女视频在线观看| 青青色国产视频在线| 国产chinesehd精品麻豆| 18禁网站一区二区三区四区| 在线视频精品你懂的| 中文字幕一区二 区二三区四区| 亚洲 欧美 精品 激情 偷拍| 人妻丝袜av在线播放网址| av高潮迭起在线观看| 天堂av在线播放免费| 97年大学生大白天操逼| 日本美女成人在线视频| 亚洲国产成人最新资源| 国产高清女主播在线| 久久这里只有精品热视频| av久久精品北条麻妃av观看| 亚洲成人熟妇一区二区三区 | 99热这里只有国产精品6| 青青青青爽手机在线| 狠狠躁夜夜躁人人爽天天久天啪| 免费十精品十国产网站| 亚洲图库另类图片区| 欧美日韩在线精品一区二区三| 91桃色成人网络在线观看| 黑人3p华裔熟女普通话| 午夜精品福利一区二区三区p| 综合色区亚洲熟妇shxstz| av在线免费观看亚洲天堂| 日本一区二区三区免费小视频| 国产精品探花熟女在线观看| 40道精品招牌菜特色| 黄工厂精品视频在线观看| 欧美激情电影免费在线| 午夜福利人人妻人人澡人人爽| 嫩草aⅴ一区二区三区| 亚洲1区2区3区精华液| 午夜场射精嗯嗯啊啊视频| 亚洲一区自拍高清免费视频| 欧美精产国品一二三产品价格| 男人操女人逼逼视频网站| 亚洲第一伊人天堂网| 97国产在线av精品| 18禁网站一区二区三区四区| 日韩欧美中文国产在线| 97超碰人人搞人人| 欧美精品 日韩国产| 亚洲欧美福利在线观看| 午夜精品久久久久麻豆影视| 社区自拍揄拍尻屁你懂的| 人人爱人人妻人人澡39| 91免费放福利在线观看| eeuss鲁片一区二区三区| 天天操,天天干,天天射| 欧美aa一级一区三区四区| 亚洲一区二区人妻av| 色婷婷综合激情五月免费观看| 国产成人精品福利短视频| 精品国产亚洲av一淫| 97年大学生大白天操逼| 婷婷五月亚洲综合在线| 人妻丰满熟妇综合网| 大陆精品一区二区三区久久| 天堂av在线官网中文| 人妻少妇亚洲一区二区| 男人的天堂av日韩亚洲| 天天日天天鲁天天操| 国产亚洲欧美45p| 欧美男人大鸡吧插女人视频| 日本丰满熟妇大屁股久久| 视频在线亚洲一区二区| 在线免费观看99视频| 日本熟妇色熟妇在线观看| 天美传媒mv视频在线观看| 2021久久免费视频| 日本韩国免费一区二区三区视频| 色综合久久无码中文字幕波多| 中文字幕av熟女人妻| 亚洲欧美久久久久久久久| 中文字幕在线视频一区二区三区| 青青青青爽手机在线| 久久午夜夜伦痒痒想咳嗽P| 91九色porny国产蝌蚪视频| 午夜场射精嗯嗯啊啊视频| 日日夜夜精品一二三| 98精产国品一二三产区区别| 天天通天天透天天插| 一区二区三区的久久的蜜桃的视频 | asmr福利视频在线观看| 快点插进来操我逼啊视频| 日本精品视频不卡一二三| 亚洲精品麻豆免费在线观看| 人妻丝袜精品中文字幕| 精品美女在线观看视频在线观看| 动漫av网站18禁| 丝袜肉丝一区二区三区四区在线| 亚洲av男人的天堂你懂的| 中文字幕在线一区精品| 日韩一个色综合导航| 成人亚洲精品国产精品| 亚洲少妇高潮免费观看| 黄色片年轻人在线观看| 久久精品国产亚洲精品166m| 人妻少妇亚洲一区二区| 黄片色呦呦视频免费看| 免费高清自慰一区二区三区网站| eeuss鲁片一区二区三区| 美女小视频网站在线| 日本少妇的秘密免费视频| 888欧美视频在线| 欧美精品久久久久久影院| 精品一区二区三区三区88 | 亚洲人妻视频在线网| 啊用力插好舒服视频| 中文字幕一区二 区二三区四区| 丝袜美腿视频诱惑亚洲无| 国产亚洲精品欧洲在线观看| 日韩黄色片在线观看网站| 激情伦理欧美日韩中文字幕| 2022国产综合在线干| 人妻丝袜av在线播放网址| 久久久久久久一区二区三| 国产在线免费观看成人| 绝色少妇高潮3在线观看| 性感美女诱惑福利视频| 中文字幕乱码人妻电影| 男女第一次视频在线观看| 99精品国自产在线人| 涩爱综合久久五月蜜臀| 中文字幕成人日韩欧美| av无限看熟女人妻另类av| 丝袜美腿视频诱惑亚洲无| 国产乱子伦精品视频潮优女| 欧美一区二区三区四区性视频| 黄色av网站免费在线| 91高清成人在线视频| 小泽玛利亚视频在线观看| 最新欧美一二三视频| 亚洲高清国产自产av| 中文字幕免费在线免费| 久久久久只精品国产三级| 成人色综合中文字幕| 精品久久久久久久久久久久人妻| 一区二区三区美女毛片| 国产一级麻豆精品免费| 啊用力插好舒服视频| 久久久久久国产精品| 巨乳人妻日下部加奈被邻居中出| 91亚洲国产成人精品性色| 性感美女高潮视频久久久| 馒头大胆亚洲一区二区| 91久久人澡人人添人人爽乱| 大陆胖女人与丈夫操b国语高清 | 欧美另类一区二区视频| 婷婷五月亚洲综合在线| 大胸性感美女羞爽操逼毛片| 肏插流水妹子在线乐播下载| 传媒在线播放国产精品一区| 国产剧情演绎系列丝袜高跟| 午夜福利资源综合激情午夜福利资| 都市激情校园春色狠狠| 国产揄拍高清国内精品对白| 色av色婷婷人妻久久久精品高清| 人妻熟女在线一区二区| 都市激情校园春色狠狠| av线天堂在线观看| 大白屁股精品视频国产| 晚上一个人看操B片| 中文字幕人妻一区二区视频| 在线视频自拍第三页| 国产精品视频欧美一区二区| av在线资源中文字幕| 人妻少妇亚洲一区二区| 男人操女人的逼免费视频| 亚洲公开视频在线观看| 日韩激情文学在线视频| 男生舔女生逼逼视频| 亚洲午夜福利中文乱码字幕| 亚欧在线视频你懂的| 99精品国产aⅴ在线观看| 9色在线视频免费观看| 免费在线观看视频啪啪| 欧美综合婷婷欧美综合| 国产白袜脚足J棉袜在线观看| 日韩精品激情在线观看| 91老师蜜桃臀大屁股| 亚洲成人av在线一区二区| 无码日韩人妻精品久久| 午夜久久久久久久精品熟女| 欧美偷拍亚洲一区二区| av老司机精品在线观看| 亚洲一区二区三区久久受| 日韩欧美亚洲熟女人妻| 日噜噜噜夜夜噜噜噜天天噜噜噜| 秋霞午夜av福利经典影视| 香港三日本三韩国三欧美三级| 色哟哟国产精品入口| 黑人变态深video特大巨大| 亚洲一区二区三区五区 | 国产高清97在线观看视频| 国产精品入口麻豆啊啊啊| 久久久久久久久久久久久97| 91国内视频在线观看| 免费手机黄页网址大全| 欧美精品一二三视频| 伊人综合aⅴ在线网| 大尺度激情四射网站| 91精品国产91青青碰| 中文字幕一区二 区二三区四区| 欧美精品中文字幕久久二区| 一区国内二区日韩三区欧美| 伊人精品福利综合导航| 激情图片日韩欧美人妻| 99的爱精品免费视频| japanese日本熟妇另类| 天天色天天操天天透| 国产性生活中老年人视频网站| 欧美日本在线观看一区二区| 在线免费观看日本伦理| 青青青青青手机视频| 青青草成人福利电影| sw137 中文字幕 在线| 国产精选一区在线播放| av天堂资源最新版在线看| 男人的天堂在线黄色| 亚洲欧美人精品高清| 都市家庭人妻激情自拍视频| 人妻少妇一区二区三区蜜桃| 偷拍美女一区二区三区| 国产1区,2区,3区| 久久美欧人妻少妇一区二区三区| 92福利视频午夜1000看| 97国产精品97久久| av中文字幕福利网| 亚洲精品 欧美日韩| 97瑟瑟超碰在线香蕉| av在线播放国产不卡| 亚洲激情偷拍一区二区| 精品人妻一二三区久久| 动漫美女的小穴视频| 岛国av高清在线成人在线| 欧美日韩精品永久免费网址 | 午夜福利资源综合激情午夜福利资 | 视频一区二区在线免费播放| 自拍偷拍亚洲另类色图| 福利午夜视频在线合集| 黄片三级三级三级在线观看| 成熟熟女国产精品一区| 免费在线看的黄网站| 久久久超爽一二三av| 干逼又爽又黄又免费的视频| 国产亚洲成人免费在线观看| 亚洲精品高清自拍av| 夜夜嗨av蜜臀av| 蜜臀av久久久久蜜臀av麻豆| 天天色天天操天天舔| 果冻传媒av一区二区三区| 亚洲欧美国产麻豆综合| 久久久久久九九99精品| 天天通天天透天天插| 一个色综合男人天堂| 黄页网视频在线免费观看| 国产福利在线视频一区| 四川乱子伦视频国产vip| 一区二区三区综合视频| 少妇高潮无套内谢麻豆| 人妻久久无码中文成人| 欧美亚洲中文字幕一区二区三区| 99久久成人日韩欧美精品| 水蜜桃一区二区三区在线观看视频| 黄色在线观看免费观看在线| 无忧传媒在线观看视频| 日韩一个色综合导航| 被大鸡吧操的好舒服视频免费| 91中文字幕免费在线观看| 黄色三级网站免费下载| 岛国免费大片在线观看 | 亚洲蜜臀av一区二区三区九色| 性生活第二下硬不起来| 日韩中文字幕福利av| gogo国模私拍视频| 欧美日韩情色在线观看| 亚洲成人激情视频免费观看了| 2020中文字幕在线播放| 日韩在线中文字幕色| 亚洲av无硬久久精品蜜桃| 超碰中文字幕免费观看| 一色桃子久久精品亚洲 | 在线观看免费av网址大全| 中文字幕高清资源站| 黑人变态深video特大巨大| 非洲黑人一级特黄片| 激情国产小视频在线| 婷婷久久一区二区字幕网址你懂得| 亚洲精品国品乱码久久久久| 国产麻豆剧果冻传媒app| 亚洲高清国产一区二区三区| 欧美视频一区免费在线| 精品国产污污免费网站入口自| 亚洲的电影一区二区三区| 乱亲女秽乱长久久久| 午夜精品一区二区三区更新| 一区二区三区日本伦理| 亚洲偷自拍高清视频| 成人午夜电影在线观看 久久| 99精品一区二区三区的区| 天天日天天透天天操| 日本女人一级免费片| 亚洲精品亚洲人成在线导航| 日韩加勒比东京热二区| 自拍偷拍,中文字幕| 不卡精品视频在线观看| 天天综合天天综合天天网| 骚逼被大屌狂草视频免费看| 午夜激情久久不卡一区二区| 午夜91一区二区三区| 人妻素人精油按摩中出| 国产精品久久久久国产三级试频| 91中文字幕免费在线观看| 这里只有精品双飞在线播放| 中文字幕视频一区二区在线观看| 东京热男人的av天堂| 曰本无码人妻丰满熟妇啪啪| AV天堂一区二区免费试看| 韩国AV无码不卡在线播放| 这里只有精品双飞在线播放| 5528327男人天堂| 综合色区亚洲熟妇shxstz| 中文字幕一区的人妻欧美日韩| 男人的天堂在线黄色| 熟女视频一区,二区,三区| 久久亚洲天堂中文对白| 精彩视频99免费在线| 最近的中文字幕在线mv视频| 国产成人午夜精品福利| 激情国产小视频在线| 岛国一区二区三区视频在线| 91色秘乱一区二区三区| 极品性荡少妇一区二区色欲| 国产一线二线三线的区别在哪 | 老司机欧美视频在线看| 黄色成人在线中文字幕| 国产免费高清视频视频| 日本美女成人在线视频| 人妻av无码专区久久绿巨人| av在线观看网址av| 后入美女人妻高清在线| 久久人人做人人妻人人玩精品vr| 日韩美女搞黄视频免费| 美女少妇亚洲精选av| 亚洲精品 欧美日韩| 一区二区免费高清黄色视频| 亚洲丝袜老师诱惑在线观看| 国产av福利网址大全| 日韩激情文学在线视频| 美女在线观看日本亚洲一区| 青青草在观免费国产精品| 青青青青视频在线播放| 亚洲精品一线二线在线观看| 521精品视频在线观看| 欧美xxx成人在线| 精品人妻伦一二三区久| 97人妻无码AV碰碰视频| 好吊视频—区二区三区| 天天射,天天操,天天说| 伊人日日日草夜夜草| 国产刺激激情美女网站| 男人操女人的逼免费视频| 国产精品视频一区在线播放| 中文字幕人妻一区二区视频| 边摸边做超爽毛片18禁色戒| 青青操免费日综合视频观看| 国产精品成人xxxx| 久久久久久久久久久免费女人| 三级av中文字幕在线观看| 天天干狠狠干天天操| 欧美日韩人妻久久精品高清国产| 日本三极片中文字幕| av天堂中文字幕最新| 亚洲一区自拍高清免费视频| 国产又粗又硬又大视频| 国产精品精品精品999| 五十路息与子猛烈交尾视频| 亚洲国产美女一区二区三区软件| 国产91嫩草久久成人在线视频| 毛片一级完整版免费| 美女小视频网站在线| 在线视频免费观看网| 好了av中文字幕在线| 五月激情婷婷久久综合网| 99精品国产自在现线观看| 一区二区三区日本伦理| 中文字幕—97超碰网| 91p0rny九色露脸熟女| 天天日天天干天天要| 97国产精品97久久| 国产黄色大片在线免费播放| 亚洲成人黄色一区二区三区| 国产精品3p和黑人大战| 亚洲一级av无码一级久久精品| 99久久99一区二区三区| av天堂中文字幕最新| 国产va在线观看精品| 狠狠鲁狠狠操天天晚上干干| 水蜜桃国产一区二区三区| 又色又爽又黄的美女裸体| 精彩视频99免费在线| 日韩北条麻妃一区在线| 黄色大片男人操女人逼| 日韩精品二区一区久久| 沈阳熟妇28厘米大战黑人| 性生活第二下硬不起来| 自拍偷区二区三区麻豆| 99久久成人日韩欧美精品| 中文字幕av一区在线观看| 亚洲丝袜老师诱惑在线观看| 成人区人妻精品一区二视频| 天天干夜夜操天天舔| 在线观看亚洲人成免费网址| 精品久久久久久久久久久99| 国产精品久久久黄网站| av手机免费在线观看高潮| 亚洲 国产 成人 在线| 国产实拍勾搭女技师av在线| 人妻爱爱 中文字幕| 欧美另类重口味极品在线观看| 自拍 日韩 欧美激情| 天天色天天爱天天爽| 成人综合亚洲欧美一区| 久草视频 久草视频2| 98精产国品一二三产区区别| 亚洲天堂第一页中文字幕| 涩涩的视频在线观看视频| 啊啊好大好爽啊啊操我啊啊视频 | 国产成人精品亚洲男人的天堂| 日韩在线视频观看有码在线| 午夜福利人人妻人人澡人人爽| 女同久久精品秋霞网| 又粗又硬又猛又爽又黄的| 欧美色婷婷综合在线| 孕妇奶水仑乱A级毛片免费看| 亚洲一级特黄特黄黄色录像片| 欧美国产亚洲中英文字幕| 天天干夜夜操啊啊啊| 国产片免费观看在线观看| 福利午夜视频在线观看| 亚洲Av无码国产综合色区| 国产精品国产三级国产精东| 免费黄高清无码国产| 免费在线看的黄网站| 亚洲天堂有码中文字幕视频 | 日韩三级黄色片网站| 亚洲av日韩精品久久久| 一级黄片大鸡巴插入美女| 一区二区三区日韩久久| 精彩视频99免费在线| 亚洲综合另类欧美久久| 新婚人妻聚会被中出| 欧美综合婷婷欧美综合| 最新国产亚洲精品中文在线| 亚洲精品久久视频婷婷| 人妻丝袜精品中文字幕| 色综合久久久久久久久中文| 青青草精品在线视频观看| 国产janese在线播放| 亚洲国产精品久久久久蜜桃| 成年人黄视频在线观看| 中文字幕av第1页中文字幕| asmr福利视频在线观看| caoporn蜜桃视频| 白嫩白嫩美女极品国产在线观看| 精品国产污污免费网站入口自| 偷拍自拍亚洲美腿丝袜| 国产午夜福利av导航| 亚洲色偷偷综合亚洲AV伊人| 精品av国产一区二区三区四区 | 免费黄高清无码国产| av手机在线免费观看日韩av| 亚洲一区制服丝袜美腿| 99精品国产自在现线观看| 日韩熟女系列一区二区三区| 日本脱亚入欧是指什么| 揄拍成人国产精品免费看视频| 综合国产成人在线观看| 久久热久久视频在线观看| avjpm亚洲伊人久久| 在线亚洲天堂色播av电影| 在线国产日韩欧美视频| 97精品综合久久在线| 午夜在线观看一区视频| 中文字幕在线免费第一页| 天天色天天爱天天爽| 日本韩国免费一区二区三区视频| 国产美女精品福利在线| 91精品视频在线观看免费| 香蕉91一区二区三区| 日韩美女精品视频在线观看网站| 日韩亚洲高清在线观看| 天天日天天摸天天爱| 亚洲美女美妇久久字幕组| 99精品一区二区三区的区| 国产美女精品福利在线| 国产日本欧美亚洲精品视| 国产精品人久久久久久| 欧亚日韩一区二区三区观看视频| 婷婷综合亚洲爱久久| 亚洲综合在线视频可播放| 91麻豆精品传媒国产黄色片| 精品人妻伦一二三区久| 91福利视频免费在线观看| 日韩亚洲高清在线观看| 97人妻无码AV碰碰视频| 黄色资源视频网站日韩| 国产精品视频资源在线播放| 日本美女性生活一级片| 国产三级精品三级在线不卡| 无套猛戳丰满少妇人妻| 欧美中国日韩久久精品| 日曰摸日日碰夜夜爽歪歪| 88成人免费av网站| 亚洲av第国产精品| 亚洲老熟妇日本老妇| 欧美另类一区二区视频| 男女之间激情网午夜在线| 日韩二区视频一线天婷婷五| 国产成人精品av网站| 女同久久精品秋霞网| 国产成人精品久久二区91| 国产视频网站一区二区三区| 美女骚逼日出水来了| eeuss鲁片一区二区三区| 日噜噜噜夜夜噜噜噜天天噜噜噜| 国产麻豆91在线视频| 硬鸡巴动态操女人逼视频| 亚洲va欧美va人人爽3p| 中文字幕av第1页中文字幕| 大屁股熟女一区二区三区| 久久这里只有精品热视频| 男人和女人激情视频| 大香蕉伊人国产在线| 狠狠嗨日韩综合久久| 精品久久久久久高潮| 亚洲欧美精品综合图片小说| 91福利在线视频免费观看| 日韩欧美在线观看不卡一区二区| 精品首页在线观看视频| 国产视频在线视频播放| 亚洲国产成人在线一区| 国产精品国色综合久久| 不卡一不卡二不卡三| 影音先锋女人av噜噜色| 亚洲精品福利网站图片| 特级无码毛片免费视频播放| 在线观看国产网站资源| 91快播视频在线观看| 绝色少妇高潮3在线观看| 2012中文字幕在线高清| 亚洲成人av一区在线| 又粗又硬又猛又爽又黄的| 全国亚洲男人的天堂| 亚洲av自拍天堂网| 91综合久久亚洲综合| 天天日天天干天天爱| 欧美一区二区中文字幕电影| 狠狠嗨日韩综合久久| 熟女少妇激情五十路| 色偷偷伊人大杳蕉综合网| 亚洲黄色av网站免费播放| 亚洲一区久久免费视频| 日韩中文字幕福利av| 19一区二区三区在线播放| 熟女人妻在线中出观看完整版| 青青青国产片免费观看视频| 岛国av高清在线成人在线| 国产视频网站一区二区三区| 爱有来生高清在线中文字幕| 福利视频广场一区二区| 真实国产乱子伦一区二区| 久久香蕉国产免费天天| 午夜国产免费福利av| 大鸡巴插入美女黑黑的阴毛| 扒开腿挺进肉嫩小18禁视频| 年轻的人妻被夫上司侵犯| 青青青视频手机在线观看| 欧美一区二区中文字幕电影 | 欧美综合婷婷欧美综合| 99精品亚洲av无码国产另类| 丝袜美腿欧美另类 中文字幕| 国产欧美精品免费观看视频| 99久久久无码国产精品性出奶水| 久久久精品欧洲亚洲av| 1769国产精品视频免费观看| 午夜精品在线视频一区| 欧美成人综合色在线噜噜| 国产成人精品一区在线观看| 亚洲国产欧美国产综合在线| 超碰97人人做人人爱| 男人的天堂av日韩亚洲| 亚洲免费在线视频网站| 全国亚洲男人的天堂| 国产精品伦理片一区二区| 国产清纯美女al在线| 五月激情婷婷久久综合网| 美女av色播在线播放| 成人免费毛片aaaa| 欧美视频不卡一区四区| 热久久只有这里有精品| 亚洲福利天堂久久久久久| 性色蜜臀av一区二区三区| 521精品视频在线观看| 中文字幕一区二区亚洲一区| 521精品视频在线观看| 果冻传媒av一区二区三区| 在线观看欧美黄片一区二区三区| 日韩熟女av天堂系列| 精品亚洲在线免费观看| 欧美黄片精彩在线免费观看| aiss午夜免费视频| 白白操白白色在线免费视频 | 亚洲av日韩高清hd| 黄工厂精品视频在线观看| 老师啊太大了啊啊啊尻视频| 亚洲高清自偷揄拍自拍| 国产va在线观看精品| 久久久久久9999久久久久| 在线播放 日韩 av| av网站色偷偷婷婷网男人的天堂| 超级av免费观看一区二区三区| 深田咏美亚洲一区二区| 九色porny九色9l自拍视频| 日韩美在线观看视频黄| 午夜大尺度无码福利视频| 老司机99精品视频在线观看| 五十路老熟女码av| 国产精品成久久久久三级蜜臀av| 日韩在线视频观看有码在线| 久久久久久久亚洲午夜综合福利| 欧洲精品第一页欧洲精品亚洲| 亚洲 色图 偷拍 欧美| 国产伊人免费在线播放| 国产亚州色婷婷久久99精品| 91国内视频在线观看| 亚洲精品国产久久久久久| 适合午夜一个人看的视频| 亚洲av色香蕉一区二区三区| av中文字幕国产在线观看| 在线观看免费岛国av| 久久精品36亚洲精品束缚| 日本一区二区三区免费小视频| av日韩在线免费播放| 91免费福利网91麻豆国产精品| 亚洲欧美色一区二区| 亚洲精品乱码久久久久久密桃明| 日本午夜久久女同精女女| 午夜精品福利91av| 日韩欧美国产一区ab| 亚洲国产精品久久久久蜜桃| 在线观看的黄色免费网站| 馒头大胆亚洲一区二区| 青青社区2国产视频| 国产日韩欧美美利坚蜜臀懂色| 午夜免费观看精品视频| 日韩中文字幕精品淫| 性色蜜臀av一区二区三区| 大鸡八强奸视频在线观看| 青青青青爽手机在线| 天天想要天天操天天干| 国产在线拍揄自揄视频网站| 女生自摸在线观看一区二区三区| 成人性黑人一级av| 欧美成人综合视频一区二区| 97人妻夜夜爽二区欧美极品| 红杏久久av人妻一区| 最新国产精品网址在线观看| 欧美日韩v中文在线| 精品av久久久久久久| 成人免费做爰高潮视频| 伊人开心婷婷国产av| 亚洲熟女女同志女同| 男人的天堂av日韩亚洲| 激情啪啪啪啪一区二区三区| 夫妻在线观看视频91| 中英文字幕av一区| 老司机免费视频网站在线看| 亚洲变态另类色图天堂网| 精品乱子伦一区二区三区免费播| 不卡日韩av在线观看| 黑人借宿ntr人妻的沦陷2| 大白屁股精品视频国产| 国产精品亚洲在线观看| 精品国产亚洲av一淫| 都市家庭人妻激情自拍视频| 亚洲少妇人妻无码精品| 1区2区3区4区视频在线观看| 欧美另类z0z变态| 天天草天天色天天干| 精品一线二线三线日本| 国产日韩精品免费在线| 天天干夜夜操啊啊啊| 91中文字幕免费在线观看| yy96视频在线观看| av破解版在线观看| 大陆胖女人与丈夫操b国语高清 | 天天综合天天综合天天网| 天天日夜夜操天天摸| 天码人妻一区二区三区在线看| 同居了嫂子在线播高清中文| 动漫黑丝美女的鸡巴| sejizz在线视频| 在线观看免费视频色97| 阴茎插到阴道里面的视频| 最近中文2019年在线看| 午夜在线观看一区视频| 99久久成人日韩欧美精品| 动漫美女的小穴视频| 国产精品中文av在线播放| 日韩加勒比东京热二区| 亚洲女人的天堂av| 人妻丝袜av在线播放网址| 天天草天天色天天干| 久久艹在线观看视频| 啊啊啊想要被插进去视频| 91麻豆精品秘密入口在线观看| 一区二区三区蜜臀在线| 少妇深喉口爆吞精韩国| 亚洲国产免费av一区二区三区 | 亚洲自拍偷拍综合色| 一区二区三区国产精选在线播放| 天天干天天操天天扣| 午夜在线观看岛国av,com| 福利在线视频网址导航 | 天天做天天干天天操天天射| 韩国AV无码不卡在线播放| 激情五月婷婷免费视频| 18禁网站一区二区三区四区| 亚洲免费国产在线日韩| 日本在线一区二区不卡视频| 欧美一区二区三区激情啪啪啪| 91精品资源免费观看| 亚洲狠狠婷婷综合久久app| 国产成人精品福利短视频| 北条麻妃肉色丝袜视频| 初美沙希中文字幕在线| 日视频免费在线观看| 激情国产小视频在线| 中文字幕1卡1区2区3区| 亚洲免费国产在线日韩| 日韩欧美国产精品91| 操日韩美女视频在线免费看| 亚洲最大黄了色网站| 亚洲欧美一区二区三区电影| 视频一区二区在线免费播放| 久久久久久久一区二区三| 免费一级特黄特色大片在线观看| 日韩三级黄色片网站| 欧美日本在线观看一区二区 | 精品国产高潮中文字幕| 亚洲色偷偷综合亚洲AV伊人| 久久综合老鸭窝色综合久久| 午夜毛片不卡免费观看视频| 国产日韩欧美美利坚蜜臀懂色| 欧美一区二区三区乱码在线播放 | 国产V亚洲V天堂无码欠欠| 夜女神免费福利视频| 九一传媒制片厂视频在线免费观看 | 美女视频福利免费看| 亚洲成高清a人片在线观看| 精品一区二区三区欧美| 一级黄色片夫妻性生活| 欧美视频综合第一页| av中文字幕网址在线| 91综合久久亚洲综合| 日韩欧美一级aa大片| 国际av大片在线免费观看| 青青青国产片免费观看视频| 欧美日韩亚洲国产无线码| 抽查舔水白紧大视频| 综合一区二区三区蜜臀| 伊拉克及约旦宣布关闭领空| 国产又粗又黄又硬又爽| 欧美一级视频一区二区| 亚洲第一黄色在线观看| 大骚逼91抽插出水视频| 自拍偷拍一区二区三区图片| 40道精品招牌菜特色| 喷水视频在线观看这里只有精品| 韩国爱爱视频中文字幕| 亚洲的电影一区二区三区| 黄工厂精品视频在线观看| 国产精品黄片免费在线观看| 在线视频国产欧美日韩| 国产chinesehd精品麻豆| 人妻熟女中文字幕aⅴ在线| 岛国免费大片在线观看 | 精品91自产拍在线观看一区| 啊啊啊想要被插进去视频| 亚洲熟妇无码一区二区三区| 国产a级毛久久久久精品| 欧美日韩精品永久免费网址| 91在线视频在线精品3| 国产精品国产三级麻豆| 久久免看30视频口爆视频| 一区二区熟女人妻视频| 美女福利写真在线观看视频| 在线观看免费视频网| 中文字幕在线视频一区二区三区| 青草久久视频在线观看| 国产视频在线视频播放| 人人妻人人人操人人人爽| 亚洲欧洲av天堂综合| 国产又粗又硬又猛的毛片视频| 肏插流水妹子在线乐播下载| 中国老熟女偷拍第一页| 天天射夜夜操综合网| 国产a级毛久久久久精品| 国产亚洲四十路五十路| 亚洲欧美日韩视频免费观看| 亚洲免费成人a v| 国产变态另类在线观看| 伊人综合免费在线视频| 中国黄片视频一区91| 亚洲人成精品久久久久久久| 久久免费看少妇高潮完整版| 亚洲国产美女一区二区三区软件| 传媒在线播放国产精品一区| 老司机福利精品免费视频一区二区 | 性感美女诱惑福利视频| 啊啊啊视频试看人妻| 国产精品人久久久久久| 80电影天堂网官网| 啊慢点鸡巴太大了啊舒服视频| 亚洲福利天堂久久久久久| 青娱乐在线免费视频盛宴| 蜜桃色婷婷久久久福利在线| 黄色大片男人操女人逼| 亚洲在线免费h观看网站| 国产三级精品三级在线不卡| 9l人妻人人爽人人爽| 国产精品黄色的av| 日韩熟女系列一区二区三区| 亚洲欧洲av天堂综合| 熟女91pooyn熟女| 啪啪啪啪啪啪啪免费视频| 狠狠躁夜夜躁人人爽天天天天97| 日韩一区二区电国产精品| 久草视频在线一区二区三区资源站 | 91大屁股国产一区二区| 午夜久久久久久久精品熟女| japanese五十路熟女熟妇| 午夜频道成人在线91| 1024久久国产精品| 天天干天天啪天天舔| 青青草亚洲国产精品视频| 专门看国产熟妇的网站| 亚洲精品无码色午夜福利理论片| 国产精品一区二区久久久av| 国产乱子伦一二三区| 唐人色亚洲av嫩草| av在线免费观看亚洲天堂| 天堂资源网av中文字幕| 青青青aaaa免费| 最新日韩av传媒在线| 哥哥姐姐综合激情小说| 国产视频在线视频播放| 精品国产在线手机在线| 亚洲特黄aaaa片| 大骚逼91抽插出水视频| 久草视频福利在线首页| 91精品国产高清自在线看香蕉网| 国产一区二区神马久久| 久久这里只有精品热视频 | 内射久久久久综合网| 老司机免费福利视频网| 成人av天堂丝袜在线观看| 亚洲精品国偷自产在线观看蜜桃| 人妻丝袜精品中文字幕| 三上悠亚和黑人665番号| 成人av天堂丝袜在线观看| 亚洲欧美清纯唯美另类 | 日本女大学生的黄色小视频| 国产精品系列在线观看一区二区| 天天干天天操天天摸天天射| 人妻少妇av在线观看| 一区二区三区的久久的蜜桃的视频 | 精品美女福利在线观看| 亚洲国产最大av综合| 久久机热/这里只有| xxx日本hd高清| 日韩成人性色生活片| 香蕉aⅴ一区二区三区| 免费黄高清无码国产| 亚洲另类在线免费观看| 国产福利小视频免费观看| 又大又湿又爽又紧A视频| 天天操天天干天天日狠狠插| 日韩不卡中文在线视频网站| 久草视频在线一区二区三区资源站| 国产亚洲精品视频合集| 久久久精品欧洲亚洲av| 最新国产精品拍在线观看| 五十路息与子猛烈交尾视频| 热99re69精品8在线播放| 天天操天天射天天操天天天| 五色婷婷综合狠狠爱| 日本欧美视频在线观看三区| 一级黄片久久久久久久久| 美女操逼免费短视频下载链接| 国产乱弄免费视频观看| 午夜的视频在线观看| 人妻凌辱欧美丰满熟妇| 色综合久久久久久久久中文| 午夜精品福利一区二区三区p| 国产女人被做到高潮免费视频| 蜜桃精品久久久一区二区| 成年人午夜黄片视频资源| 三级av中文字幕在线观看| 国产在线观看免费人成短视频| 精品久久久久久高潮| 99热久久极品热亚洲| 婷婷综合亚洲爱久久| 亚洲激情唯美亚洲激情图片| 国产精品国产三级国产精东| 偷拍美女一区二区三区| 日韩欧美制服诱惑一区在线| 亚洲精品高清自拍av| av森泽佳奈在线观看| 日韩特级黄片高清在线看| 第一福利视频在线观看| 美女吃鸡巴操逼高潮视频| 人人妻人人澡人人爽人人dvl| 天天射夜夜操综合网| 97精品视频在线观看| 亚洲 图片 欧美 图片| 美女视频福利免费看| 粉嫩欧美美人妻小视频| 大学生A级毛片免费视频| 偷拍自拍福利视频在线观看| 欧美精品资源在线观看| 久青青草视频手机在线免费观看 | 亚洲最大黄 嗯色 操 啊| av男人天堂狠狠干| yy96视频在线观看| 热99re69精品8在线播放| 动漫美女的小穴视频| 亚洲福利精品视频在线免费观看| 中英文字幕av一区| 国产综合视频在线看片| 亚洲图片欧美校园春色| 天天日天天敢天天干| av视网站在线观看| 一区二区三区四区视频在线播放| 久久久精品999精品日本| 丝袜美腿视频诱惑亚洲无| 中文字幕av男人天堂| 2o22av在线视频| 日本熟妇喷水xxx| 超碰公开大香蕉97| 美女视频福利免费看| 亚洲日本一区二区三区| 天天日天天爽天天干| 成人免费毛片aaaa| 人妻av无码专区久久绿巨人| 日韩中文字幕在线播放第二页 | 男女啪啪视频免费在线观看| 亚洲国产40页第21页| 91片黄在线观看喷潮| 国产黄色a级三级三级三级| 在线观看av2025| 自拍偷区二区三区麻豆| 亚洲一区二区三区av网站| 精内国产乱码久久久久久| 国产三级片久久久久久久| 亚洲第一黄色在线观看| 亚洲 欧美 自拍 偷拍 在线| 欧美第一页在线免费观看视频| 亚洲2021av天堂| 粉嫩欧美美人妻小视频| 色av色婷婷人妻久久久精品高清| 97小视频人妻一区二区| 免费观看污视频网站| 一级A一级a爰片免费免会员| 天天躁夜夜躁日日躁a麻豆| 亚洲激情av一区二区| 在线国产精品一区二区三区| 国产黄网站在线观看播放| 欧美色呦呦最新网址| 中文字幕免费在线免费| 亚洲av一妻不如妾| 老司机午夜精品视频资源| 美女av色播在线播放| 中国把吊插入阴蒂的视频| 日本成人一区二区不卡免费在线| 性色蜜臀av一区二区三区| 乱亲女秽乱长久久久| 青青青视频自偷自拍38碰| 在线观看免费av网址大全| 少妇系列一区二区三区视频| 国产精品三级三级三级| 国产精品自拍视频大全| 国产在线观看黄色视频| 免费一级黄色av网站| 国产精品系列在线观看一区二区| 亚洲精品在线资源站| 99久久99久国产黄毛片| 亚洲一区二区三区uij| 午夜大尺度无码福利视频| 少妇人妻二三区视频| 91色秘乱一区二区三区| 久久精品国产亚洲精品166m| 97超碰人人搞人人| 亚洲精品精品国产综合| 日本熟妇喷水xxx| 亚洲午夜福利中文乱码字幕| 大黑人性xxxxbbbb| 中文乱理伦片在线观看| 男人的天堂在线黄色| av天堂中文字幕最新| 红杏久久av人妻一区| 日韩av免费观看一区| 一区二区三区 自拍偷拍| 91色网站免费在线观看| 免费观看污视频网站| 中文字幕高清在线免费播放| 性感美女诱惑福利视频| japanese日本熟妇另类| 精品国产午夜视频一区二区| 少妇系列一区二区三区视频| 日本一道二三区视频久久| 啪啪啪啪啪啪啪免费视频| 最新中文字幕免费视频| 2020国产在线不卡视频| 2020久久躁狠狠躁夜夜躁| 农村胖女人操逼视频| 国产成人小视频在线观看无遮挡| 亚洲人人妻一区二区三区| 蜜桃色婷婷久久久福利在线| 日本xx片在线观看| 国产精品探花熟女在线观看| 一区二区三区美女毛片| 18禁美女黄网站色大片下载| av日韩在线观看大全| 中文字幕免费在线免费| av中文字幕电影在线看| 女人精品内射国产99| 亚洲天堂成人在线观看视频网站| 亚洲人人妻一区二区三区| 欧美亚洲偷拍自拍色图| 久久www免费人成一看片| 亚洲高清免费在线观看视频| 中文字幕奴隷色的舞台50| 青青青青操在线观看免费| 日韩人妻xxxxx| 操操网操操伊剧情片中文字幕网| 少妇ww搡性bbb91| 在线免费视频 自拍| 99热99这里精品6国产| 色婷婷久久久久swag精品| 亚洲一区二区三区五区| av天堂加勒比在线| 欧美美女人体视频一区| 搡老妇人老女人老熟女| 人人爱人人妻人人澡39| 欧美地区一二三专区| 一二三区在线观看视频| 福利国产视频在线观看| 一色桃子久久精品亚洲| 在线观看的黄色免费网站| 国产自拍黄片在线观看| 欧美成人综合色在线噜噜| 天干天天天色天天日天天射 | 欧美精品一二三视频| 黄色大片男人操女人逼| heyzo蜜桃熟女人妻| 99视频精品全部15| 伊人开心婷婷国产av| 日韩美女精品视频在线观看网站| 日本免费视频午夜福利视频| 性欧美日本大妈母与子| 在线免费观看欧美小视频| 久久久久久9999久久久久| 国产乱子伦一二三区| 激情国产小视频在线| 亚洲国产免费av一区二区三区 | 11久久久久久久久久久| 巨乳人妻日下部加奈被邻居中出| 天天躁日日躁狠狠躁av麻豆| av老司机精品在线观看| 亚洲Av无码国产综合色区| 天天通天天透天天插| okirakuhuhu在线观看| 国产chinesehd精品麻豆| 久草视频首页在线观看| 91chinese在线视频| 欧美视频中文一区二区三区| 1000部国产精品成人观看视频| 欧美在线一二三视频| 毛片一级完整版免费| 黄色的网站在线免费看| 成人30分钟免费视频| 亚洲第17页国产精品| 福利在线视频网址导航| 女同性ⅹxx女同h偷拍| 搞黄色在线免费观看| 在线播放国产黄色av| 天堂va蜜桃一区入口| 操日韩美女视频在线免费看 | 91小伙伴中女熟女高潮| 日本欧美视频在线观看三区| 亚洲国产在线精品国偷产拍| 国产品国产三级国产普通话三级| 2020中文字幕在线播放| 天天插天天狠天天操| 97资源人妻免费在线视频| 国产激情av网站在线观看| 国产精品亚洲а∨天堂免| 亚洲欧美福利在线观看| 亚洲精品国产在线电影| 日本熟妇丰满厨房55| 中文字幕在线观看国产片| 欧美aa一级一区三区四区| 福利在线视频网址导航| 亚洲国产香蕉视频在线播放| 韩国三级aaaaa高清视频| 四虎永久在线精品免费区二区| 中文字幕无码一区二区免费| 69精品视频一区二区在线观看| 大鸡吧插入女阴道黄色片| 日本免费一级黄色录像| 亚洲va国产va欧美va在线| 大香蕉伊人中文字幕| 国产品国产三级国产普通话三级| 日本最新一二三区不卡在线| 中文亚洲欧美日韩无线码| 国产成人一区二区三区电影网站| 伊人精品福利综合导航| 青青青青操在线观看免费| 2020久久躁狠狠躁夜夜躁| gay gay男男瑟瑟在线网站| 国产麻豆国语对白露脸剧情| 青青青爽视频在线播放| 青娱乐蜜桃臀av色| 青娱乐最新视频在线| 在线亚洲天堂色播av电影| 美女福利写真在线观看视频| 91成人在线观看免费视频| 成人精品视频99第一页| 5528327男人天堂| 1769国产精品视频免费观看| 人人妻人人澡欧美91精品| 天天操,天天干,天天射| 欧美精品亚洲精品日韩在线| 国产中文字幕四区在线观看| 自拍偷拍一区二区三区图片| 成人蜜臀午夜久久一区| av乱码一区二区三区| 亚洲精品国产久久久久久| 国产普通话插插视频| 91人妻精品一区二区在线看| 又色又爽又黄又刺激av网站| 中文字幕1卡1区2区3区| 亚洲欧美一区二区三区爱爱动图| mm131美女午夜爽爽爽| 蝴蝶伊人久久中文娱乐网| 日本人妻少妇18—xx| 三级黄色亚洲成人av| 日韩欧美国产一区ab| 99精品久久久久久久91蜜桃| 欧美成人小视频在线免费看| 国产精品日韩欧美一区二区| 亚洲国产精品中文字幕网站| 精品黑人巨大在线一区| 成人av中文字幕一区| 女生自摸在线观看一区二区三区| 亚洲va国产va欧美va在线| 在线视频这里只有精品自拍| 黄色片一级美女黄色片| 91香蕉成人app下载| 激情啪啪啪啪一区二区三区 | 色在线观看视频免费的| 80电影天堂网官网| 国产视频网站国产视频| 热99re69精品8在线播放| av中文字幕福利网| 亚洲成人情色电影在线观看| 日韩伦理短片在线观看| 亚洲熟女女同志女同| 亚洲久久午夜av一区二区| 日日夜夜狠狠干视频| 在线观看国产网站资源| 中文字幕在线永久免费播放| 国产精彩福利精品视频| 日韩精品二区一区久久| 高清一区二区欧美系列| 久久久91蜜桃精品ad| 在线观看一区二区三级| 成人亚洲国产综合精品| 东京干手机福利视频| 免费69视频在线看| 东游记中文字幕版哪里可以看到| 涩爱综合久久五月蜜臀| 国产a级毛久久久久精品| 精品久久婷婷免费视频| 在线播放国产黄色av| 老司机福利精品免费视频一区二区| 又色又爽又黄的美女裸体| 狠狠嗨日韩综合久久| 38av一区二区三区| 天天干天天啪天天舔| 欧美日本在线视频一区| 美女张开两腿让男人桶av| 97小视频人妻一区二区| 超pen在线观看视频公开97 | 久草视频首页在线观看| 九九视频在线精品播放| yy6080国产在线视频| 18禁污污污app下载| 国产亚洲视频在线二区| 人人人妻人人澡人人| 青青草视频手机免费在线观看| 黑人巨大精品欧美视频| 天天干天天日天天谢综合156 | 在线免费观看欧美小视频| 婷婷六月天中文字幕| 大鸡八强奸视频在线观看| av在线免费观看亚洲天堂| 欧美黄片精彩在线免费观看| 亚洲av日韩av第一区二区三区| 久久热久久视频在线观看| 一色桃子人妻一区二区三区| 亚洲综合在线视频可播放| 国产品国产三级国产普通话三级| 日韩中文字幕精品淫| 人人妻人人爽人人添夜| 色哟哟国产精品入口| 骚货自慰被发现爆操| 人妻自拍视频中国大陆| 免费啪啪啪在线观看视频| 999久久久久999| 久久艹在线观看视频| 欧美女同性恋免费a| 中字幕人妻熟女人妻a62v网| 一区二区三区日本伦理| 中文字幕日韩91人妻在线| 首之国产AV医生和护士小芳| 熟女国产一区亚洲中文字幕| 2017亚洲男人天堂| 午夜精品一区二区三区4| 大尺度激情四射网站| 亚洲一级av无码一级久久精品| 免费看国产av网站| 成人精品视频99第一页| 欧美男人大鸡吧插女人视频| 大香蕉玖玖一区2区| 99精品视频之69精品视频| 偷偷玩弄新婚人妻h视频| 38av一区二区三区| 久久久超爽一二三av| 午夜国产免费福利av| 九色porny九色9l自拍视频| 在线播放 日韩 av| 99热99这里精品6国产| 鸡巴操逼一级黄色气| 97人人妻人人澡人人爽人人精品| 偷拍自拍国产在线视频| 人人妻人人人操人人人爽| 日韩写真福利视频在线观看| 在线国产精品一区二区三区| 可以免费看的www视频你懂的| 精品乱子伦一区二区三区免费播| 在线播放 日韩 av| 一区二区免费高清黄色视频| 欧美天堂av无线av欧美| 九九热99视频在线观看97| 成人久久精品一区二区三区| 人妻最新视频在线免费观看| 91九色国产porny蝌蚪| 四川五十路熟女av| 欧美地区一二三专区| 国产成人一区二区三区电影网站| 涩涩的视频在线观看视频| 四川五十路熟女av| eeuss鲁片一区二区三区| 天天日天天鲁天天操| 日本在线一区二区不卡视频| 99精品国产免费久久| 91中文字幕最新合集| 久久香蕉国产免费天天| 成人乱码一区二区三区av| 91天堂天天日天天操| rct470中文字幕在线| 影音先锋女人av噜噜色| 二区中出在线观看老师| 在线不卡日韩视频播放| 丝袜亚洲另类欧美变态| 激情国产小视频在线| 青青青青青青青青青青草青青| 欧美激情电影免费在线| 日本最新一二三区不卡在线 | 亚洲av琪琪男人的天堂| 天天干天天啪天天舔| 国产成人精品午夜福利训2021 | 一色桃子久久精品亚洲| 亚洲另类伦春色综合小| 啪啪啪操人视频在线播放| 93视频一区二区三区| 夜色撩人久久7777| 粉嫩av懂色av蜜臀av| 可以在线观看的av中文字幕| 久久久久国产成人精品亚洲午夜| 亚洲人人妻一区二区三区| 91亚洲精品干熟女蜜桃频道 | 亚洲图片欧美校园春色| sw137 中文字幕 在线| 一区二区三区四区中文| 欧美3p在线观看一区二区三区| 午夜精品一区二区三区更新| 啪啪啪操人视频在线播放| 亚洲av一妻不如妾| 中文字幕无码一区二区免费| 一级a看免费观看网站| 91av中文视频在线| 一区二区三区久久久91| 91片黄在线观看喷潮| 国产露脸对白在线观看| 伊人情人综合成人久久网小说| 亚洲国产成人在线一区| 欧美日本aⅴ免费视频| 成人动漫大肉棒插进去视频| 色哟哟国产精品入口| 日本成人一区二区不卡免费在线| 沙月文乃人妻侵犯中文字幕在线 | avjpm亚洲伊人久久| 色天天天天射天天舔| 影音先锋女人av噜噜色| 97少妇精品在线观看| 人妻熟女在线一区二区| 新婚人妻聚会被中出| 亚洲久久午夜av一区二区| 老有所依在线观看完整版| 天天日天天鲁天天操| 91国偷自产一区二区三区精品| 99热这里只有精品中文| 日本熟妇一区二区x x| 女生被男生插的视频网站| 天天干天天操天天摸天天射| 在线观看欧美黄片一区二区三区| 亚洲欧美日韩视频免费观看| 人妻最新视频在线免费观看| 免费69视频在线看| 欧美精品久久久久久影院| 18禁污污污app下载| 日韩av有码一区二区三区4| 搞黄色在线免费观看| 欧美日本在线视频一区| 中文字幕日韩精品就在这里| 视频 一区二区在线观看| 亚洲一区久久免费视频| 午夜在线一区二区免费| 播放日本一区二区三区电影| 粉嫩欧美美人妻小视频| 色秀欧美视频第一页| 天堂资源网av中文字幕| av破解版在线观看| tube69日本少妇| 97国产在线观看高清| 非洲黑人一级特黄片| 99热99re在线播放| a v欧美一区=区三区| 又色又爽又黄又刺激av网站| 亚洲av无女神免非久久| 老司机99精品视频在线观看 | 久久人人做人人妻人人玩精品vr| 青青伊人一精品视频| 亚洲av可乐操首页| 大胸性感美女羞爽操逼毛片| 香蕉aⅴ一区二区三区| 亚洲伊人色一综合网| 蜜臀av久久久久蜜臀av麻豆| 免费无毒热热热热热热久| 国产日韩一区二区在线看| 亚洲国产中文字幕啊啊啊不行了 | 激情五月婷婷综合色啪| 日本福利午夜电影在线观看| 性欧美日本大妈母与子| 国产精品国色综合久久| 精品人妻每日一部精品| 青青青青青操视频在线观看| 最新欧美一二三视频|