Saya mencobanya dengan cara yang berbeda dan kinerja terbaik yang saya temukan adalah kueri sederhana ini:
select a.id+1 gapIni
,(select x.id-1 from arrc_vouchers x where x.id>a.id+1 limit 1) gapEnd
from arrc_vouchers a
left join arrc_vouchers b on b.id=a.id+1
where b.id is null
order by 1
;
... satu left join untuk memeriksa apakah id berikutnya ada, hanya jika next jika tidak ditemukan, maka subquery mencari id berikutnya yang ada untuk mencari akhir celah. Saya melakukannya karena query dengan equal (=) adalah kinerja yang lebih baik daripada operator (>).
Menggunakan sqlfiddle itu tidak menunjukkan kinerja yang sangat berbeda dari kueri lain tetapi dalam database nyata, kueri di atas ini menghasilkan 3 kali lebih cepat daripada yang lain.
Skema:
CREATE TABLE arrc_vouchers (id int primary key)
;
INSERT INTO `arrc_vouchers` (`id`) VALUES (1),(4),(5),(7),(8),(9),(10),(11),(15),(16),(17),(18),(19),(20),(21),(22),(23),(24),(25),(26),(27),(28),(29)
;
Ikuti di bawah semua kueri yang saya buat untuk membandingkan kinerja:
select a.id+1 gapIni
,(select x.id-1 from arrc_vouchers x where x.id>a.id+1 limit 1) gapEnd
from arrc_vouchers a
left join arrc_vouchers b on b.id=a.id+1
where b.id is null
order by 1
;
select *, (gapEnd-gapIni) qt
from (
select id+1 gapIni
,(select x.id from arrc_vouchers x where x.id>a.id limit 1) gapEnd
from arrc_vouchers a
order by id
) a where gapEnd <> gapIni
;
select id+1 gapIni
,(select x.id from arrc_vouchers x where x.id>a.id limit 1) gapEnd
#,coalesce((select id from arrc_vouchers x where x.id=a.id+1),(select x.id from arrc_vouchers x where x.id>a.id limit 1)) gapEnd
from arrc_vouchers a
where id+1 <> (select x.id from arrc_vouchers x where x.id>a.id limit 1)
order by id
;
select id+1 gapIni
,coalesce((select id from arrc_vouchers x where x.id=a.id+1),(select x.id from arrc_vouchers x where x.id>a.id limit 1)) gapEnd
from arrc_vouchers a
order by id
;
select id+1 gapIni
,coalesce((select id from arrc_vouchers x where x.id=a.id+1),concat('*** GAT *** ',(select x.id from arrc_vouchers x where x.id>a.id limit 1))) gapEnd
from arrc_vouchers a
order by id
;
Mungkin itu membantu seseorang dan bermanfaat.
Anda dapat melihat dan menguji kueri saya menggunakan sqlfiddle ini :
http://sqlfiddle.com/#!9/6bdca7/1