2012-02-20 15 views
0
SELECT M.msg_id, M.uid_fk, M.message, M.created, 
U.fname, U.lname, M.uploads 
FROM messages M, users_friends F, users U 
WHERE M.uid_fk=F.friendID 
and F.userID = '5' 
and status='2' 

友だちからのメッセージ(更新)を取得したいと思います。複数のテーブルのクエリ - 友人の更新を取得する

上記のクエリは、テーブルにユーザー5からのメッセージがあることを確認したにもかかわらず、空のセットを返します。

スキーマ:

CREATE TABLE IF NOT EXISTS `messages` (
    `msg_id` int(11) NOT NULL AUTO_INCREMENT, 
    `message` varchar(200) CHARACTER SET utf8 DEFAULT NULL, 
    `uid_fk` int(11) DEFAULT NULL, 
    `ip` varchar(30) DEFAULT NULL, 
    `created` int(11) DEFAULT '1269249260', 
    `uploads` varchar(30) DEFAULT NULL, 
    PRIMARY KEY (`msg_id`), 
    KEY `uid_fk` (`uid_fk`) 
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=263 ; 


CREATE TABLE IF NOT EXISTS `users` (
    `fname` varchar(15) NOT NULL, 
    `lname` varchar(15) NOT NULL, 
    `userID` int(11) NOT NULL AUTO_INCREMENT, 
    `username` varchar(23) NOT NULL, 
    `email` varchar(50) NOT NULL, 
    `password` varchar(32) NOT NULL, 
    `DOB` date DEFAULT NULL, 
    `sex` varchar(1) DEFAULT NULL, 
    `about` text NOT NULL, 
    `location` varchar(20) DEFAULT NULL, 
    `last_login` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, 
    `user_level` int(11) NOT NULL DEFAULT '0', 
    `profile_image` varchar(200) NOT NULL, 
    `profile_image_small` varchar(200) NOT NULL, 
    PRIMARY KEY (`userID`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=19 ; 


CREATE TABLE IF NOT EXISTS `users_friends` (
    `userID` int(11) NOT NULL, 
    `friendID` int(11) NOT NULL, 
    `status` int(1) NOT NULL DEFAULT '0', 
    PRIMARY KEY (`userID`,`friendID`), 
    KEY `fk_users_has_friends_users1` (`userID`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

答えて

1

あなたは→ '5' & '2' WHERE句であなたのINT値を引用し、単一のです。

また、JOINを試してください。

SELECT M.msg_id, 
     M.uid_fk, 
     M.message, 
     M.created, 
     U.fname, 
     U.lname, 
     M.uploads 
FROM messages M 
INNER JOIN users_friends F ON F.friendID = M.uid_fk 
    AND F.userID = 5 
    AND F.status = 2 
INNER JOIN users U ON U.userID = F.friendID; 
+0

#1064 - SQL構文に誤りがあります。あなたのMySQLサーバーのバージョンに対応するマニュアルをチェックしてください。正しい構文が使用されています。 'INNER JOIN users_friends F ON F.friendID = M.uid_fk AND F.userID = 5 AN' 9行目 –

+0

Nevermind、ちょうどカンマINNER JOINの前にあるべきではありません。できます! –

+0

@BrianByrne Yupは、Mの後の余分なカンマでした。 – Timeout

関連する問題