0
//Table One {news}
Id1 | subject1 | url1 | source1

//Table Two {blog_news}
order_id | type | id1 | id

//Table Three {blog}
id | name | subject | url

//SQL query
SELCET nf.*, fnb.*, b.id, b.name, b.subject, b.url FROM news AS nf JOIN blog_news AS fnb ON nf.id1=fnb.id1 JOIN blog AS b ON fnb.id=b.id
//Display Code

if(($i = 0; $i <= 5; ++$i)&&(fnb.type' ==1)){

//Order the result by 'order_id'

//Table Display Code
<table>
 <tr> 
  <td width='250px' valign='middle' align='left'>
     <font size='-2'>
     <a herf='” . $_GET['b.url'] . “'>
     <b>” . $_GET ['b.subject'] . “&lt;/b>
     </a>
     </font>
   </td>
   <td width='100px' valign='middle' align='right'>
       <font size='-2'>
       <a herf='” . $_GET['b.url'] . “'>
       <b>” . $_GET ['b.name'] . “&lt;/b>
       </a>
       </font>
     </td> 
   </tr> 
 </table> 
 }endif

我想要完成的是将三个数据库表连接在一起,并使用类似于{//display}代码部分的代码在两个区域中显示结果。

我尝试了可能不同的方法来完成这项任务。
我尝试在 php 中使用 while 循环来显示结果,并且mysql_fetch_error()在 while 循环开始之前收到了一个。我的目标是让每张桌子都按order_id顺序DESC排列。

4

1 回答 1

0

在 MySQL 中组织数据要容易得多。

尝试这个:

SELECT nf.*, fnb.*, b.id, b.name, b.subject, b.url
FROM news nf
  JOIN blog_news fnb ON nf.id1 = fnb.id1
  JOIN blog b ON fnb.id = b.id
WHERE fnb.type = 1
ORDER BY fnb.order_id DESC
LIMIT 5

并看看 MySQL 的ORDER BY是如何工作的。

如果您不知道如何在 php 中与 MySQL 交互,那么在您最喜欢的搜索引擎上快速搜索“MySQL 和 php 教程”应该会有所帮助。

于 2013-03-16T22:53:08.083 回答