国产秋霞理论久久久电影-婷婷色九月综合激情丁香-欧美在线观看乱妇视频-精品国avA久久久久久久-国产乱码精品一区二区三区亚洲人-欧美熟妇一区二区三区蜜桃视频

上億數(shù)據(jù)如何秒查(附源碼)

共 565字,需瀏覽 2分鐘

 ·

2020-09-15 20:21

點擊上方[全棧開發(fā)者社區(qū)]右上角[...][設為星標?]

作者:blog.csdn.net/chenleixing/article/details/44994571

最近在忙著優(yōu)化集團公司的一個報表。優(yōu)化完成后,報表查詢速度有從半小時以上(甚至查不出)到秒查的質(zhì)變。從修改SQL查詢語句邏輯到?jīng)Q定創(chuàng)建存儲過程實現(xiàn),花了我3天多的時間,在此總結一下,希望對朋友們有幫助。

數(shù)據(jù)背景

首先項目是西門子中國在我司實施部署的MES項目,由于項目是在產(chǎn)線上運作(3 years+),數(shù)據(jù)累積很大。在項目的數(shù)據(jù)庫中,大概上億條數(shù)據(jù)的表有5個以上,千萬級數(shù)據(jù)的表10個以上,百萬級數(shù)據(jù)的表,很多…

(歷史問題,當初實施無人監(jiān)管,無人監(jiān)控數(shù)據(jù)庫這塊的性能問題。ps:我剛?cè)肼毑痪谩?

不多說,直接貼西門子中國的開發(fā)人員在我司開發(fā)的SSRS報表中的SQL語句:

select?distinct?b.MaterialID?as?matl_def_id,?c.Descript,?case?when?right(b.MESOrderID,?12)?'001000000000'?then?right(b.MESOrderID,?9)??
else?right(b.MESOrderID,?12)?end??as?pom_order_id,?a.LotName,?a.SourceLotName?as?ComLot,?
e.DefID?as?ComMaterials,?e.Descript?as?ComMatDes,?d.VendorID,?d.DateCode,d.SNNote,?b.OnPlantID,a.SNCUST
from??
(
????select?m.lotname,?m.sourcelotname,?m.opetypeid,?m.OperationDate,n.SNCUST?from?View1?m
????left?join?co_sn_link_customer?as?n?on?n.SNMes=m.LotName
????where?
????(?m.LotName?in?(select?val?from?fn_String_To_Table(@sn,',',1))?or?(@sn)?=?'')?and?
????(?m.sourcelotname?in?(select?val?from?fn_String_To_Table(@BatchID,',',1))?or?(@BatchID)?=?'')
????and?(n.SNCust?like?'%'+?@SN_ext?+?'%'?or?(@SN_ext)='')
)?a
left?join?
(
????select?*?from?Table1?where?SNType?=?'IntSN'
????and?SNRuleName?=?'ProductSNRule'
????and?OnPlantID=@OnPlant
)?b?on?b.SN?=?a.LotName
inner?join?MMdefinitions?as?c?on?c.DefID?=?b.MaterialID
left?join??Table1?as?d?on?d.SN?=?a.SourceLotName?
inner?join?MMDefinitions?as?e?on?e.DefID?=?d.MaterialID
where?not?exists?(
?select?distinct?LotName,?SourceLotName?from?ELCV_ASSEMBLE_OPS?
where?LotName?=?a.SourceLotName?and?SourceLotName?=?a.LotName
)?
and?(d.DateCode?in?(select?val?from?fn_String_To_Table(@DCode,',',1))?or?(@DCode)?=?'')
and?(d.SNNote??like?'%'+@SNNote+'%'?or?(@SNNote)?=?'')
and?((case?when?right(b.MESOrderID,?12)?'001000000000'?then?right(b.MESOrderID,?9)??
else?right(b.MESOrderID,?12)?end)?in?(select?val?from?fn_String_To_Table(@order_id,',',1))?or?(@order_id)?=?'')
and?(e.DefID?in?(select?val?from?fn_String_To_Table(@comdef,',',1))?or?(@comdef)?=?'')
--View1是一個嵌套兩層的視圖(出于保密性,實際名稱可能不同),里面有一張上億數(shù)據(jù)的表和幾張千萬級數(shù)據(jù)的表做左連接查詢
--Table1是一個數(shù)據(jù)記錄超過1500萬的表

這個查詢語句,實際上通過我的檢測和調(diào)查,在B/S系統(tǒng)前端已無法查出結果,半小時,一小時 … 。因為我直接在SQL查詢分析器查,半小時都沒有結果。

(原因是里面對一張上億級數(shù)據(jù)表和3張千萬級數(shù)據(jù)表做全表掃描查詢)

不由感慨,西門子中國的素質(zhì)(或者說責任感)就這樣?

下面說說我的分析和走的彎路(思維誤區(qū)),希望對你也有警醒。

探索和誤區(qū)

首先相關表的索引,沒有建全的,把索引給建上。

索引這步完成后,發(fā)現(xiàn)情況還是一樣,查詢速度幾乎沒有改善。后來想起相關千萬級數(shù)據(jù)以上的表,都還沒有建立表分區(qū)。于是考慮建立表分區(qū)以及數(shù)據(jù)復制的方案。

這里有必要說明下:我司報表用的是一個專門的數(shù)據(jù)庫服務器,數(shù)據(jù)從產(chǎn)線訂閱而來。就是常說的“讀寫分離”。

如果直接在原表上建立表分區(qū),你會發(fā)現(xiàn)執(zhí)行表分區(qū)的事物會直接死鎖。原因是:表分區(qū)操作本身會鎖表,產(chǎn)線還在推數(shù)據(jù)過來,這樣很容易“阻塞”,“死鎖”。

我想好的方案是:建立一個新表(空表),在新表上建好表分區(qū),然后復制數(shù)據(jù)過來。

正打算這么干。等等!我好像進入了一個嚴重的誤區(qū)!

分析:原SQL語句和業(yè)務需求,是對產(chǎn)線的數(shù)據(jù)做產(chǎn)品以及序列號的追溯,關鍵是查詢條件里沒有有規(guī)律的”條件”(如日期、編號),

貿(mào)然做了表分區(qū),在這里幾乎沒有意義!反而會降低查詢性能!

好險!還是一步一步來,先做SQL語句分析。

一. 對原SQL語句的分析

  • 查詢語句的where條件,有大量@var in … or (@var =”) 的片段

  • where條件有l(wèi)ike ‘%’+@var+’%’

  • where條件有 case … end 函數(shù)

  • 多次連接同一表查詢,另外使用本身已嵌套的視圖表,是不是必須,是否可替代?

  • SQL語句有號,視圖中也有號出現(xiàn)

二. 優(yōu)化設計

首先是用存儲過程改寫,好處是設計靈活。

核心思想是:用一個或多個查詢條件(查詢條件要求至少輸入一個)得到臨時表,每個查詢條件如果查到集合,就更新這張臨時表,最后匯總的時候,只需判斷這個臨時表是否有值。以此類推,可以建立多個臨時表,將查詢條件匯總。

這樣做目前來看至少兩點好處:

  1. 省去了對變量進行 =@var or (@var=”)的判斷;

  2. 拋棄sql拼接,提高代碼可讀性。

再有就是在書寫存儲過程,這個過程中要注意:

  1. 盡量想辦法使用臨時表掃描替代全表掃描;

  2. 拋棄in和not in語句,使用exists和not exists替代;

  3. 和客戶確認,模糊查詢是否有必要,如沒有必要,去掉like語句;

  4. 注意建立適當?shù)模蠄鼍暗乃饕?/p>

  5. 踩死 “*” 號;

  6. 避免在where條件中對字段進行函數(shù)操作;

  7. 對實時性要求不高的報表,允許臟讀(with(nolock))。

三. 存儲過程

如果想?yún)⒖純?yōu)化設計片段的詳細內(nèi)容,請參閱SQL代碼:

/**
?*?某某跟蹤報表
?**/

--exec?spName1?'','','','','','','公司代號'
CREATE?Procedure?spName1
???@MESOrderID?nvarchar(320),?--工單號,最多30個
???@LotName?nvarchar(700),????--產(chǎn)品序列號,最多50個
???@DateCode?nvarchar(500),???--供應商批次號,最多30個
???@BatchID?nvarchar(700),????--組裝件序列號/物料批號,最多50個
???@comdef?nvarchar(700),?????--組裝件物料編碼,最多30個
???@SNCust?nvarchar(1600),????--外部序列號,最多50個
???@OnPlant?nvarchar(20)??????--平臺
AS
BEGIN
????SET?NOCOUNT?ON;??
????/**
?????*?1)定義全局的臨時表,先根據(jù)六個查詢條件的任意一個,得出臨時表結果
?????**/

????CREATE?TABLE?#FinalLotName
????(
????????LotName?NVARCHAR(50),???????--序列號
????????SourceLotName?NVARCHAR(50),?--來源序列號
????????SNCust?NVARCHAR(128)????????--外部序列號
????)
????--1.1
????IF?@LotName<>''
????BEGIN
????????SELECT?Val?INTO?#WorkLot?FROM?fn_String_To_Table(@LotName,',',1)
????????SELECT?LotPK,LotName?INTO?#WorkLotPK?FROM?MMLots?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkLot?b?WHERE?b.Val=MMLots.LotID)

????????--求SourceLotPK只能在這里求
????????SELECT?a.LotPK,a.SourceLotPK?into?#WorkSourcePK?FROM?MMLotOperations?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkLotPK?b?WHERE?b.LotPK=a.LotPK)?AND?a.SourceLotPK?IS?NOT?NULL

????????SELECT?a.LotPK,a.SourceLotPK,b.LotName?INTO?#WorkSourcePK2?FROM?#WorkSourcePK?a?JOIN?#WorkLotPK?b?ON?a.LotPK=b.LotPK

????????INSERT?INTO?#FinalLotName?SELECT?a.LotName,b.LotName?AS?SourceLotName,NULL?FROM?#WorkSourcePK2?a?JOIN?(SELECT?LotPK,LotName?FROM?MMLots?WITH(NOLOCK)?)?b?on?a.SourceLotPK=b.LotPK?--b的里面加不加WHERE?RowDeleted=0待確定
????????SELECT?a.LotName,a.SourceLotName,b.SNCust?INTO?#FinalLotNameX1?FROM?#FinalLotName?a?LEFT?JOIN?CO_SN_LINK_CUSTOMER?b?WITH(NOLOCK)?ON?a.LotName=b.SNMes
????????DELETE?FROM?#FinalLotName
????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#FinalLotNameX1
????END
????--1.2
????IF?@BatchID<>''
????BEGIN
????????SELECT?Val?INTO?#WorkSourceLot?FROM?fn_String_To_Table(@BatchID,',',1)
????????IF?EXISTS(SELECT?1?FROM?#FinalLotName)--如果@LotName也不為空
????????BEGIN
????????????SELECT?a.LotName,a.SourceLotName,a.SNCust?INTO?#FinalLotNameX2?FROM?#FinalLotName?a?WHERE?EXISTS(SELECT?1?FROM?#WorkSourceLot?b?WHERE?a.SourceLotName=b.Val)
????????????DELETE?FROM?#FinalLotName
????????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#FinalLotNameX2
????????END
????????ELSE?--@LotName條件為空
????????BEGIN
????????????SELECT?LotPK?AS?SourceLotPK,LotName?AS?SourceLotName?INTO?#2?FROM?MMLots?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkSourceLot?b?WHERE?b.Val=MMLots.LotID)
????????????SELECT?a.LotPK,a.SourceLotPK?into?#21?FROM?MMLotOperations?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#2?b?WHERE?b.SourceLotPK=a.SourceLotPK)
????????????SELECT?a.LotPK,a.SourceLotPK,b.SourceLotName?INTO?#22?FROM?#21?a?JOIN?#2?b?ON?a.SourceLotPK=b.SourceLotPK????
????????????INSERT?INTO?#FinalLotName?SELECT?b.LotName,a.SourceLotName,NULL?FROM?#22?a?JOIN?(SELECT?LotPK,LotName?FROM?MMLots?WITH(NOLOCK)?)?b?on?a.LotPK=b.LotPK?--b的里面加不加WHERE?RowDeleted=0待確定????
????????????SELECT?a.LotName,a.SourceLotName,b.SNCust?INTO?#FinalLotNameX21?FROM?#FinalLotName?a?LEFT?JOIN?CO_SN_LINK_CUSTOMER?b?WITH(NOLOCK)?ON?a.LotName=b.SNMes
????????????DELETE?FROM?#FinalLotName
????????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#FinalLotNameX21????????
????????END
????END
????--1.3
????IF?@SNCust<>''
????BEGIN
????????SELECT?Val?INTO?#WorkCustomSN?FROM?fn_String_To_Table(@SNCust,',',1)
????????IF?EXISTS(SELECT?1?FROM?#FinalLotName)--前面兩個條件至少有一個有值
????????BEGIN
????????????SELECT?a.LotName,a.SourceLotName,a.SNCust?INTO?#FinalLotNameX3?FROM?#FinalLotName?a?WHERE?EXISTS(SELECT?1?FROM?#WorkCustomSN?b?WHERE?a.SNCust=b.Val)
????????????DELETE?FROM?#FinalLotName?
????????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#FinalLotNameX3
????????END
????????ELSE
????????BEGIN
????????????SELECT?a.SNMes?INTO?#WorkLotX?FROM?CO_SN_LINK_CUSTOMER?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkCustomSN?b?WHERE?a.SNCust=b.Val)
????????????-------------------以下邏輯和變量1(@LotName)類似[先根據(jù)外部序列號求解序列號,再照搬第一個判斷變量的方式]
????????????SELECT?LotPK,LotName?INTO?#WorkLotPKX?FROM?MMLots?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkLotX?b?WHERE?b.SNMes=MMLots.LotID)

????????????--求SourceLotPK只能在這里求
????????????SELECT?a.LotPK,a.SourceLotPK?into?#WorkSourcePKX?FROM?MMLotOperations?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkLotPKX?b?WHERE?b.LotPK=a.LotPK)?AND?a.SourceLotPK?IS?NOT?NULL

????????????SELECT?a.LotPK,a.SourceLotPK,b.LotName?INTO?#WorkSourcePK2X?FROM?#WorkSourcePKX?a?JOIN?#WorkLotPKX?b?ON?a.LotPK=b.LotPK

????????????INSERT?INTO?#FinalLotName?SELECT?a.LotName,b.LotName?AS?SourceLotName,NULL?FROM?#WorkSourcePK2X?a?JOIN?(SELECT?LotPK,LotName?FROM?MMLots?WITH(NOLOCK)?)?b?on?a.SourceLotPK=b.LotPK?--b的里面加不加WHERE?RowDeleted=0待確定
????????????SELECT?a.LotName,a.SourceLotName,b.SNCust?INTO?#FinalLotNameX31?FROM?#FinalLotName?a?LEFT?JOIN?CO_SN_LINK_CUSTOMER?b?WITH(NOLOCK)?ON?a.LotName=b.SNMes
????????????DELETE?FROM?#FinalLotName
????????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#FinalLotNameX31
????????????-----------------------
????????END
????END

????/**
?????* 2)定義全局的臨時表,用于替換第一個全局臨時表。
?????**/

????CREATE?TABLE?#FinalCO_SN
????(
????????SN?NVARCHAR(50),
????????SourceSN?NVARCHAR(50),
????????SNCust?NVARCHAR(128),
????????matl_def_id?NVARCHAR(50),--sn的物料ID
????????ComMaterials?NVARCHAR(50),??--SourceSN的物料ID
????????MESOrderID?NVARCHAR(20),
????????OnPlantID?NVARCHAR(20),
????????VendorID?NVARCHAR(20),
????????DateCode?NVARCHAR(20)?,
????????SNNote?NVARCHAR(512)
????)
????--2.1
????IF?@MESOrderID<>''
????BEGIN
????????-------------------------------將MESOrderID做特殊處理-----------------------------------
????????SELECT?Val?INTO?#WorkMESOrderID?FROM?fn_String_To_Table(@MESOrderID,',',1)
????????IF?@OnPlant='Comba'
????????BEGIN
????????????UPDATE?#WorkMESOrderID?SET?Val='C000'+Val?WHERE?LEN(Val)=9
????????END
????????ELSE
????????BEGIN
????????????UPDATE?#WorkMESOrderID?SET?Val='W000'+Val?WHERE?LEN(Val)=9
????????END
????????SELECT?SN,MaterialID,MESOrderID,OnPlantID?INTO?#WorkCO_SN1?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)
????????WHERE?SNType='IntSN'?AND?SNRuleName?=?'ProductSNRule'?AND?OnPlantID=@OnPlant
????????AND?EXISTS(SELECT?1?FROM?#WorkMESOrderID?b?WHERE?a.MESOrderID=b.Val)
????????------------------------------------------------------------------------------------------
????????--條件判斷(邏輯分析)開始
????????IF?EXISTS(SELECT?1?FROM?#FinalLotName)--如果前面判斷的查詢條件有值
????????BEGIN
????????????--查出SourceLotName對應的查詢字段
????????????SELECT?a.SN?AS?SourceLotName,a.VendorID,a.DateCode,a.SNNote,a.MaterialID?AS?ComMaterials?INTO?#SourceLotNameTable?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.SourceLotName)

????????????INSERT?INTO?#FinalCO_SN
????????????SELECT?a.LotName,a.SourceLotName,d.SNCust,b.MaterialID,c.ComMaterials,b.MESOrderID,b.OnPlantID,c.VendorID,c.DateCode,c.SNNote?FROM?#FinalLotName?a?
????????????LEFT?JOIN?#WorkCO_SN1?b?ON?a.LotName=b.SN
????????????LEFT?JOIN?#SourceLotNameTable?c?ON?a.SourceLotName=c.SourceLotName
????????????LEFT?JOIN?CO_SN_LINK_CUSTOMER?d?WITH(NOLOCK)?ON?a.LotName=d.SNMes
????????END
????????ELSE
????????BEGIN
????????????--已知SN集合求解對應的SourceSN和SNCust集合------------------------------------------
????????????SELECT?LotPK,LotName?INTO?#WorkLotPK410?FROM?MMLots?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkCO_SN1?b?WHERE?b.SN=MMLots.LotID)
????????????SELECT?a.LotPK,a.SourceLotPK?into?#WorkSourcePK420?FROM?MMLotOperations?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkLotPK410?b?WHERE?b.LotPK=a.LotPK)?AND?a.SourceLotPK?IS?NOT?NULL
????????????SELECT?a.LotPK,a.SourceLotPK,b.LotName?INTO?#WorkSourcePK430?FROM?#WorkSourcePK420?a?JOIN?#WorkLotPK410?b?ON?a.LotPK=b.LotPK
????????????INSERT?INTO?#FinalLotName?SELECT?a.LotName,b.LotName?AS?SourceLotName,NULL?FROM?#WorkSourcePK430?a?JOIN?(SELECT?LotPK,LotName?FROM?MMLots?WITH(NOLOCK)?)?b?on?a.SourceLotPK=b.LotPK?--b的里面加不加WHERE?RowDeleted=0待確定

????????????SELECT?a.LotName,a.SourceLotName,b.SNCust?INTO?#FinalLotNameX440?FROM?#FinalLotName?a?LEFT?JOIN?CO_SN_LINK_CUSTOMER?b?WITH(NOLOCK)?ON?a.LotName=b.SNMes
????????????DELETE?FROM?#FinalLotName
????????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#FinalLotNameX440
????????????-------------------------------------------------------------------------------------
????????????SELECT?a.SN?AS?SourceLotName,a.VendorID,a.DateCode,a.SNNote,a.MaterialID?AS?ComMaterials?INTO?#SourceLotNameTable2?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.SourceLotName)

????????????INSERT?INTO?#FinalCO_SN
????????????SELECT?a.LotName,a.SourceLotName,a.SNCust,b.MaterialID,c.ComMaterials,b.MESOrderID,b.OnPlantID,c.VendorID,c.DateCode,c.SNNote?FROM?#FinalLotName?a?
????????????LEFT?JOIN?#WorkCO_SN1?b?ON?a.LotName=b.SN
????????????LEFT?JOIN?#SourceLotNameTable2?c?ON?a.SourceLotName=c.SourceLotName
????????END????
????END
????--2.2
????IF?@DateCode<>''
????BEGIN
????????SELECT?Val?INTO?#WorkDateCode?FROM?fn_String_To_Table(@DateCode,',',1)
????????--此@DataCode條件求解出來的是SourceSN
????????SELECT?SN?AS?SourceSN,MaterialID?AS?ComMaterials,VendorID,DateCode,SNNote?INTO?#WorkSourceSNT1?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkDateCode?b?WHERE?a.DateCode=b.Val)
????????----------------------------------------------------------------------------------------------------
????????--條件判斷(邏輯分析)開始
????????IF?EXISTS(SELECT?1?FROM?#FinalCO_SN)--如果前面判斷的查詢條件有值
????????BEGIN
????????????SELECT?a.LotName,a.SourceLotName,a.SNCust,a.MaterialID,a.ComMaterials,a.MESOrderID,a.OnPlantID,a.VendorID,a.DateCode,a.SNNote?INTO?#TMP51?FROM?#FinalCO_SN?a?WHERE?EXISTS?(SELECT?1?FROM?#WorkDateCode?b?WHERE?a.DateCode=b.Val)
????????????DELETE?FROM?#FinalCO_SN
????????????INSERT?INTO?#FinalCO_SN?SELECT?LotName,SourceLotName,SNCust,MaterialID,ComMaterials,MESOrderID,OnPlantID,VendorID,DateCode,SNNote?FROM?#TMP51
????????END
????????ELSE
????????BEGIN
????????????IF?EXISTS(SELECT?1?FROM?#FinalLotName)
????????????BEGIN
????????????--查出SourceLotName對應的查詢字段
????????????SELECT?a.SourceSN,a.VendorID,a.DateCode,a.SNNote,a.ComMaterials?INTO?#SourceLTX5?FROM?#WorkSourceSNT1?a?WHERE?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SourceSN=b.SourceLotName)
????????????--查出SN對應的查詢字段
????????????SELECT?SN,MaterialID,MESOrderID,OnPlantID?INTO?#WorkSNT510?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)
????????????WHERE?SNType='IntSN'?AND?SNRuleName?=?'ProductSNRule'?AND?OnPlantID=@OnPlant
????????????AND?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.LotName)

????????????INSERT?INTO?#FinalCO_SN
????????????SELECT?a.LotName,a.SourceLotName,d.SNCust,b.MaterialID,c.ComMaterials,b.MESOrderID,b.OnPlantID,c.VendorID,c.DateCode,c.SNNote?FROM?#FinalLotName?a?
????????????LEFT?JOIN?#WorkSNT510?b?ON?a.LotName=b.SN
????????????LEFT?JOIN?#WorkSourceSNT1?c?ON?a.SourceLotName=c.SourceSN
????????????LEFT?JOIN?CO_SN_LINK_CUSTOMER?d?WITH(NOLOCK)?ON?a.LotName=d.SNMes

????????????END
????????????ELSE
????????????BEGIN
????????????????--已知SourceSN集合求解對應的SN和SNCust集合------------------------------------------
????????????????SELECT?LotPK?AS?SourceLotPK,LotName?AS?SrouceLotName?INTO?#WorkLotX510?FROM?MMLots?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkSourceSNT1?b?WHERE?b.SourceSN=MMLots.LotID)
????????????????SELECT?a.LotPK,a.SourceLotPK?into?#WorkLotX520?FROM?MMLotOperations?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkLotX510?b?WHERE?b.SourceLotPK=a.SourceLotPK)
????????????????SELECT?a.LotPK,a.SourceLotPK,b.SrouceLotName?INTO?#WorkLotX530?FROM?#WorkLotX520?a?JOIN?#WorkLotX510?b?ON?a.SourceLotPK=b.SourceLotPK

????????????????INSERT?INTO?#FinalLotName?SELECT?b.LotName,a.SrouceLotName,NULL?FROM?#WorkLotX530?a?JOIN?(SELECT?LotPK,LotName?FROM?MMLots?WITH(NOLOCK)?)?b?on?a.LotPK=b.LotPK?--b的里面加不加WHERE?RowDeleted=0待確定

????????????????SELECT?a.LotName,a.SourceLotName,b.SNCust?INTO?#WorkLotX540?FROM?#FinalLotName?a?LEFT?JOIN?CO_SN_LINK_CUSTOMER?b?WITH(NOLOCK)?ON?a.LotName=b.SNMes
????????????????DELETE?FROM?#FinalLotName
????????????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#WorkLotX540
????????????????-------------------------------------------------------------------------------------
????????????????SELECT?SN,MaterialID,MESOrderID,OnPlantID?INTO?#WorkLotX550?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)
????????????????WHERE?SNType='IntSN'?AND?SNRuleName?=?'ProductSNRule'?AND?OnPlantID=@OnPlant
????????????????AND?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.LotName)

????????????????INSERT?INTO?#FinalCO_SN
????????????????SELECT?a.LotName,a.SourceLotName,a.SNCust,b.MaterialID,c.ComMaterials,b.MESOrderID,b.OnPlantID,c.VendorID,c.DateCode,c.SNNote?FROM?#FinalLotName?a?
????????????????LEFT?JOIN?#WorkLotX550?b?ON?a.LotName=b.SN
????????????????LEFT?JOIN?#WorkSourceSNT1?c?ON?a.SourceLotName=c.SourceSN
????????????END
????????END
????END
????--2.3
????IF?@comdef<>''
????BEGIN
????????SELECT?Val?INTO?#WorkComdef?FROM?fn_String_To_Table(@comdef,',',1)
????????--此@comdef條件求解出來的是SourceSN
????????SELECT?SN?AS?SourceSN,MaterialID?AS?ComMaterials,VendorID,DateCode,SNNote?INTO?#WorkSourceSNT16?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkComdef?b?WHERE?a.MaterialID=b.Val)
????????----------------------------------------------------------------------------------------------------
????????--條件判斷(邏輯分析)開始
????????IF?EXISTS(SELECT?1?FROM?#FinalCO_SN)--如果前面判斷的查詢條件有值
????????BEGIN
????????????SELECT?a.LotName,a.SourceLotName,a.SNCust,a.MaterialID,a.ComMaterials,a.MESOrderID,a.OnPlantID,a.VendorID,a.DateCode,a.SNNote?INTO?#TMP516?FROM?#FinalCO_SN?a?WHERE?EXISTS?(SELECT?1?FROM?#WorkComdef?b?WHERE?a.matl_def_id=b.Val)
????????????DELETE?FROM?#FinalCO_SN
????????????INSERT?INTO?#FinalCO_SN?SELECT?LotName,SourceLotName,SNCust,MaterialID,ComMaterials,MESOrderID,OnPlantID,VendorID,DateCode,SNNote?FROM?#TMP516
????????END
????????ELSE
????????BEGIN
????????????IF?EXISTS(SELECT?1?FROM?#FinalLotName)
????????????BEGIN
????????????--查出SourceLotName對應的查詢字段
????????????SELECT?a.SourceSN,a.VendorID,a.DateCode,a.SNNote,a.ComMaterials?INTO?#SourceLTX56?FROM?#WorkSourceSNT16?a?WHERE?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SourceSN=b.SourceLotName)
????????????--查出SN對應的查詢字段
????????????SELECT?SN,MaterialID,MESOrderID,OnPlantID?INTO?#WorkSNT5106?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)
????????????WHERE?SNType='IntSN'?AND?SNRuleName?=?'ProductSNRule'?AND?OnPlantID=@OnPlant
????????????AND?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.LotName)

????????????INSERT?INTO?#FinalCO_SN
????????????SELECT?a.LotName,a.SourceLotName,d.SNCust,b.MaterialID,c.ComMaterials,b.MESOrderID,b.OnPlantID,c.VendorID,c.DateCode,c.SNNote?FROM?#FinalLotName?a?
????????????LEFT?JOIN?#WorkSNT5106?b?ON?a.LotName=b.SN
????????????LEFT?JOIN?#WorkSourceSNT16?c?ON?a.SourceLotName=c.SourceSN
????????????LEFT?JOIN?CO_SN_LINK_CUSTOMER?d?WITH(NOLOCK)?ON?a.LotName=d.SNMes

????????????END
????????????ELSE
????????????BEGIN
????????????????--已知SourceSN集合求解對應的SN和SNCust集合------------------------------------------
????????????????SELECT?LotPK?AS?SourceLotPK,LotName?AS?SrouceLotName?INTO?#WorkLotX5106?FROM?MMLots?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkSourceSNT16?b?WHERE?b.SourceSN=MMLots.LotID)
????????????????SELECT?a.LotPK,a.SourceLotPK?into?#WorkLotX5206?FROM?MMLotOperations?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#WorkLotX5106?b?WHERE?b.SourceLotPK=a.SourceLotPK)
????????????????SELECT?a.LotPK,a.SourceLotPK,b.SrouceLotName?INTO?#WorkLotX5306?FROM?#WorkLotX5206?a?JOIN?#WorkLotX5106?b?ON?a.SourceLotPK=b.SourceLotPK

????????????????INSERT?INTO?#FinalLotName?SELECT?b.LotName,a.SrouceLotName,NULL?FROM?#WorkLotX5306?a?JOIN?(SELECT?LotPK,LotName?FROM?MMLots?WITH(NOLOCK)?)?b?on?a.LotPK=b.LotPK?--b的里面加不加WHERE?RowDeleted=0待確定

????????????????SELECT?a.LotName,a.SourceLotName,b.SNCust?INTO?#WorkLotX5406?FROM?#FinalLotName?a?LEFT?JOIN?CO_SN_LINK_CUSTOMER?b?WITH(NOLOCK)?ON?a.LotName=b.SNMes
????????????????DELETE?FROM?#FinalLotName
????????????????INSERT?INTO?#FinalLotName?SELECT?LotName,SourceLotName,SNCust?FROM?#WorkLotX5406
????????????????-------------------------------------------------------------------------------------
????????????????SELECT?SN,MaterialID,MESOrderID,OnPlantID?INTO?#WorkLotX5506?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)
????????????????WHERE?SNType='IntSN'?AND?SNRuleName?=?'ProductSNRule'?AND?OnPlantID=@OnPlant
????????????????AND?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.LotName)

????????????????INSERT?INTO?#FinalCO_SN
????????????????SELECT?a.LotName,a.SourceLotName,a.SNCust,b.MaterialID,c.ComMaterials,b.MESOrderID,b.OnPlantID,c.VendorID,c.DateCode,c.SNNote?FROM?#FinalLotName?a?
????????????????LEFT?JOIN?#WorkLotX5506?b?ON?a.LotName=b.SN
????????????????LEFT?JOIN?#WorkSourceSNT16?c?ON?a.SourceLotName=c.SourceSN
????????????END
????????END
????END

????/**
?????*?3)條件判斷結束
?????**/

????IF?EXISTS(SELECT?1?FROM?#FinalLotName)
????BEGIN
????????IF?EXISTS(SELECT?1?FROM?#FinalCO_SN)
????????BEGIN--3.1
????????????SELECT?a.matl_def_id,b.Descript,a.MESOrderID?AS?pom_order_id,a.SN?AS?LotName,a.SourceSN?AS?ComLot,
???????????????????a.ComMaterials,c.Descript?AS?ComMatDes,a.VendorID,a.DateCode,a.SNNote,
???????????????????OnPlantID,SNCust?FROM?#FinalCO_SN?a
???????????????????JOIN?MMDefinitions?b?WITH(NOLOCK)?ON?a.matl_def_id=b.DefID
???????????????????JOIN?MMDefinitions?c?WITH(NOLOCK)?ON?a.ComMaterials=c.DefID
????????????WHERE?NOT?EXISTS(select?distinct?SN,?SourceSN?from?#FinalCO_SN?x?
?????????????????????????????where?x.SN?=?a.SourceSN?and?x.SourceSN?=?a.SN)
????????END
????????ELSE
????????BEGIN--3.2
????????????--3.2.1求解SN的必查字段
????????????SELECT?SN,MaterialID,MESOrderID,OnPlantID?INTO?#FinalSNX1?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)
????????????WHERE?SNType='IntSN'?AND?SNRuleName?=?'ProductSNRule'?AND?OnPlantID=@OnPlant
????????????AND?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.LotName)
????????????--3.2.2求解SourceSN的必查字段
????????????SELECT?a.SN?AS?SourceLotName,a.VendorID,a.DateCode,a.SNNote,a.MaterialID?AS?ComMaterials?INTO?#FinalSNX2?FROM?CO_SN_GENERATION?a?WITH(NOLOCK)?WHERE?EXISTS(SELECT?1?FROM?#FinalLotName?b?WHERE?a.SN=b.SourceLotName)

????????????SELECT?b.MaterialID?AS?matl_def_id,x.Descript,b.MESOrderID?AS?pom_order_id,b.SN?AS?LotName,c.SourceLotName?AS?ComLot,c.ComMaterials,y.Descript?AS?ComMatDes,c.VendorID,c.DateCode,c.SNNote,b.OnPlantID,a.SNCust
????????????FROM?#FinalLotName?a
????????????LEFT?JOIN?#FinalSNX1?b?ON?a.LotName=b.SN
????????????LEFT?JOIN?#FinalSNX2?c?ON?a.SourceLotName=c.SourceLotName
????????????JOIN?MMDefinitions?x?WITH(NOLOCK)?ON?b.MaterialID=x.DefID
????????????JOIN?MMDefinitions?y?WITH(NOLOCK)?ON?c.ComMaterials=y.DefID
????????????WHERE?NOT?EXISTS(
????????????????SELECT?DISTINCT?*?FROM?#FinalLotName?z
????????????????WHERE?z.LotName=a.SourceLotName?and?z.SourceLotName=a.LotName
????????????)
????????END
????END
????ELSE
????BEGIN
????????IF?EXISTS(SELECT?1?FROM?#FinalCO_SN)
????????BEGIN--3.3
????????????SELECT?a.matl_def_id,b.Descript,a.MESOrderID?AS?pom_order_id,a.SN?AS?LotName,a.SourceSN?AS?ComLot,
???????????????????a.ComMaterials,c.Descript?AS?ComMatDes,a.VendorID,a.DateCode,a.SNNote,
???????????????????OnPlantID,SNCust?FROM?#FinalCO_SN?a
???????????????????JOIN?MMDefinitions?b?WITH(NOLOCK)?ON?a.matl_def_id=b.DefID
???????????????????JOIN?MMDefinitions?c?WITH(NOLOCK)?ON?a.ComMaterials=c.DefID
????????????WHERE?NOT?EXISTS(select?distinct?SN,?SourceSN?from?#FinalCO_SN?x?
?????????????????????????????where?x.SN?=?a.SourceSN?and?x.SourceSN?=?a.SN)
????????END
????????ELSE
????????BEGIN--3.4
????????????PRINT?'There?is?no?queryable?condition,please?enter?at?less?a?query?conditon.'
????????END
????END

END
GO

雖然犧牲了代碼的可讀性,但創(chuàng)造了性能價值。本人水平有限,還請各位不吝賜教!

最后,將SSRS報表替換成此存儲過程后,SQL查詢分析器是秒查的。B/S前端用時1~2秒!

四. 總結

平常的你是否偶爾會因急于完成任務而書寫一堆性能極低的SQL語句呢?寫出可靠性能的SQL語句不難,難的是習慣。

本文的優(yōu)化思想很簡單,關鍵點是避免全表掃描 & 注重SQL語句寫法 & 索引,另外,如果你查詢的表有可能會在查詢時段更新,而實際業(yè)務需求允許臟讀,可加with(nolock)預防查詢被更新事物阻塞。

覺得本文對你有幫助?請分享給更多人

關注「全棧開發(fā)者社區(qū)」加星標,提升全棧技能


本公眾號會不定期給大家發(fā)福利,包括送書、學習資源等,敬請期待吧!

如果感覺推送內(nèi)容不錯,不妨右下角點個在看轉(zhuǎn)發(fā)朋友圈或收藏,感謝支持。


好文章,留言、點贊、在看和分享一條龍吧??

瀏覽 40
點贊
評論
收藏
分享

手機掃一掃分享

分享
舉報
評論
圖片
表情
推薦
點贊
評論
收藏
分享

手機掃一掃分享

分享
舉報

感谢您访问我们的网站,您可能还对以下资源感兴趣:

国产秋霞理论久久久电影-婷婷色九月综合激情丁香-欧美在线观看乱妇视频-精品国avA久久久久久久-国产乱码精品一区二区三区亚洲人-欧美熟妇一区二区三区蜜桃视频 亚洲天堂2014| a片视频免费| 人妻无码91| 欧美草逼| 91国产视频在线观看| 91久久久久久久18| 中文字幕人成人乱| 亚洲欧美综合| 99在线观看免费视频| 亚洲成人AV无码| 成人性爱视频免费观看| 亚洲A片免费看| 91乱伦| A级网站| 日韩精品三级| 欧美亚洲日韩在线观看| 黑种人配中国少妇HD| 中国免费视频高清观看| 国产精品A片| 大香蕉尹在线| 黄片51| 欧美性生交18XXXXX无码| 亚洲一本色道中文无码| 男女嫩草视频| 黄色操逼网站| 超碰97人人操| 国产在线视频导航| 人人看人人摸人人草| 182AV| 久久人人做| 国产亚洲av| 国产成人精品在线| 久久久久久穴| 色欲影音| 国产1级a毛a毛1级a毛1级| 国产精品无码成人AV电影| 国产激情欧洲在线观看一区二区三区 | 国产成人女人在线观看| 九九热九九| www.人人操| 日韩成人AV在线| 日日搔av一区二区三区| 久久九九电影| 成年人免费网站| 人人操人人超碰| 99热免费| 欧美一级日韩一级| 人妻体内射精一区二区| 亚洲福利网站| 加勒比无码在线播放| 九草在线| 男人视频网站| 精品无码不卡| 亚洲插逼视频| 青娱乐亚洲精品视频| 国产成人在线视频| 久草成人| 日本成人中文字幕| 亚洲AV无码电影| 欧美黄色毛片| 特级西西444www大精品 | 探花AV| 谁有毛片网站| 国产内射网站| 另类老妇性BBwBBw图片| 被黑人操| 日韩极品在线观看| 色哟哟视频在线观看| 在线综合国产欧美| 久久丁香五月婷婷五月天激情视频| 黄色片在线看| 青娱乐自拍视频| 99成人国产精品视频| 免费无码一区| 日逼电影网| 91精品婷婷国产综合久久| 久久99久久99| 在线免费观看视频黄| 日韩一区二区三区无码| 国产小视频在线免费观看| 中文字幕在线视频无码| 亚洲色激情| av天天av无码av天天爽| 日韩成人黄色视频| 天堂网视频| 美女一级变态毛片| 蜜臀久久99精品久久久巴士| a片在线免费观看| 伊人大香蕉综合| 亚洲无码在线免费观看视频| 一道本一区| 黑人无码AV黑人天堂无码AV| 国产视频二区| 亚洲中文字幕影院| 99综合视频| 国产麻豆三级片| JULIA超乳JULIA无码| a片免费在线| 免费在线观看视频黄| 91丨九色丨熟女泻火| 麻豆精品国产传媒| 毛片日韩| 无码电影免费观看| 婷婷五月中文| 97国产精品视频人人做人人爱| 超碰黄片| 国产精品扒开腿做爽爽爽视频 | 操逼操逼操逼操逼操逼操逼| 天天日综合网| 2021狠狠操| 亚洲成人情趣大香蕉| 激情婷婷亚洲| 亚洲三级无码在线观看| 水果派解说AV无码一区| 国产精品伦子伦免费视频| 91精品国产综合久久久蜜臀粉嫩 | 一个人看的www日本高清视频| www.五月天.con| 北条麻妃三区| 波多野59部无码喷潮| 操日本女人逼| 亚洲无码色色| aaaaaa在线观看免费高清| 俄罗斯白嫩BBwBBwBBw91| 亚洲精品视频免费观看| av无码免费观看| 91福利视频在线观看| 黄色片在线观看视频| 亚洲激情五月| 91精品国产aⅴ一区二区| 成人无码区免费A片久久| 中文字幕日本在线| 无码人妻一区二区三区免费n鬼沢| 欧美v日韩| 亚洲免费一区二区| 操B视频在线观看| 免费一级a片| 51成人网站免费| 成人视频免费在线观看| 黄色国产视频| 亚州精品国产精品乱码不99勇敢| 婷婷激情五月综合| 最新激情网站| 中文字幕无码播放| 婷婷国产成人精品视频| av婷婷五月天| 国产视频第一页| 思思热在线观看视频| 俺也去啦WWW色官网| 一本色道久久88加勒比| 一级女婬片A片AAAA片| 亚洲最大成人网站| 尤物在线视频| 无码国产传媒精品一区| 国产一区二区免费在线观看| 少妇性受XXXX黑人XYX性爽 | 激情综合婷婷久久| 爱搞搞就要搞搞| 亚洲精品婷婷| 婷婷五月中文字幕| 麻豆一区二区| 色天使色天堂| 精品无码一区二区三区四区五区| av无码av天天av天天爽| 影音先锋男人你懂的| 蜜桃性爱视频| 国产伦精一品二品三品app| 免费乱伦视频| 国产熟女乱伦视频| 日韩AV免费| 日本高清一区二区高清免费视频| 色欲天天网| 成人做爱黄片| 国产日韩中文字幕| 亚洲一区欧美| 国产精品夜夜爽7777777| 国产在线观看一区二区| 欧美激情一区| 97无码| 在线观看AV91| 国产精品99久久免费黑人人妻| 成年片免费观看网站免费观看,亚洲+欧... | 亚洲人成无码| 激情五月天成人| 亚洲欧美在线视频| 亚洲天堂av在线免费观看 | 色婷婷国产精品视频| 一级性爽AV毛片| 日本欧美黄色| 西西特级无码444www| 九色PORNY国产成人蝌蚪| 五月天亭亭.com| 精品国产AV色一区二区深夜久久| 大香蕉亚洲在线| 黄色视频网站在线看| 成人无码区免费A片久久| 中文AV在线播放| 成人精品鲁一鲁一区二区| 亚洲伊人av| 国产欧美精品一区二区三区| 18啪啪网站| 亚久久| 免费黄色成人视频| 欧美日本国产| 婷婷五月天在线电影| 国产免费观看AV| 免费69视频看片| 操比网| 欧美一级特黄A片免费看视频小说 东北嫖老熟女一区二区视频网站 国产丨熟女丨国产熟女视频 | 久草视频网站| 亚洲综合社区在线| 国内自拍网站| 少妇av| 免费看操片| 黄片AAA| 淫乱人妻| 久久久久中文字幕| 人人爽人人做| www.久久久久| 国内精品无码| 人人干人人操人人爽| 国产精品做爱| 北条麻妃精品在线| 操人妻| 欧美黄网站| 久久精品v| 北条麻妃久久久| 国产夫妻自拍AV| 加勒比无码高清| 超碰在线91| 久久艹精品视频| 亚洲AV无码久久寂寞少妇多毛 | 狠狠操在线| 激情小视频国产在线播放| 午夜视频18| 美女福利视频| 亚洲av高清无码| 免费在线观看AV| 人人肏人人射| 99re6热在线精品视频| 天天日天天射天天操| 激情丁香五月| 中文字幕天天在线| 五月天婷婷激情视频| 91蝌蚪在线| 国产视频福利| 久久久久久久久久久久成人| 婷婷久久综合久| www.五月婷婷| 奶大丰满一乱一视频一区二区三区在 | 国产一级a毛一级a毛片视频黑人| AV中文无码| 亚洲黄色成人| 99在线免费观看| 学生妹作爱片| 五月天一区二区三区| 欧美一级免费观看| 天堂VA蜜桃一区二区三区| 久久久老熟女一区二区三区91| 欧亚免费视频| 日韩无码性爱| 黄色免费a级片一级片| av不卡在线观看| 日本99热| 国产无码高清| 日本在线不卡视频| 日韩不卡一区| 日日碰狠狠添| 久久中文字幕无码| 东北老女人操逼| 亚洲激情AV| 色av网| 一个人看的视频www| 在线免费观看一区| 俺来也官网欧美久久精品| 亚洲男人av| 国产麻豆三级片| 五月婷婷中文字幕| 欧美一区二区三区在线播放| 黄色免费在线观看| 日韩av在线免费观看| 亚洲无码你懂的| 91天堂在线| 国产精品操逼视频| 国产精品扒开腿| 在线观看黄视频| 91狠狠综合久久久| 大香蕉伊人电影| 一级特黄录像免费播放下载软件| 国产午夜无码福利视频| 中字幕视频在线永久在线观看免费 | 国产精品国三级国产a11| 一本一道久久a久久精品蜜桃| 国产精品操逼网站| 欧美内射网站| 黄色一级大片| 久操免费在线观看| 呦小BBBB小小BBBB| 国产清纯可爱美女自卫裸贷偷情 | 91精品福利| 久久久久久久久久久久成人| 一级黄色录像带| 国产免费一区二区三区四区六区在线| 91嫖妓站街埯店老熟女| 日韩一区在线视频| 国产日韩欧美综合精品在线观看| 69国产成人综合久久精品欧美| 在线观看无码高清| 乱伦99| 波多野结衣无码在线视频| 成人性爱网站| 大香蕉99热| 日韩a级毛片| 久久国产大奶| 日日99| 亚洲精品a| A视频免费在线观看| 一级二级三级无码| 亚洲综合伊人| 91天天看| 中文字幕在线观看免费高清完整版在线观看 | 99视频精品全部免费看| 免费操逼| 成人A∨| 久久久久成人片免费观看蜜芽| 国产在线内射| 日韩无码操逼视频| 乱伦无码高清麻豆视频一区二区| 大香蕉午夜视频| 天天色天天干天天日| 亚洲网站在线免费观看| 无码黄片免费| 国产操女人| 久久久成人免费视频| 色婷婷综合网| 国产成人亚洲精品| 成人无码区免费AV片| 嫩草久久| 免费无码婬片AAAA片直播| 国产成人女人在线观看| 91精品在线观看视频| 91精品国久久久久久无码一区二区三区| xxxx色| 色噜| 九九九九精品| 一级黄色生活片| 欧洲一级片| 成人免费爱爱视频| 久久女人视频| 日韩中文字幕区| 乖我硬了让老子cao你小视频| 日韩中文字| 亚洲精品一二三| 久久精品在线| 久热亚洲| 成人做爰黄A片免费看三区蜜臀 | 92久久| 大香蕉精品欧美色综合2025 | 国产精品永久| 91视频免费在线看| 99热国产免费| 国产青草视频在线观看| 天天干天天日天天色| 摸BBB槡BBBB搡BBB,,,,,| 特级婬片AAAAAAA级| 天堂精品在线| 久草手机视频在线观看| 欧美日韩男女淫乱一区二区| 亚洲综合在线观看视频| h片在线观看| 亚洲另类自拍| 99精品视频在线观看| 天天日天天操天天摸天天干天日射天天插| 毛片毛片毛片| 午夜福利视频网站| A片免费在线观看| 97国产在线观看| 99热9| 国产久久在线观看| 欧美日韩免费在线播放电影在线播放电影在线播放电影免费 | 少妇免费视频| 成人性爱视频网| 亚洲无码激情| 亚洲精品一区二区三区四区五区六区 | 4438黄色| 亚洲无码电影在线| 国产欧美日韩视频| 福利一区二区| 无码精品成人观看A片| 欧美日韩狠狠操在线观看视频 | 黄色视频网站在线观看免费| 国产欧美精品一区二区三区 | 日本A片| 久久久久久免费毛片精品| 91九色丨国产丨爆乳| 一级特黄录像免费播放下载软件 | 日韩黄色大片| 日韩专区在线观看| AV在线资源| 欧美激情视频一区二区| 欧美精品久久久久久久久爆乳| 各国熟女HD合集| 久艹久| 91热在线| 亚洲黄色视频在线免费观看| 第一福利视频| av网站免费在线观看| 国产a级毛片| 99re6热在线精品视频| 免费一级无码婬片A片AAA毛片| JlZZJLZZ亚洲美女18| 可以看的三级网站| a视频免费在线观看| 一起操影院| 99热亚洲| 欧美日逼片| 伊人狼人香蕉| 无码伊人| 操B视频在线免费观看| eeuss一区| 国产成人精品免高潮在线观看| 欧美性爱小说| 青娱乐精品在线| 国产熟女一区二区久久| 国产精品1区2区| 久热中文在线观看精品视频| 国产美女精品| 成熟的国模冰莲[2]| 午夜福利高清在线观看| 69pao| 激情婷婷色五月| 99这里只有精品视频| 一区二区三区日本| 悠悠AV导航| 色婷婷AV一区二区三区之e本道| 日韩69| 中国熟妇XXXX18| 成人午夜| 男女啪网| 国产精品成人99一区无码| 国产主播一区二区| 操操操操操| 日韩啊v| 欧美黄色免费| 97操碰| 亚洲天堂国产| 特级丰满少妇免费观看| 亚洲无码大全| 日韩不卡视频在线观看| 天天操夜夜骑| 久草福利网| 亚洲三级片免费观看| 丰满欧美熟妇免费视频| 日韩不卡电影| 免费的一级A片| 一区二区三区四区免费| 大香蕉98| 99re6热在线精品视频功能| 国产熟妇婬乱A片免费看牛牛| 中文字幕国产在线观看| 色情欧美一级A片| 亚洲综合久| AV国产精品| 久久福利导航| 日韩毛片在线播放| 99视频+国产日韩欧美| 亚洲秘无码一区二区三区观看| 天天看片天天爽| 在线免费观看国产视频| 免费A级毛片在线播放不收费| 91精品国产一区二区| 久久久久人| 日韩无码激情| 国产精品高潮呻吟久久| 亚洲女人天堂AV| 全国最大成人网站| 中文字字幕在线中文| 亚洲综合免费观看高清完整版在线观 | 亚洲免费在线| 日本熟妇一区二区三区| 69人人| 欧美日本激情| 人人摸人人射| 欧美热热| 国产亚洲综合无码| 毛片国产| 婷婷五月六月丁香| 天天天做夜夜夜爽无码| 国产精品国产自产拍高清AV| 国产免费a| 久草国产在线视频| 成人免费毛片果冻日本| 亚洲av资源| 真人无码| 亚洲国产高清国产精品| av免费网站| 国产av一级片| 久久九九电影| 久久人人网| 国产性爱AV| 特级婬片A片AAA毛片AA做头 | 99久久久精品| 亚洲日韩在线a成| 91久久婷婷国产麻豆精品电影.co| 美女乱伦| 91精品视频网| 狠狠操狠狠色| 五月婷婷影院| 999国产精品| 蜜桃视频日韩| 日无码在线| 伊人大香蕉在线视频| 精品免费在线观看| 色播欧美| 欧美老妇日韩| 成人免费无码婬片在线| 日韩性爱小视频| 国产精品久久久久无码AV| 一级黄色在线观看| av中文在线观看| 东北老女人操逼视频| 成人免费视频网站| 精品无码一区二区人妻久久蜜桃 | 国产AV自拍-久| AA片免费网站| 精品一区二区三区视频| 色播视频在线观看| 美女视频黄a视频全免费不卡| 国产成人网| 国产AV无码成人精品区| 日韩逼逼| 宅男看片| 日韩精品视频在线| 中日韩无码| 欧美日韩在线看| 亚洲高清毛片一区二区| 久久婷视频| 伊人无码视频| 久久精品国产精品| 操B久久| 国产一区二区三区视频在线| 无码操逼| 日本黄色三级视频| 黄色大片免费在线观看| 婷婷成人视频| 中文字幕精品综合| 午夜操逼| 三级黄色视频| A片免费在线播放| 北条麻妃无码在线视频| www.大鸡巴| 一本色道久久综合狠狠躁的推荐| 麻豆成人精品| 亚洲播播在线视频| 六月丁香欧美综合| 亚洲性爱在线观看| 日韩无码黄片| 9热精品| 人人摸在线视频| 天天干网址| 超碰AA| 99乱伦| 国产AV在| 日本精品黄色| 精品视频在线看| 中文字幕日韩欧美在线| 伊人黄片| 老熟女痒到不行-ThePorn| Chinese搡老女人| 蜜桃传媒视频| 北条麻妃亚洲无码| 69AV视频网站| 久久久国产探花视频| 国产乱码一区二区三区的解决方法| AV中文字幕在线播放| 日B视频在线观看| 免费三级怡红院| 超碰在线最新| 兔子先生和優奈玩游戲脫衣服,運氣報表優奈輸到脫精光 | 麻豆三级片在线观看| 国产午夜精品一区二区三区牛牛| 中文字幕无码一区二区三区一本久| 大鸡巴影院| 在线观看免费黄色视频| 日韩爱爱视频| 99这里有精品视频| 日韩无码成人片| ww亚洲ww| 亚洲综合网在线观看| 亚洲日韩国产AV| 91在线视频观看| 人妻人人爱| 麻豆国产精品| 亚洲日本黄色视频| 日本一区不卡| 国产精品美女在线观看| aⅴ免费观看| A级片毛片| 亚洲美女喷水视频| 久久久久久久国产| 青青草无码成人天堂免费| av片在线免费观看| 日韩性爱区| 日日日日日干| 学生妹一级片内射视频| 亚洲黄色在线播放| 操国产美女| 婷婷五月在线播放| 91大神免费观看| 黄色成人视频在线观看| 人妻熟女字幕一区二区| 欧美日韩99| 蜜桃av一区二区三区| 伊人国产视频| 狠狠色噜噜狠狠狠7777| 青青草网址| 国产在线接入| 99久久人妻精品免费二区| 欧美成人网站视频| 青草娱乐| 国产色片| 中文字幕综合| 欧美操操| 狠狠草视频| 99久在线精品99re8热| 毛片毛片毛片毛片毛片| 加勒比日韩| 亚洲AV成人网| 一区二区成人视频| 亚洲精品影视| 五月天婷婷综合网| 无码综合| 伊人99在线| 爱爱视频无码| 夫妻无码| 精品欧美激情精品一区| 成人午夜精品福利免费| 亚洲精品成人| 在线看A片| 婷婷久久久| 色婷婷综合在线| 欧美亚洲| 性生活毛片| 国产一区二区三区免费播放| 天天爽天天射| 激情小视频| 午夜福利剧场| 免费观看成人| 国产日韩欧美一区二区| 杨贵妃一级婬片90分钟| 日本一区二区三区在线播放| 国产一级麻豆| 国产精品AV在线观看| 国产精品自拍三级| 日韩无码中文字幕视频| 69人妻人人澡人人爽久久| 狠狠操2019| 爆操网站| 夜夜骚av.一区二区三区四区| 日韩中文字幕视频在线观看| 无码人妻久久一区二区三区蜜桃| 91红桃视频| www.操逼网| 曰曰干| 一道本无码视频| 超碰97成人| 91无码人妻精品一区二区三区四| 三级片AV在线| 婷婷五月伊人| jizz国产视频| 男人天堂资源网| 中国12一13毛片| 九九热99视频| 国产女人十八水真多| 欧美视频在线观看一区| 揉BBB搡BBB搡BBB| 伊人大香焦网| 91二区三区| 91久久久久久久久久久久18| 成人69AV| 天堂网av2014| jlzzzjlzzz国产免费观看| 日韩欧美中文字幕公布| 欧美亚洲日韩在线观看| 怡春院欧美| WWW色色| 亚洲性爱视频| 嫰BBB槡BBBB槡BBBB| 亚洲无码视频一区二区| 人妻无码高清| 靠逼久久| 蜜芽无码| 黄色性爱小说| 国产性爱AV| 国产操b| 亚洲激情在线| 殴美色色网| 国产成人女人在线观看| 国产精品aaa| 91人妻无码精品| 久热中文在线观看精品视频| 91精品少妇高潮一区二区三区不卡 | 欧美l∨视| 久久久久无码精品亚洲日韩| 中文字幕成人网| 黄色大片在线免费观看| 97综合| 99热9| 老司机AV91| www.av免费| 蜜桃成人久久| 足交在线播放| 午夜欧美性爱视频| 成人一区视频| 天天日狠狠操| 国产精品98| 中文字幕国产av| 亚洲人体视频| 成人免费版欧美州| 91人妻无码| 日本成人视频在线免费播放| 麻豆91网站| 操www| www.蜜桃av| 亚洲成人在线免费| 婷婷色五月激情| 日韩精品一二区| 啪啪视频最新地址发布页| 中文字幕免费高清在线观看| 青青草97国产精品麻豆| 人妻在线观看| 欧洲天堂在线视频网站| 国产美女操逼网站| 国产美女激情视频| 五月天成人导航| 成人免费在线网站| 日韩人妻码一区二区三区| 婷婷五月天综合| 伊人久色| 蜜臀久久99精品久久久晴天影视 | 久亚洲| 五月天综合久久| 欧美亚洲国产日韩| 亚洲中文字幕在线视频观看| 日韩AV综合| 日韩一级欧美一级| 天天色综| 人人摸人人操人人摸| av天堂电影网| 激情三区| 思思热思思操| 丝袜人妻| 五月天激情电影| 亚欧精品久久久久久久久久久| 尤物一区二区| 911国产视频| 五月天婷婷网站| 亚洲综合在线观看视频| 丁香五月激情小说| 中文字幕一区二区三区精华液| 日本黄色视频免费看| 在线观看av中文字幕| 亚洲人人爱| AV在线四季综合网站| 乱子伦国产精品www| 97热热| 日韩国产一区| 2025最新偷拍| 91福利影院| 人人干视频| 欧一美一色一伦一A片| 人人看人人做| 欧美福利导航| 免费成人在线网站| 操穴网| 内射熟妇| 久久99嫩草熟妇人妻蜜臀| av中文在线观看| 国产三级黄色AV| 2019中文字幕mv第三季歌词| 天堂中文在线播放| 亚韩AV| 怡春院在线| 欧美一区二区三区在线| 性饥渴欧美老妇XXXXX| 男女一区二区三区| 日韩一级片免费| 强伦轩一区二区三区四区| 高清无码在线观看视频| 91精品婷婷国产| 亚洲色一| 波多野结衣一级| 日韩a级片| 日韩电影免费在线观看中文字幕| 特黄AAAAAAAA片视频| 色老板av| 影音先锋男人资源网| 日韩特级毛片| 91工厂露脸熟女| 久久成人综合网| 国产精品人妻无码一区牛牛影视| 久久一道| 午夜视频在线播放| 久久久影院| 先锋影音男人| 影音先锋成人在线视频| 五月婷婷综合在线| 麻豆精品久久久久久久99蜜桃| 就去色色五月丁香婷婷久久久| 亚洲婷婷精品国产成人| 毛片导航| 国产区精品| 国产无码AV| 精品国产999久久久免费| 91国内精品视频| 亭亭五月丁香| 久久黄色| 亚洲精品自拍视频| 亚洲天堂手机在线| 国产精品秘麻豆免费版现看视频 | 日韩欧美一级A片| 真实白嫖91探花无码| 无码人妻精品一区二区蜜桃91| 午夜精品久久久久久久99黑人 | 嫩BBB搡BBBB搡BBBB-百度| 国产精品自拍偷拍| 91视频一区二区三区| 麻豆91免费视频| 天天爱天天插| caopeng97| 91人人爽| 免费福利在线视频| 竹菊传媒一区二区三区| 日本一级片在线观看| 波多野结衣高清无码| 青青草原视频在线免费观看| AV婷婷五月天| 国产2区| 天天操天天干欧美精品| 2016超碰| 亚洲色图另类| 午夜A片| 久久久久久黄片| 黄色视频网站在线看| 成人91看片| 亚洲AV无码久| 亚洲综合视频网| 欧美操逼的| 青娱乐AV| 欧美视频自拍| 男人日女人视频| 无码在线免费观看视频| 夜夜骑免费视频| 国产精品福利导航| 精品国产乱码久久久久久郑州公司 | 一级片日韩| 三级黄片免费看| 日韩精品成人免费观看视频| 五月天色综合| 伊人在综合| 国产免费av网站| 中文字幕日韩视频| 操逼视频免费| 亚洲高清福利视频| AV无码电影| 狼人综合网| 天天射日| 国产综合在线播放| 日韩理论片| 肏屄在线观看| 麻豆av在线观看| 久久肏| 可以看的黄色视频| 亚洲精品一级二级三级| 大香蕉75| 人人爱人人操人人干| 99xxxxx| 伊人黄色| 91精品国产综合久久久久久久 | 操日本少妇| 激情在线视频| 日本少妇性爱视频| 黑人猛躁白人BBBBBBBBB | 欧美精产国品一二三产品价格| 青娱乐91| 在线观看免费黄| 日本在线一区二区| 日韩欧美在线免费观看| 97黄色| 免费三级毛片| 女人的天堂AV| 人人色人人草| 日韩欧美国产成人| 亚洲无码成人电影| 182AV| 国产操逼视频网站| 97在线鲁碰免费视频| 一级黄色性爱视频| AV在线直播| 天堂无码视频在线播放|