我有這個java代碼:多個SQL查詢單查詢加盟
ArrayList<MessageMap> ids = getNewMail(UserID, type, maxIdMessage);
Message[] message = new Message[ids.size()];
if(ids.size()>0){
ResultSet rs;
int j =0;
for(MappaMessaggi i : ids){
pstmt = conn.prepareStatement("SELECT * FROM Messaggi WHERE MessageID = ?");
pstmt.setInt(1, i.getMessageID());
rs = pstmt.executeQuery();
rs.next();
.
.
.
}
其中getNewMail
是:
public synchronized ArrayList<MessageMap> getNewMail(int UserID,int type,int max){
ArrayList<MessageMap> map = new ArrayList<MessageMap>();
try {
pstmt = conn.prepareStatement("SELECT * FROM MessageMap WHERE UserID = ? AND TipoID = ? AND MessageID > ?");
.
.//fill arraylist with resultSet
.
}
我知道這是有可能做同樣的只有一個查詢,但我不知道如何......有人能睜開我的眼睛嗎? :) 謝謝!!!
編輯:我嘗試:
SELECT i.*
FROM Messaggi AS i
INNER JOIN MessageMap AS p i.MessageID = p.MessageID
WHERE p.MessageID = 1 AND p.UserID = 1 AND p.TipoID = 2
但我取回:
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'i.MessageID = p.MessageID WHERE p.MessageID = 1 AND p.UserID = 1 AND p.TipoID = ' at line 3
請參閱編輯頁:(我有錯誤 – JackTurky
@JackTurky,對不起,我忘了'ON',看我的編輯。它應該是'INNER JOIN MessageMap p ON i.MessageID = p .MessageID'而不是'INNER JOIN MessageMap p i.MessageID = p.MessageID'。 –
好!!!這是我需要的!謝謝!:) – JackTurky