作爲一名新手,我有點失落至於如何釘這個。我正試圖加入三張桌子。這是表結構:如何連接三個表並添加「AND」運算符?
Accounts Table:
1) id
2) User_id (Id given to user upon sign up)
3) Full_name
4) Username
5) Email
6) Password
Contacts Table:
1) My_id (This is the user who added friend_id)
2) Contact_id (this is the contact who was added by my_id)
3) Status (status of relationship)
Posts Table:
1) Post_id
2) User_posting (this is the user who posted it)
3) Post_name
4) User_allowed (this is where its specified who can see it)
下面是代碼結構,我有:
<?php
$everybody = "everybody";
$sid = "user who is logged in.";
$sql = <<<SQL
SELECT DISTINCT contacts.contact_id, accounts.full_name, posts.post_id, posts.post_name
FROM contacts, accounts, posts
WHERE
(contacts.my_id = '$sid'
AND contacts.contact_id = accounts.user_id)
OR (contacts.my_id = '$sid'
AND contacts.contact_id = accounts.user_id)
OR (posts.user_posting = '$sid'
AND contacts.contact_id = accounts.user_id
AND posts.user_allowed = '$everybody')
OR (posts.user_id = '$sid'
AND contacts.user_id = accounts.user_id
AND posts.user_allowed = '$everybody')
LIMIT $startrow, 20;
$query = mysql_query($sql) or die ("Error: ".mysql_error());
$result = mysql_query($sql);
if ($result == "")
{
echo "";
}
echo "";
$rows = mysql_num_rows($result);
if($rows == 0)
{
print("");
}
elseif($rows > 0)
{
while($row = mysql_fetch_array($query))
{
$contactid = htmlspecialchars($row['contact_id']);
$name = htmlspecialchars($row['full_name']);
$postid = htmlspecialchars($row['post_id']);
$postname = htmlspecialchars($row['post_name']);
// If $dob is empty
if (empty($contactid)) {
$contactid = "You haven't added any friends yet.";
}
print("$contactid <br>$postname by $name <br />");
}
}
的問題是,查詢顯示我我的職位,加上朋友的所有帖子。
我在做什麼錯了?
您應該使用正確的'JOIN'語法。你的預期產出是多少? – Matthew
您期待的輸出是什麼? – Travesty3
你的輸出有什麼問題?期望什麼? – Paul