isql -i c:\temp\dml-basic-benchmark.sqlThis script will create a database approximately 3.6Gb in size. Please delete it after the test.
CPU | Disk | RAM | Firebird Version |
Page Buffers |
## of rows |
INSERT, ms | Commit, ms | UPDATE, ms | Commit, ms | DELETE time. ms | Commit, ms |
---|---|---|---|---|---|---|---|---|---|---|---|
Intel Core i3-3220 | SSD Crucial MX300 | 12Gb | 3.0.5 | 2048 | 1000000 | 92699 | 1214 | 136096 | 2072 | 93232 | 11 |
Intel Xeon E5-2643 | SSD Samsung PM863a | 64Gb | 3.0.4 | 256 | 1000000 | 320461 | 80 | 907881 | 100 | 1317092 | 76 |
AMD Ryzen 2700 | SSD | 32Gb | 3.0.4 | 1048576 | 1000000 | 69383 | 10191 | 84234 | 25364 | 23201 | 20695 |
AMD Ryzen 2700 | SSD | 32Gb | 3.0.4 | 102400 | 1000000 | 70323 | 8668 | 86418 | 13778 | 26141 | 9092 |
AMD Ryzen 2700 | HDD 5400 | 32Gb | 3.0.4 | 1048576 | 1000000 | 79515 | 28402 | 95141 | 60402 | 25472 | 57165 |
AMD Ryzen 2700 | HDD 5400 | 32Gb | 3.0.4 | 102400 | 1000000 | 84724 | 23632 | 108874 | 34303 | 64082 | 32228 |
AMD Ryzen 2700 | SSD | 32Gb | 2.5.9 | 1024 | 1000000 | 76561 | 700 | 114704 | 1160 | 75043 | 1840 |
AMD Ryzen 2700 | SSD | 32Gb | 2.5.9 | 2048 | 1000000 | 69169 | 630 | 101828 | 1340 | 65820 | 2110 |
AMD Ryzen 2700 | SSD | 32Gb | 2.5.9 | 9999 | 1000000 | 65853 | 1040 | 84859 | 1840 | 38483 | 3280 |
AMD Ryzen 2700 | SSD | 32Gb | 2.5.9 | 20000 | 1000000 | 65533 | 1200 | 84710 | 2090 | 37958 | 3680 |
AMD Ryzen 2700 | SSD | 32Gb | 2.5.9 | 50000 | 1000000 | 65395 | 2810 | 84003 | 3580 | 34756 | 5160 |
AMD Ryzen 2700 | SSD | 32Gb | 2.5.9 | 100000 | 1000000 | 64599 | 6170 | 82475 | 6350 | 37160 | 7650 |
Intel Pentium G850 2.9 GHz | HDD 7200 | 8Gb | 2.5.1 | 2048 | 1000000 | 104128 | 16570 | 142834 | 42220 | 99325 | 58170 |
Intel i7-5500U | SSD | 16Gb | 3.0.4 | 50000 | 1000000 | 125055 | 5216 | 152995 | 5178 | 67123 | 5813 |
Intel i7-5500U | HDD | 16Gb | 3.0.4 | 50000 | 1000000 | 186218 | 14153 | 231001 | 15584 | 80080 | 15458 |
Intel i7-5500U | SSD | 16Gb | 3.0.4 | 75000 | 1000000 | 134811 | 9712 | 163249 | 8297 | 68074 | 13976 |
Intel Core i5-2500 | SSD INTEL SSDSA2CW120G3 | 4Gb | 2.5.8 | 9999 | 1000000 | 88692 | 2670 | 113835 | 3420 | 231538 | 3570 |
Intel Core i5-2500 | SSD INTEL SSDSA2CW120G3 | 4Gb | 2.5.8 | 384 | 1000000 | 124815 | 1700 | 192240 | 2390 | 295163 | 2010 |
Intel Core i3 | SSD NVMe Samsung 860 EVO | 16Gb | 2.5.9 | 75 | 1000000 | 92618 | 0 | 112457 | 0 | 66142 | 0 |
Intel Core i3 | SSD NVMe Samsung 860 EVO | 16Gb | 2.5.9 | 1024 | 1000000 | 78058 | 10 | 104130 | 10 | 60402 | 10 |
Intel Core i3 | SSD NVMe Samsung 860 EVO | 16Gb | 2.5.9 | 2048 | 1000000 | 72798 | 10 | 97114 | 20 | 54991 | 10 |
Intel Core i3 | SSD NVMe Samsung 860 EVO | 16Gb | 2.5.9 | 9999 | 1000000 | 70918 | 7 | 87512 | 8 | 41651 | 8 |
create database "xnet://e:\inserttest4.fdb" user "SYSDBA" password "masterkey" page_size 16384; set term ^; execute block as begin -- ###################################################### rdb$set_context('USER_SESSION', 'ROWS_TO_HANDLE', 1000000); -- ###################################################### execute statement 'drop sequence g'; when any do begin end end ^ set term ;^ commit; create sequence g; recreate table test( id int ,grp smallint ,pid int ,dts timestamp ,code_sml varchar(15) ,code_med varchar(150) ,code_lrg varchar(1500) ,code_unq char(16) character set octets ,constraint test_pk primary key(id) ,constraint test_unq unique( code_unq ) ); create index test_pid on test(pid); create descending index test_dts on test(dts); create index test_dml on test(code_sml); create index test_med on test(code_med); create index test_lrg on test(code_lrg); commit; ---------------------------------------------- set bail on; set list on; set stat on; set term ^; execute block returns( inserted_rows int, elap_ms int ) as declare i int = 0; declare t timestamp; begin inserted_rows = rdb$get_context('USER_SESSION', 'ROWS_TO_HANDLE'); t = 'now'; while ( i < inserted_rows ) do begin insert into test(id, grp, pid, dts, code_sml, code_med, code_lrg, code_unq) values( gen_id(g,1) ,rand() * 10 ,rand() * 1000 ,dateadd( rand()*1000000 second to timestamp '01.01.2019 00:00:00' ) ,lpad('', 15, 'QWERTY' ) ,lpad('', 150, 'QWERTY' ) ,lpad('', 1500, 'QWERTY' ) ,gen_uuid() ); i = i + 1; end elap_ms = datediff(millisecond from t to cast('now' as timestamp)); suspend; end ^ commit^ ----------------------------------------------- execute block returns( updated_rows int, elap_ms int ) as declare i int = 0; declare t timestamp; begin updated_rows = rdb$get_context('USER_SESSION', 'ROWS_TO_HANDLE'); t = 'now'; while ( i < updated_rows ) do begin update test set grp = rand() * 10 ,pid = rand() * 1000 ,dts = dateadd( rand()*100000 second to timestamp '01.01.2019 00:00:00' ) ,code_sml = lpad('', 15, 'ASDFGH' ) ,code_med = lpad('', 150, 'ASDFGH' ) ,code_lrg = lpad('', 1500, 'ASDFGH' ) ,code_unq = gen_uuid() where id = :i+1 ; i = i + 1; end elap_ms = datediff(millisecond from t to cast('now' as timestamp)); suspend; end ^ commit^ ----------------------------------------------- execute block returns( deleted_rows int, elap_ms int ) as declare i int = 0; declare t timestamp; begin deleted_rows = rdb$get_context('USER_SESSION', 'ROWS_TO_HANDLE'); t = 'now'; while ( i < deleted_rows ) do begin delete from test where id = :i+1 ; i = i + 1; end elap_ms = datediff(millisecond from t to cast('now' as timestamp)); suspend; end ^ set term ;^ commit;