結合を避け、データを 1 回だけ反復処理するため、これは私の意見では非常に高速です。唯一のボトルネックは、2 つの一時テーブルを使用し、ユーザー定義の値を使用する必要があることです。
setステートメントなし
select START_INTERVAL+0, END_INTERVAL+0
from
(
select
if(@start = NULL or @start > PRODUCTSERIALNUMBER, @start='', '') as SET_START,
if (@start = '', @start:= @previous, @start) as START_INTERVAL,
if(PRODUCTSERIALNUMBER - @previous > 1, concat(@end:=@previous,@start:=''), @end:='') as END_INTERVAL,
@previous:= PRODUCTSERIALNUMBER as PRODUCTSERIALNUMBER
from
(
select min(PRODUCTSERIALNUMBER)-2 as PRODUCTSERIALNUMBER from Product
UNION
(select PRODUCTSERIALNUMBER as PRODUCTSERIALNUMBER from Product ORDER BY productSerialnumber)
UNION
select max(PRODUCTSERIALNUMBER)+2 as PRODUCTSERIALNUMBER from Product
) as TEMP
)
as RESULTS where
not START_INTERVAL is null AND
not END_INTERVAL is null AND
not END_INTERVAL = '' AND
not START_INTERVAL - END_INTERVAL > 0;
Set ステートメントあり
set @start='';
select select START_INTERVAL+0, END_INTERVAL+0
from
(
select
if (@start = '', @start:= @previous, @start) as START_INTERVAL,
if(PRODUCTSERIALNUMBER - @previous > 1, concat(@end:=@previous,@start:=''), @end:='') as END_INTERVAL,
@previous:= PRODUCTSERIALNUMBER as PRODUCTSERIALNUMBER
from
(
select min(PRODUCTSERIALNUMBER)-2 as PRODUCTSERIALNUMBER from Product
UNION
(select PRODUCTSERIALNUMBER as PRODUCTSERIALNUMBER from Product ORDER BY productSerialnumber)
UNION
select max(PRODUCTSERIALNUMBER)+2 as PRODUCTSERIALNUMBER from Product
) as TEMP
)
as RESULTS where
not RESULTS.START_INTERVAL is null AND
not RESULTS.END_INTERVAL is null AND
not RESULTS.END_INTERVAL = '' AND
not RESULTS.START_INTERVAL - RESULTS.END_INTERVAL > 0;
SQLFiddle: http://sqlfiddle.com/#!2/a622a/60