Hi! Could we please enable some services and cookies to improve your experience and our website?

PHPize Online / SQLize Online  /  SQLtest Online

A A A
Login    Share code      Blog   FAQ

Online Sandbox for SQL and PHP: Write, Run, Test, and Share SQL Queries and PHP Code

Copy Format Clear
CREATE TABLE data_table ( id INT, `char` VARCHAR(10), numb VARCHAR(10), typ1 INT, typ2 INT, typ3 INT, PRIMARY KEY (id) ); INSERT INTO data_table VALUES (1, 'ALFA', '01', 0, 1, 0), (2, 'BETA', '02', 0, 1, 1), (3, 'GAMMA', '03', 1, 1, 1), (4, 'DELTA', '04', 0, 0, 0), (5, 'EPSILON', '05', 1, 1, 1); CREATE TABLE values_table01 ( id_num1 INT, id_num2 INT ); INSERT INTO values_table01 VALUES (1, 11111111), (2, 12222221), (3, 13333331), (3, 13333332), (4, 14444444), (5, 15555555); CREATE TABLE values_table02 ( id_num1 INT, id_num2 INT ); INSERT INTO values_table02 VALUES (1, 21111111), (1, 21111112), (2, 22222221), (2, 22222222), (3, 23333331), (5, 25555551); CREATE TABLE values_table03 ( id_num1 INT, id_num2 INT ); INSERT INTO values_table03 VALUES (1, 31111111), (2, 32222221), (2, 32222222), (2, 32222223), (3, 33333331), (4, 34444441);

Stuck with a problem? Got Error? Ask AI support!

Copy Clear
Copy Format Clear
<?php $portfolios = [ 'ALFA01', 'BETA02', 'GAMMA03', 'DELTA04', 'EPSILON05', 'ZETA06', ]; $placeholders = implode(',', array_fill(0, count($portfolios), '?')); $sql = <<<SQL SELECT data.id, values_table.id_num2 AS val FROM data_table AS data JOIN ( SELECT 1 AS typ_num, id_num1, id_num2 FROM values_table01 UNION SELECT 2 AS typ_num, id_num1, id_num2 FROM values_table02 UNION SELECT 3 AS typ_num, id_num1, id_num2 FROM values_table03 ) AS values_table ON values_table.id_num1 = data.id AND ( (values_table.typ_num = 1 AND data.typ1 = 1) OR (values_table.typ_num = 2 AND data.typ2 = 1) OR (values_table.typ_num = 3 AND data.typ3 = 1) ) WHERE CONCAT(`char`,numb) IN ($placeholders) SQL; $result = []; foreach ($mysqli->execute_query($sql, $portfolios) as $row) { $result[$row['id']][] = $row['val']; } var_export($result);
Copy Clear