0

dat_eb_registrants行としての値 (例: $row[1]) と から抽出された水平配列の値を含むテーブルがありますdat_eb_field_values。それらを分割して、必要に応じてすべてをテーブルに並べることができるようにします。

データがテーブルにどのように配置されるか:

$count = 0;
while ($row = mysql_fetch_row($result))
{
echo "<tr>";
$myArray[] ="<tr><td>" . $row[9] . "</td><td>"; echo $myArray[$count];
$count++;
echo "</tr>"; 
}

データベースからすべてのデータを抽出する方法 (はい、古いことはわかっています):

SELECT dr.id, dr.first_name, dr.last_name, dr.email, dr.comment, dr.amount, dr.published, dr.transaction_id, dr.register_date, GROUP_CONCAT(df.field_value SEPARATOR '</td><td>') 
   FROM dat_eb_registrants dr 
   LEFT JOIN dat_eb_field_values df 
    ON dr.id=df.registrant_id
   WHERE `event_id` >= 20 AND `event_id` <= 25
   GROUP BY dr.id
   ORDER BY '".$sort."', '".$ascdsc."'

$row[1]ここで、最初のテーブル (eg ) および (.eg. $row[2]) からいくつかの行を配列の中央に垂直に配置したいと考えています。これどうやってするの?

配列は一度に私のテーブルを埋めるため、 を使用すると$rows、どの行をどこに表示するかを簡単に知ることができます...

これは私が望むものです (コードが正しくない可能性があります):

while ($row = mysql_fetch_row($result)) {
  echo "<tr>";
echo "<td>"'.$row_table_1[1]'"</td>";
echo "<td>"'.$row_table_1[2]'"</td>";
echo "<td>"'.$row_table_2[35]'"</td>";
echo "<td>"'.$row_table_2[45]'"</td>";
echo "<td>"'.$row_table_1[5]'"</td>";
echo "<td>"'.$row_table_2[6]'"</td>";
echo "</tr>";
}

やったことある:

echo "<td>"; $result24 = mysql_query("SELECT field_id, field_value FROM dat_eb_field_values WHERE (field_id = 88) AND (registrant_id = $row[0])"); $r24 = mysql_fetch_row($result24); echo $r24[1]; echo "</td>";
echo "<td>"; $result25 = mysql_query("SELECT field_id, field_value FROM dat_eb_field_values WHERE (field_id = 57) AND (registrant_id = $row[0])"); $r25 = mysql_fetch_row($result25); echo $r25[1]; echo "</td>";
echo "<td>" . $row[5] . "</td>";
echo "<td>" . $row[6] . "</td>";

私はやってみたいです:

echo "<td>" . $rowfromsecondtable[1] . "</td>";
echo "<td>" . $rowfromsecondtable[2] . "</td>";
echo "<td>" . $row[5] . "</td>";
echo "<td>" . $row[6] . "</td>";

(上記のコードを使用)

のプレビューdat_eb_registrants:

    |   id   |   first_name   |   last_name   |   email               |
------------------------------------------------------------------------
    |    1   |      Mike      |     Doe       |   mikedoe@hotmail.com |
    |    2   |      John      |     Smith     |   j_smith@hotmail.com |

のプレビューdat_eb_field_values:

field 1 = fav.sport
field 2 = fav. color
field 3 = fav. food

    |   registrant_id   |   field_id  |   field_value    |
----------------------------------------------------------
    |    1              |      1      |     tennis       |
    |    1              |      2      |     green        |
    |    1              |      3      |     spagetti     |
    |    2              |      1      |     hockey       |
    |    2              |      2      |     red          |
    |    2              |      3      |     fish         |

私は欲しい:

first_name  |   id   |   fav.sport   |   last_name   |   fav.food   |
---------------------------------------------------------------------
Mike        |    1   |      Tennis   |     Doe       |   spagetti   |
John        |    2   |      Hockey   |     Smith     |   fish       |
4

2 に答える 2

0

多分私は何かが欠けているかもしれませんが、SQLでこのタスクを実行しないのはなぜですか. これは基本的にピボットです。MySQL にはピボットがありませんが、CASEステートメントで集計関数を使用できます。

select r.first_name,
  r.id,
  r.last_name,
  max(case when f.field_id =1 then f.field_value else null end) As FavSport,
  max(case when f.field_id =2 then f.field_value else null end) As FavColor,
  max(case when f.field_id =3 then f.field_value else null end) As FavFood
from dat_eb_registrants r
left join dat_eb_field_values f
  on r.id = f.registrant_id
group by r.first_name, r.id, r.last_name
order by r.id

デモで SQL Fiddle を参照してください

クエリの結果は、必要な出力です。

| FIRST_NAME | ID | LAST_NAME | FAVSPORT | FAVCOLOR |  FAVFOOD |
----------------------------------------------------------------
|       Mike |  1 |       Doe |   tennis |    green | spagetti |
|       John |  2 |     Smith |   hockey |      red |     fish |

dat_eb_field_valuesまたは、テーブルで複数の結合を使用できます。

select r.first_name,
  r.id,
  r.last_name,
  fSport.field_value FavSport,
  fColor.field_value FavColor,
  fFood.field_value FavFood
from dat_eb_registrants r
left join dat_eb_field_values fSport
  on r.id = fSport.registrant_id
  and fSport.field_id = 1
left join dat_eb_field_values fColor
  on r.id = fColor.registrant_id
  and fColor.field_id = 2
left join dat_eb_field_values fFood
  on r.id = fFood.registrant_id
  and fFood.field_id = 3
order by r.id

SQL Fiddle with Demoを参照してください。同じ結果が得られます。

于 2013-01-03T20:45:54.513 に答える
0

これはあなたの質問には答えませんが、$row[9]、$row[10] などを使用する代わりに、テーブルの列名を行インデックスとして使用できます。

$row['first_name'] $row['last_name']

等々。コードが読みやすくなります。

最初にすべてのデータを取得してから、html コードを生成することもできます。見た目がすっきりします。

例えば

$result24 = mysql_query(sometihng here); 
$r24 = mysql_fetch_row($result24);

$result25 = mysql_query(sometihng else here); 
$r25 = mysql_fetch_row($result25);

//php code for table starts here 
echo '<table>';
于 2013-01-03T19:50:30.123 に答える