/ / SQLite `ifnull ()` vs `coalesce ()` wydajność - sql, performance, sqlite, coalesce, ifnull

SQLite `ifnull ()` vs `coalesce ()` wydajność - sql, performance, sqlite, coalesce, ifnull

Od Witryna SQLite,

Funkcja ifnull () jest równoważna koalesce () z dwoma argumentami.

Następnie, jeśli mam dwa argumenty, który z nich jest szybszy?

Odpowiedzi:

4 dla odpowiedzi № 1

Potwierdziłem wypowiedź Gordona Linoffa z kilkoma eksperymentami: Setup: SQLiteSpy na Windows 8, i5 i cała tabela w pamięci RAM.

Zapytanie zajęło około 1,64 s przy bardzo małych fluktuacjach (mniej niż 0,1 sekundy). Przez większość czasu mieli rację 1,64 sekundy.

Zapytania:

    create table t (
a int, b int);

insert into t values (null,null);
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;
insert into t select case when random() < .5 then 1 end, case when random() < .5 then 1 end from t;

select sum(ifnull(a, b)) from t;
select sum(coalesce(a, b)) from t;
select count(*) from t;