3v4l.org

run code in 300+ PHP versions simultaneously
<?php $template = "select emp.* from employee emp" . " join departments dep on emp.id_department = dep.id" . " @{where}" . " @{order}" . " limit :limit offset :offset"; echo $template; $pattern = '/[^\\$]\\@\\{(\\w+)\\}/'; preg_match_all($pattern, $str, $matches);
Output for 8.1.0 - 8.1.27, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
select emp.* from employee emp join departments dep on emp.id_department = dep.id @{where} @{order} limit :limit offset :offset Warning: Undefined variable $str in /in/Egr7N on line 11 Deprecated: preg_match_all(): Passing null to parameter #2 ($subject) of type string is deprecated in /in/Egr7N on line 11
Output for 8.0.0 - 8.0.30
select emp.* from employee emp join departments dep on emp.id_department = dep.id @{where} @{order} limit :limit offset :offset Warning: Undefined variable $str in /in/Egr7N on line 11
Output for 5.0.4 - 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.8 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.20, 7.2.6 - 7.2.33, 7.3.12 - 7.3.31, 7.4.0 - 7.4.25, 7.4.27 - 7.4.33
select emp.* from employee emp join departments dep on emp.id_department = dep.id @{where} @{order} limit :limit offset :offset Notice: Undefined variable: str in /in/Egr7N on line 11
Output for 7.3.32 - 7.3.33, 7.4.26
select emp.* from employee emp join departments dep on emp.id_department = dep.id @{where} @{order} limit :limit offset :offset
Output for 4.3.0 - 4.3.11, 4.4.0 - 4.4.9, 5.0.0 - 5.0.3
select emp.* from employee emp join departments dep on emp.id_department = dep.id @{where} @{order} limit :limit offset :offset Notice: Undefined variable: str in /in/Egr7N on line 11

preferences:
210.79 ms | 402 KiB | 311 Q