PHP MYSQL从多个列中检索Min值

时间:2013-12-04 11:08:46

标签: php mysql

非常新的PHP,所以请耐心等待。

我有一个包含多列的表格  id | onezw | twozw | threezw | fourzw | fivezw | sixzw | minzw

每列都有一个输入的数字,然后我需要'minzw'列来显示6列的最小值。我有以下代码,但似乎无法解决问题。有人可能会朝着正确的方向推动我。

<?php
$host="localhost"; // Host name
$username="xxx"; // Mysql username
$password="xxx"; // Mysql password
$db_name="xxxx"; // Database name
$tbl_name="ZW"; // Table name


// Connect to server and select database.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");

// get value of id that sent from address bar
$id=$_GET['id'];

// Retrieve data from database
$sql="SELECT * FROM $tbl_name WHERE id='$id'";
$result=mysql_query($sql);
$minzwarray = array("onezw" , "twozw" , "threezw" , "fourzw" , "fivezw" , "sixzw");
$minzw = min($minzwarray);

$rows=mysql_fetch_array($result);
echo $minzw['minzw'];


mysql_close();
?>

1 个答案:

答案 0 :(得分:3)

您可以使用mysql使用LEAST()返回带有最小值的额外列:

SELECT *,LEAST(onezw , twozw , threezw , fourzw , fivezw , sixzw) AS MIN_VALUE
FROM tab1

sqlfiddle demo