婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 大數據量分頁存儲過程效率測試附測試代碼與結果

大數據量分頁存儲過程效率測試附測試代碼與結果

熱門標簽:小e電話機器人 申請400電話在哪辦理流程 貴州房產智能外呼系統供應商 百度地圖標注改顏色 臨沂智能電銷機器人加盟哪家好 外呼運營商線路收費 電銷外呼有錄音系統有哪些 一個導航軟件能用幾個地圖標注點 鎮江網路外呼系統供應商
測試環境
硬件:CPU 酷睿雙核T5750 內存:2G
軟件:Windows server 2003 + sql server 2005
OK,我們首先創建一數據庫:data_Test,并在此數據庫中創建一表:tb_TestTable
復制代碼 代碼如下:

create database data_Test --創建數據庫
data_Testnbsp;
GO
use data_Test
GO
create table tb_TestTable --創建表
(id int identity(1,1) primary key,
userName nvarchar(20) not null,
userPWD nvarchar(20) not null,
userEmail nvarchar(40) null)
GO

然后我們在數據表中插入2000000條數據:

復制代碼 代碼如下:

--插入數據
set identity_insert tb_TestTable on
declare @count int
set @count=1
while @count=2000000
begin
insert into tb_TestTable(id,userName,userPWD,userEmail) values(@count,'admin','admin888','lli0077@yahoo.com.cn')
set @count=@count+1
end
set identity_insert tb_TestTable off

我首先寫了五個常用存儲過程:
1,利用select top 和select not in進行分頁,具體代碼如下:
復制代碼 代碼如下:
create procedure proc_paged_with_notin --利用select top and select not in
(
@pageIndex int, --頁索引
@pageSize int --每頁記錄數
)
as
begin
set nocount on;
declare @timediff datetime --耗時
declare @sql nvarchar(500)
select @timediff=Getdate()
set @sql='select top '+str(@pageSize)+' * from tb_TestTable where(ID not in(select top '+str(@pageSize*@pageIndex)+' id from tb_TestTable order by ID ASC)) order by ID'
execute(@sql) --因select top后不支技直接接參數,所以寫成了字符串@sql
select datediff(ms,@timediff,GetDate()) as 耗時
set nocount off;
end

2,利用select top 和 select max(列鍵)
復制代碼 代碼如下:
create procedure proc_paged_with_selectMax --利用select top and select max(列)
(
@pageIndex int, --頁索引
@pageSize int --頁記錄數
)
as
begin
set nocount on;
declare @timediff datetime
declare @sql nvarchar(500)
select @timediff=Getdate()
set @sql='select top '+str(@pageSize)+' * From tb_TestTable where(ID>(select max(id) From (select top '+str(@pageSize*@pageIndex)+' id From tb_TestTable order by ID) as TempTable)) order by ID'
execute(@sql)
select datediff(ms,@timediff,GetDate()) as 耗時
set nocount off;
end

3,利用select top和中間變量--此方法因網上有人說效果最佳,所以貼出來一同測試
復制代碼 代碼如下:
create procedure proc_paged_with_Midvar --利用ID>最大ID值和中間變量
(
@pageIndex int,
@pageSize int
)
as
declare @count int
declare @ID int
declare @timediff datetime
declare @sql nvarchar(500)
begin
set nocount on;
select @count=0,@ID=0,@timediff=getdate()
select @count=@count+1,@ID=case when @count=@pageSize*@pageIndex then ID else @ID end from tb_testTable order by id
set @sql='select top '+str(@pageSize)+' * from tb_testTable where ID>'+str(@ID)
execute(@sql)
select datediff(ms,@timediff,getdate()) as 耗時
set nocount off;
end

4,利用Row_number() 此方法為sql server 2005中新的方法,利用Row_number()給數據行加上索引
復制代碼 代碼如下:
create procedure proc_paged_with_Rownumber --利用SQL 2005中的Row_number()
(
@pageIndex int,
@pageSize int
)
as
declare @timediff datetime
begin
set nocount on;
select @timediff=getdate()
select * from (select *,Row_number() over(order by ID asc) as IDRank from tb_testTable) as IDWithRowNumber where IDRank>@pageSize*@pageIndex and IDRank@pageSize*(@pageIndex+1)
select datediff(ms,@timediff,getdate()) as 耗時
set nocount off;
end

5,利用臨時表及Row_number
復制代碼 代碼如下:
create procedure proc_CTE --利用臨時表及Row_number
(
@pageIndex int, --頁索引
@pageSize int --頁記錄數
)
as
set nocount on;
declare @ctestr nvarchar(400)
declare @strSql nvarchar(400)
declare @datediff datetime
begin
select @datediff=GetDate()
set @ctestr='with Table_CTE as
(select ceiling((Row_number() over(order by ID ASC))/'+str(@pageSize)+') as page_num,* from tb_TestTable)';
set @strSql=@ctestr+' select * From Table_CTE where page_num='+str(@pageIndex)
end
begin
execute sp_executesql @strSql
select datediff(ms,@datediff,GetDate())
set nocount off;
end

OK,至此,存儲過程創建完畢,我們分別在每頁10條數據的情況下在第2頁,第1000頁,第10000頁,第100000頁,第199999頁進行測試,耗時單位:ms 每頁測試5次取其平均值
存過 第2頁耗時 第1000頁耗時 第10000頁耗時 第100000頁耗時 第199999頁耗時 效率排行
1用not in 0ms 16ms 47ms 475ms 953ms 3
2用select max 5ms 16ms 35ms 325ms 623ms 1
3中間變量 966ms 970ms 960ms 945ms 933ms 5
4row_number 0ms 0ms 34ms 365ms 710ms 2
4臨時表 780ms 796ms 798ms 780ms 805ms 4

測試結果顯示:select max >row_number>not in>臨時表>中間變量
于是我對效率最高的select max方法用2分法進行了擴展,代碼取自互聯網,我修改了ASC排序時取不到值的BUG,測試結果:
2分法 156ms 156ms 180ms 470ms 156ms 1*
從測試結果來看,使用2分法確實可以提高效率并使效率更為穩定,我又增加了第159999頁的測試,用時僅296ms,效果相當的不錯!
下面是2分法使用select max的代碼,已相當完善。

復制代碼 代碼如下:

--/*-----存儲過程 分頁處理 孫偉 2005-03-28創建 -------*/
--/*-----存儲過程 分頁處理 浪塵 2008-9-1修改----------*/
--/*----- 對數據進行了2分處理使查詢前半部分數據與查詢后半部分數據性能相同 -------*/

alter PROCEDURE proc_paged_2part_selectMax
(
@tblName nvarchar(200), ----要顯示的表或多個表的連接
@fldName nvarchar(500) = '*', ----要顯示的字段列表
@pageSize int = 10, ----每頁顯示的記錄個數
@page int = 1, ----要顯示那一頁的記錄
@fldSort nvarchar(200) = null, ----排序字段列表或條件
@Sort bit = 0, ----排序方法,0為升序,1為降序(如果是多字段排列Sort指代最后一個排序字段的排列順序(最后一個排序字段不加排序標記)--程序傳參如:' SortA Asc,SortB Desc,SortC ')
@strCondition nvarchar(1000) = null, ----查詢條件,不需where
@ID nvarchar(150), ----主表的主鍵
@Dist bit = 0, ----是否添加查詢字段的 DISTINCT 默認0不添加/1添加
@pageCount int = 1 output, ----查詢結果分頁后的總頁數
@Counts int = 1 output ----查詢到的記錄數
)
AS
SET NOCOUNT ON
Declare @sqlTmp nvarchar(1000) ----存放動態生成的SQL語句
Declare @strTmp nvarchar(1000) ----存放取得查詢結果總數的查詢語句
Declare @strID nvarchar(1000) ----存放取得查詢開頭或結尾ID的查詢語句

Declare @strSortType nvarchar(10) ----數據排序規則A
Declare @strFSortType nvarchar(10) ----數據排序規則B

Declare @SqlSelect nvarchar(50) ----對含有DISTINCT的查詢進行SQL構造
Declare @SqlCounts nvarchar(50) ----對含有DISTINCT的總數查詢進行SQL構造

declare @timediff datetime --耗時測試時間差
select @timediff=getdate()

if @Dist = 0
begin
set @SqlSelect = 'select '
set @SqlCounts = 'Count(*)'
end
else
begin
set @SqlSelect = 'select distinct '
set @SqlCounts = 'Count(DISTINCT '+@ID+')'
end


if @Sort=0
begin
set @strFSortType=' ASC '
set @strSortType=' DESC '
end
else
begin
set @strFSortType=' DESC '
set @strSortType=' ASC '
end



--------生成查詢語句--------
--此處@strTmp為取得查詢結果數量的語句
if @strCondition is null or @strCondition='' --沒有設置顯示條件
begin
set @sqlTmp = @fldName + ' From ' + @tblName
set @strTmp = @SqlSelect+' @Counts='+@SqlCounts+' FROM '+@tblName
set @strID = ' From ' + @tblName
end
else
begin
set @sqlTmp = + @fldName + 'From ' + @tblName + ' where (1>0) ' + @strCondition
set @strTmp = @SqlSelect+' @Counts='+@SqlCounts+' FROM '+@tblName + ' where (1>0) ' + @strCondition
set @strID = ' From ' + @tblName + ' where (1>0) ' + @strCondition
end

----取得查詢結果總數量-----
exec sp_executesql @strTmp,N'@Counts int out ',@Counts out
declare @tmpCounts int
if @Counts = 0
set @tmpCounts = 1
else
set @tmpCounts = @Counts

--取得分頁總數
set @pageCount=(@tmpCounts+@pageSize-1)/@pageSize

/**//**//**//**當前頁大于總頁數 取最后一頁**/
if @page>@pageCount
set @page=@pageCount

--/*-----數據分頁2分處理-------*/
declare @pageIndex int --總數/頁大小
declare @lastcount int --總數%頁大小

set @pageIndex = @tmpCounts/@pageSize
set @lastcount = @tmpCounts%@pageSize
if @lastcount > 0
set @pageIndex = @pageIndex + 1
else
set @lastcount = @pagesize

--//***顯示分頁
if @strCondition is null or @strCondition='' --沒有設置顯示條件
begin
if @pageIndex2 or @page=@pageIndex / 2 + @pageIndex % 2 --前半部分數據處理
begin
if @page=1
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' order by '+ @fldSort +' '+ @strFSortType
else
begin
if @Sort=1
begin
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' (select min('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1) as Varchar(20)) +' '+ @ID +' from '+@tblName
+' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
+' order by '+ @fldSort +' '+ @strFSortType
end
else
begin
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' >(select max('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1) as Varchar(20)) +' '+ @ID +' from '+@tblName
+' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
+' order by '+ @fldSort +' '+ @strFSortType
end
end
end
else
begin
set @page = @pageIndex-@page+1 --后半部分數據處理
if @page = 1 --最后一頁數據顯示
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@lastcount as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType
else
if @Sort=1
begin
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' >(select max('+ @ID +') from('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-2)+@lastcount as Varchar(20)) +' '+ @ID +' from '+@tblName
+' order by '+ @fldSort +' '+ @strSortType+') AS TBMaxID)'
+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType
end
else
begin
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' (select min('+ @ID +') from('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-2)+@lastcount as Varchar(20)) +' '+ @ID +' from '+@tblName
+' order by '+ @fldSort +' '+ @strSortType+') AS TBMaxID)'
+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType
end
end
end

else --有查詢條件
begin
if @pageIndex2 or @page=@pageIndex / 2 + @pageIndex % 2 --前半部分數據處理
begin
if @page=1
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where 1=1 ' + @strCondition + ' order by '+ @fldSort +' '+ @strFSortType
else if(@Sort=1)
begin
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' (select min('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1) as Varchar(20)) +' '+ @ID +' from '+@tblName
+' where (1=1) ' + @strCondition +' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
+' '+ @strCondition +' order by '+ @fldSort +' '+ @strFSortType
end
else
begin
set @strTmp=@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' >(select max('+ @ID +') from ('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-1) as Varchar(20)) +' '+ @ID +' from '+@tblName
+' where (1=1) ' + @strCondition +' order by '+ @fldSort +' '+ @strFSortType+') AS TBMinID)'
+' '+ @strCondition +' order by '+ @fldSort +' '+ @strFSortType
end
end
else
begin
set @page = @pageIndex-@page+1 --后半部分數據處理
if @page = 1 --最后一頁數據顯示
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@lastcount as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where (1=1) '+ @strCondition +' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType
else if(@Sort=1)
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' >(select max('+ @ID +') from('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-2)+@lastcount as Varchar(20)) +' '+ @ID +' from '+@tblName
+' where (1=1) '+ @strCondition +' order by '+ @fldSort +' '+ @strSortType+') AS TBMaxID)'
+' '+ @strCondition+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType
else
set @strTmp=@SqlSelect+' * from ('+@SqlSelect+' top '+ CAST(@pageSize as VARCHAR(4))+' '+ @fldName+' from '+@tblName
+' where '+@ID+' (select min('+ @ID +') from('+ @SqlSelect+' top '+ CAST(@pageSize*(@page-2)+@lastcount as Varchar(20)) +' '+ @ID +' from '+@tblName
+' where (1=1) '+ @strCondition +' order by '+ @fldSort +' '+ @strSortType+') AS TBMaxID)'
+' '+ @strCondition+' order by '+ @fldSort +' '+ @strSortType+') AS TempTB'+' order by '+ @fldSort +' '+ @strFSortType
end
end

------返回查詢結果-----
exec sp_executesql @strTmp
select datediff(ms,@timediff,getdate()) as 耗時
--print @strTmp
SET NOCOUNT OFF
GO

執行示例:exec proc_paged_2part_selectMax 'tb_testTable','ID,userName,userPWD,userEmail',10,100000,'ID',0,null,'ID',0
這種測試只在單機進行,并且沒有在實際開發WEB項目中分頁測試,測試項也比較單一,所以不夠全面系統,但從其效率相比上,我們可以在數據庫分頁算法上進行有效的控制。
您可能感興趣的文章:
  • 大數據量時提高分頁的效率
  • 數據庫高并發情況下重復值寫入的避免 字段組合約束
  • 大數據量,海量數據處理方法總結
  • MySQL數據庫優化經驗詳談(服務器普通配置)
  • MySQL數據庫十大優化技巧
  • SQL Server數據庫的高性能優化經驗總結
  • sql 存儲過程分頁代碼 支持億萬龐大數據量
  • 數據庫性能優化三:程序操作優化提升性能
  • 數據庫性能優化二:數據庫表優化提升性能
  • 數據庫性能優化一:數據庫自身優化提升性能
  • Oracle 數據庫優化實戰心得總結
  • 優化mysql數據庫的經驗總結
  • mysql數據庫優化總結(心得)
  • 關于數據庫優化問題收集匯總
  • oracle數據庫sql的優化總結
  • sql 百萬級數據庫優化方案分享
  • 優化Mysql數據庫的8個方法
  • mysql數據庫sql優化原則(經驗總結)
  • 針對Sqlserver大數據量插入速度慢或丟失數據的解決方法
  • MySQL數據庫優化詳解
  • MySQL中實現高性能高并發計數器方案(例如文章點擊數)
  • 超大數據量存儲常用數據庫分表分庫算法總結
  • sqlserver數據庫優化解析(圖文剖析)
  • 詳解MySQL性能優化(一)
  • 詳解MySQL性能優化(二)
  • 19個MySQL性能優化要點解析
  • 大數據量高并發的數據庫優化詳解

標簽:澳門 日照 晉城 保定 合肥 延邊 三明 嘉興

巨人網絡通訊聲明:本文標題《大數據量分頁存儲過程效率測試附測試代碼與結果》,本文關鍵詞  大,數據,量,分頁,存儲,過程,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《大數據量分頁存儲過程效率測試附測試代碼與結果》相關的同類信息!
  • 本頁收集關于大數據量分頁存儲過程效率測試附測試代碼與結果的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美极品少妇xxxxⅹ高跟鞋| 91久久国产综合久久| 亚洲伊人伊色伊影伊综合网| 国产精品成人网| 欧美国产激情一区二区三区蜜月| 久久久久国产免费免费| 国产日韩精品一区二区浪潮av| 久久久精品免费免费| 久久一区二区三区国产精品| 国产色一区二区| 18欧美亚洲精品| 亚洲第一成年网| 日韩二区三区在线观看| 国产一区二区导航在线播放| 成人免费毛片aaaaa**| 色综合咪咪久久| 欧美日韩成人综合| 日韩欧美一级二级| 中文字幕一区二区三区不卡| 亚洲第一av色| 国产福利一区在线| 91行情网站电视在线观看高清版| 欧美精品一二三| 久久精品欧美日韩| 午夜欧美大尺度福利影院在线看| 国模套图日韩精品一区二区 | 午夜精品久久久久久久99樱桃| 日韩国产欧美视频| 成人看片黄a免费看在线| 91官网在线观看| 欧美xfplay| 亚洲黄色在线视频| 国产在线看一区| 欧美日韩三级在线| 国产精品欧美经典| 日本亚洲电影天堂| 91麻豆蜜桃一区二区三区| 精品国产一区二区三区久久久蜜月| 中文字幕在线不卡| 国产一区亚洲一区| 欧美日韩一级片在线观看| 中文字幕乱码久久午夜不卡| 男人的天堂亚洲一区| 91久久一区二区| 国产精品美日韩| 国产露脸91国语对白| 6080午夜不卡| 一区二区三区丝袜| 99精品视频在线观看免费| 精品日本一线二线三线不卡| 亚洲午夜激情网站| 99久久精品一区| 国产欧美日本一区视频| 久久99精品网久久| 欧美一区二区女人| 天天综合日日夜夜精品| 在线精品视频小说1| 亚洲欧美色综合| av电影天堂一区二区在线 | 色美美综合视频| 国产精品亲子伦对白| 国产美女久久久久| 久久综合狠狠综合久久综合88| 捆绑紧缚一区二区三区视频| 欧美疯狂性受xxxxx喷水图片| 亚洲成人一区二区| 欧美性色aⅴ视频一区日韩精品| 国产精品剧情在线亚洲| 成人综合婷婷国产精品久久| 国产欧美日韩麻豆91| 成人性生交大合| 国产精品久久久久aaaa樱花| 99国产精品国产精品久久| 一区视频在线播放| 色综合天天做天天爱| 亚洲精品国产品国语在线app| www.亚洲激情.com| 亚洲综合无码一区二区| 在线观看日韩电影| 日韩二区在线观看| 欧美精品一区二区三区在线播放| 韩国成人在线视频| 中文字幕精品三区| 色8久久精品久久久久久蜜| 亚洲一区在线观看免费| 3751色影院一区二区三区| 久久99九九99精品| 欧美经典一区二区| 欧美网站一区二区| 精久久久久久久久久久| 欧美韩国日本综合| 欧美在线视频不卡| 精品一区二区三区免费观看| 国产精品国产三级国产| 在线国产电影不卡| 蜜桃久久久久久| 国产精品乱子久久久久| 欧美日韩国产精品成人| 激情欧美日韩一区二区| 亚洲视频图片小说| 日韩欧美的一区| 97超碰欧美中文字幕| 日韩成人免费电影| 亚洲图片欧美激情| 精品国产伦一区二区三区观看方式 | 成人av小说网| 日韩av一区二| 国产精品久久久久9999吃药| 91麻豆精品国产自产在线观看一区| 国产精品资源网| 日韩精品久久久久久| 国产精品毛片久久久久久| 欧美一级二级三级蜜桃| 在线免费不卡视频| 国产一区二区三区国产| 天天色天天操综合| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 宅男噜噜噜66一区二区66| 日本高清不卡aⅴ免费网站| 精品一区二区三区蜜桃| 午夜欧美在线一二页| 国产精品的网站| 欧美激情综合在线| 欧美不卡激情三级在线观看| 欧美无人高清视频在线观看| 成人性生交大片免费看视频在线| 久久超碰97中文字幕| 青青草视频一区| 亚洲综合网站在线观看| 亚洲三级在线看| 成人免费在线视频观看| 欧美高清在线精品一区| 久久久国产一区二区三区四区小说 | 午夜精品视频在线观看| **欧美大码日韩| 中文av字幕一区| 国产亚洲一二三区| 久久精品视频在线看| 精品蜜桃在线看| 26uuu亚洲综合色欧美| 精品久久人人做人人爰| 欧美成va人片在线观看| 日韩欧美中文字幕一区| 欧美大白屁股肥臀xxxxxx| 欧美猛男超大videosgay| 欧美日韩一二区| 91精品国产美女浴室洗澡无遮挡| 欧美另类变人与禽xxxxx| 欧美肥妇毛茸茸| 欧美大片国产精品| 久久久亚洲综合| 国产精品毛片a∨一区二区三区| 中文字幕精品—区二区四季| 午夜欧美2019年伦理| 亚洲色图视频网| 偷拍与自拍一区| 狠狠色综合日日| 99在线精品视频| 欧美影院午夜播放| 日韩一区二区视频在线观看| 欧美大片免费久久精品三p| 久久久精品免费免费| 1024国产精品| 亚洲一区二区三区自拍| 免费精品视频在线| 成人午夜激情在线| 欧洲亚洲国产日韩| 欧美一级午夜免费电影| 欧美国产一区视频在线观看| 一区二区三区日韩在线观看| 丝瓜av网站精品一区二区| 国产精品亚洲一区二区三区妖精 | 99久久精品国产一区二区三区| 色8久久人人97超碰香蕉987| 91麻豆精品国产91久久久更新时间 | 欧美一区午夜视频在线观看 | 色综合久久综合网欧美综合网| 欧美日韩国产a| 中文字幕精品一区二区三区精品 | 国产91精品欧美| 在线亚洲人成电影网站色www| 日韩精品最新网址| 中文字幕一区二区日韩精品绯色| 亚洲bdsm女犯bdsm网站| 国产呦精品一区二区三区网站| 色综合久久综合中文综合网| ww久久中文字幕| 亚洲6080在线| 91在线国产福利| 精品久久久久久综合日本欧美| 中文字幕在线视频一区| 久久精品国产99国产| 日本大香伊一区二区三区| 久久久久久久网| 美女一区二区视频| 欧美视频一区二区| 亚洲美女在线一区| av资源站一区| 国产片一区二区| 精品制服美女丁香|