3v4l.org

run code in 300+ PHP versions simultaneously
<?php $query = 'UPDATE `table_name` SET `field1_name` = :? WHERE `field2_name` = :?'; $bind_marker = '?'; $bind_values = array("'foo'", "'bar'"); echo str_replace($bind_marker, $bind_values, $query);
Output for 8.0.0 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
Fatal error: Uncaught TypeError: str_replace(): Argument #2 ($replace) must be of type string when argument #1 ($search) is a string in /in/kHkoL:5 Stack trace: #0 /in/kHkoL(5): str_replace('?', Array, 'UPDATE `table_n...') #1 {main} thrown in /in/kHkoL on line 5
Process exited with code 255.
Output for 4.3.0 - 4.3.11, 4.4.0 - 4.4.9, 5.0.0 - 5.0.5, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29, 5.4.0 - 5.4.45, 5.5.24 - 5.5.35, 5.6.7 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.20, 7.2.0 - 7.2.33, 7.3.16 - 7.3.31, 7.4.0 - 7.4.33
Notice: Array to string conversion in /in/kHkoL on line 5 UPDATE `table_name` SET `field1_name` = :Array WHERE `field2_name` = :Array
Output for 7.3.32 - 7.3.33
UPDATE `table_name` SET `field1_name` = :Array WHERE `field2_name` = :Array

preferences:
229.58 ms | 401 KiB | 313 Q