1

每个 childrow 都有一个 parentid 和 position。对于具有相同位置的子行,有一行 where start='1'

我想要做的是返回待处理行及其起始行。

应该显示的结果是;开始(欧文)待定(戴夫,保罗)。这是因为它们的位置相同。这是 SQL 小提琴http://sqlfiddle.com/#!2/e6e54/1

  id |  name | parentid|  position|  start  |  pending |
   1 |  mike |    0    |    0     |    0    |     0    |
   2 |  dave |    1    |    1     |    0    |     1    | 
   3 |  paul |    1    |    1     |    0    |     1    |
   4 |  john |    1    |    2     |    1    |     0    |
   5 |  bret |    1    |    2     |    0    |     0    |
   6 |  owen |    1    |    1     |    1    |     0    |
   7 |  rick |    1    |    3     |    1    |     0    |
   8 |  jaye |    1    |    3     |    0    |     0    |



    $getquery = mysql_query("select child.*
from `mytable` child inner join `mytable` parent 
on parent.id=child.parentid
inner join `mytable` child2 on child.parentid=child2.parentid
and child2.pending='1'
where child.start='1' ORDER BY child.id DESC");



while($row=mysql_fetch_assoc($getquery)) {

 $name = $row['name'];

echo "<p>Name: $name </p>";

}
4

1 回答 1

0
select * from `mytable` order by position, pending

where position=1如果这是唯一感兴趣的位置,您可以添加一个子句。

于 2012-04-08T15:37:44.850 回答