3v4l.org

run code in 300+ PHP versions simultaneously
<?php function prepared_mysqli_query($query) { //initializing required variables $first_half = ''; $placeholders = ''; $data_types = ''; $values = ''; //getting the first half of query $trim_end = strrpos($query,'('); $first_half = substr($query, 0, $trim_end); //getting the values to be inserted $open = strrpos($query,'('); $close = strrpos($query,')'); $values = substr($query,($open+1),($close+1)); $values_stripped = substr($values,0,-1); $values_array = explode(",",$values_stripped); $values_count = count($values_array); //generating placeholders $ph = "("; for ($i = 1; $i < $values_count; $i++) { $ph.= "?,"; } $ph.= "?)"; $placeholders .= $ph; //getting value types $types =''; for ($i = 0; $i < $values_count; $i++){ $str = gettype($values_array[0]); $types .= $str[0]; } $data_types .= $types; //execution $query = $first_half.$placeholders; return ["query" => $query, "data_types" => $data_types, "values" => $values_array ]; } var_dump(prepared_mysqli_query("INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES (NULL, 'v1', 'v2');")); var_dump(prepared_mysqli_query("INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES (NOW(), 'v1', 'v2');")); var_dump(prepared_mysqli_query("INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES ('test,with,commas', 'v1', 'v2');")); var_dump(prepared_mysqli_query("INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES ('v0', 'v1', 'v2') ON DUPLICATE KEY UPDATE `column2` = 'v2';"));
Output for git.master, git.master_jit, rfc.property-hooks
array(3) { ["query"]=> string(72) "INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES (?,?,?)" ["data_types"]=> string(3) "sss" ["values"]=> array(3) { [0]=> string(4) "NULL" [1]=> string(5) " 'v1'" [2]=> string(6) " 'v2')" } } array(3) { ["query"]=> string(76) "INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES (NOW(?,?,?)" ["data_types"]=> string(3) "sss" ["values"]=> array(3) { [0]=> string(1) ")" [1]=> string(5) " 'v1'" [2]=> string(6) " 'v2')" } } array(3) { ["query"]=> string(76) "INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES (?,?,?,?,?)" ["data_types"]=> string(5) "sssss" ["values"]=> array(5) { [0]=> string(5) "'test" [1]=> string(4) "with" [2]=> string(7) "commas'" [3]=> string(5) " 'v1'" [4]=> string(6) " 'v2')" } } array(3) { ["query"]=> string(72) "INSERT INTO `tablename` (`column1`, `column2`, `column3`) VALUES (?,?,?)" ["data_types"]=> string(3) "sss" ["values"]=> array(3) { [0]=> string(4) "'v0'" [1]=> string(5) " 'v1'" [2]=> string(47) " 'v2') ON DUPLICATE KEY UPDATE `column2` = 'v2'" } }

This tab shows result from various feature-branches currently under review by the php developers. Contact me to have additional branches featured.

Active branches

Archived branches

Once feature-branches are merged or declined, they are no longer available. Their functionality (when merged) can be viewed from the main output page


preferences:
163.73 ms | 409 KiB | 5 Q