3v4l.org

run code in 300+ PHP versions simultaneously
<?php $config['sql_query_logging'] = [ 'enabled' => true, 'exclusions' => [ 'tables' => ['ci_sessions', 'system_log', 'jobs_log', 'error_log'], 'keywords' => ['select', 'show tables'] ] ]; $sqls = [ 'select * from table', 'show tables', 'update ci_sessions set some_col = some_val', 'update test set some_col = some_val', 'insert into test values(23, 45)', 'insert into ci_sessions values(1,2,3)', 'truncate ci_sessions' ]; foreach($sqls as $sql){ $result = array_merge( array_filter($config['sql_query_logging']['exclusions']['keywords'], fn($v) => preg_match('/\b'.$v.'\b/', $sql) === 1), array_filter($config['sql_query_logging']['exclusions']['tables'], function($table) use ($sql){ return preg_match('/\b(from|insert into|update|join|truncate|table)\s+'.$table.'\b/', $sql) === 1; }) ); if(empty($result)){ echo "Can log: ", $sql, PHP_EOL; // log here }else{ echo "Cannot log: ", $sql, PHP_EOL; } }
Output for 8.0.1 - 8.0.30, 8.1.0 - 8.1.33, 8.2.0 - 8.2.29, 8.3.0 - 8.3.28, 8.4.1 - 8.4.14, 8.5.0
Cannot log: select * from table Cannot log: show tables Cannot log: update ci_sessions set some_col = some_val Can log: update test set some_col = some_val Can log: insert into test values(23, 45) Cannot log: insert into ci_sessions values(1,2,3) Cannot log: truncate ci_sessions
Output for 8.4.15
/bin/php-8.4.15: /usr/lib/libm.so.6: version `GLIBC_2.38' not found (required by /bin/php-8.4.15) /bin/php-8.4.15: /usr/lib/libm.so.6: version `GLIBC_2.35' not found (required by /bin/php-8.4.15) /bin/php-8.4.15: /usr/lib/libc.so.6: version `GLIBC_2.34' not found (required by /bin/php-8.4.15) /bin/php-8.4.15: /usr/lib/libc.so.6: version `GLIBC_2.38' not found (required by /bin/php-8.4.15)
Process exited with code 1.

preferences:
123.46 ms | 407 KiB | 5 Q