使用UNION进行SQL多表查询,如何获取表名

时间:2011-08-20 20:16:58

标签: php mysql sql arrays union

我有以下表格结构。一个表EQUITIES和该表中每行的表。

EQUITIES table:
id instrument

每个乐器的表格都与此类似: 名为EE5367126893的表(各种名称和名称存储在股票表中)。

EE5367126893
id chg 

编辑: 我的代码很糟糕。它以某种方式让我得到错误的结果,我似乎无法找到错误。

<?
//CREATION OF TOP MOVERS
include('connect.php');
$sql = "SELECT * FROM equities";     

$result = mysql_query($sql) or die(mysql_error());

$instruments = array();
while ($row = mysql_fetch_array($result)) {
    array_push($instruments, $row["instrument"]);
}
$i=0;
foreach($instruments as $instrument) {
    $sqlx .= "(SELECT id, chg, vol, '$instrument' as name FROM ".$instrument." ORDER BY id DESC LIMIT 1)";
    if ($i<count($instruments)-1){
            $sqlx .= " UNION ";
            $i++;
    }
}
$gsql = $sqlx;
$lsql = $sqlx;
$vsql = $sqlx;

//Gainers
$gsql .= " ORDER BY chg DESC LIMIT 3";
$gresult = mysql_query($gsql) or die(mysql_error());
while ($grow = mysql_fetch_array($gresult)) {
    $g[$grow['name']] = $grow['chg'];;
}
print_r($g);
//losers
$lsql .= " ORDER BY chg ASC LIMIT 3";
$lresult = mysql_query($lsql) or die(mysql_error());
while ($lrow = mysql_fetch_array($lresult)) {
    $l[$lrow['name']] = $lrow['chg'];;
}
print_r($l);
//most volume
$vsql .= " ORDER BY vol DESC LIMIT 3";
$vresult = mysql_query($vsql) or die(mysql_error());
while ($vrow = mysql_fetch_array($vresult)) {
    $v[$vrow['name']] = $vrow['vol'];;
}
print_r($v);
?>

它让我得到了结果:

Array
(
    [LV0057869] => 0.68
    [EE310054309] => 0.00
    [EE3100034553] => -5.03
)
Array
(
    [LV0054359] => -0.84
    [LT0000543337] => -3.83
    [LT00453127375] => -4.03
)
Array
(
    [EE310054334653] => 791
    [EE3100003609] => 58538
    [LT000543337] => 33240
)

很明显,我没有得到最高,最低或最大vol的值(-0.84&gt; -5.03)。看起来随机值被此查询锁定。捕获量在哪里?我很确定我的sql查询有些不好......

1 个答案:

答案 0 :(得分:0)

您可以添加名称以选择

SELECT id, chg, 'table_name or instrument_name' as inst_name from ...

示例:

$sqlx .= "(SELECT id, chg, '$instrument' as name FROM ".$instrument." ORDER BY id DESC LIMIT 1)";

似乎vol有VARCHAR类型,行按字符排序而不是整数。 你能提供你的餐桌计划吗?