php读取mysql表数据并按总和排序

现在需要从表里提取数据并显示,这个倒简单.不过目前的要求是得加一个额外字段显示部分表内字段数据的总和以进行排序,请问如此处理?需要提取比如info1+info2的总和进行... 现在需要从表里提取数据并显示,这个倒简单.
不过目前的要求是得加一个额外字段显示部分表内字段数据的总和以进行排序,请问如此处理?
需要提取比如info1+info2的总和进行排序

  <?php

  $result = mysql_query("SELECT * FROM stats ORDER BY data2 DESC LIMIT 20");

  echo "<table border='1'>
  <tr>
  <th>ID</th>
  <th>data1</th>
  <th>data2>/th>
....

  </tr>";

  while($row = mysql_fetch_array($result))
  {
  echo "<tr>";
  echo "<td>" . $row['id'] . "</td>";
  //echo "<td>" . $row['info1'] . "</td>";
  echo "<td>" . $row['info2'] . "</td>";
......

  echo "</tr>";
  }
  echo "</table>";

  mysql_close($con);
  ?>
展开
 我来答
阳光上的桥
2015-07-21 · 知道合伙人软件行家
阳光上的桥
知道合伙人软件行家
采纳数:21424 获赞数:65806
网盘是个好东东,可以对话和传文件

向TA提问 私信TA
展开全部
例如你的数字字段有a、b、c、d,需要查询时显示那么之和,并按综合排序,SQL语句可以这样写:
SELECT a+b+c+d, a, b, c, d FROM 表名 ORDER BY 1

上面的例子典型的应用是学生成绩计算总分,其实可以加总和,也可以部分字段减,例如a+b+c-d,例如用来计算工资等。

对于你补充的例子,我修改你的SQL语句为:
$result = mysql_query("SELECT info1+info2,* FROM stats ORDER BY 1,data2 DESC LIMIT 20");
追问
这种是属于纯sql方法了吧, 目前要求必须得在php里去做
追答
如果数据有100万条,需要获取info1+info2最大的20条,难道我们要把100万数据获取到PHP数组里面排序后输出结果,这样的程序必死无疑。

所以,对于这个问题,要求用PHP实现的“老师”,你可以直接给他两耳光。
意志之胜
2015-07-21
知道答主
回答量:33
采纳率:0%
帮助的人:6.2万
展开全部
先把数据放入数组,然后用php操作数组就可以了。
追问
麻烦看下补充说明,谢谢
能否帮忙给个范例?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式