2

MSSQL SERVER 2005 で、次のように派生テーブルから select ステートメントを実行しようとしています。

私が解決しようとしている問題は、重複する行があることですが、日付フィールドが秒単位で異なりますが、たとえば分を考慮に入れています

ID  DATE
1   08:20:00
1   08:20:01
2   09:21:00
5   10:00:00
5   10:00:01

ID の DISTINCT 値を取り、DATE で並べ替えたいのですが、日付で並べ替えると、DATE フィールドを含める必要があります。したがって、1つの列で明確に選択することはできません。

派生テーブル クエリ (重複を完全に取得するだけで機能します)

SELECT  p.[SICIL] AS ID, h.[ZAMAN_TRH] AS ZAMAN_TRH
FROM [RF_BIO].[dbo].[PERSONEL] p,  [RF_BIO].[dbo].[HAREKETLER] h  
WHERE h.[ZAMAN_TRH] > '2013-05-27T00:00:00.000' AND h.[YON]= 2 AND 
(p.[KARTNO] = h.[KARTNO] OR p.[SICIL]= h.[SICIL]) 
ORDER BY h.[ZAMAN_TRH] DESC 

派生テーブルを使用するクエリ:

SELECT DISTINCT [SICIL] 
FROM ( SELECT  p.[SICIL] AS SICIL, h.[ZAMAN_TRH] AS ZAMAN_TRH  
FROM [RF_BIO].[dbo].   [PERSONEL] p,  [RF_BIO].[dbo].[HAREKETLER] h 
WHERE h.[ZAMAN_TRH] > '2013-05-27T00:00:00.000' AND h.[YON]= 2 AND 
(p.[KARTNO] = h.[KARTNO] OR p.[SICIL]= h.[SICIL]) ORDER BY h.[ZAMAN_TRH] DESC ) AS LAST

これにより、JavaでSQL例外が発生します

java.sql.SQLException:  
    at net.sourceforge.jtds.jdbc.SQLDiagnostic.addDiagnostic(SQLDiagnostic.java:372)
    at net.sourceforge.jtds.jdbc.TdsCore.tdsErrorToken(TdsCore.java:2893)
    at net.sourceforge.jtds.jdbc.TdsCore.nextToken(TdsCore.java:2335)
    at net.sourceforge.jtds.jdbc.TdsCore.getMoreResults(TdsCore.java:638)
    at net.sourceforge.jtds.jdbc.JtdsStatement.executeSQLQuery(JtdsStatement.java:505)
    at net.sourceforge.jtds.jdbc.JtdsStatement.executeQuery(JtdsStatement.java:1427)

ご協力ありがとうございました。

4

1 に答える 1

2

ORDER BY 句の集計関数で GROUP BY 句を使用する

SELECT p.[ID] AS ID
FROM [RF_BIO].[dbo].[PERSONEL] p, [RF_BIO].[dbo].[HAREKETLER] h  
WHERE h.[DATE] > '2013-05-27T00:00:00.000' AND h.[YON]= 2
  AND (p.[KART] = h.[KART] OR p.[ID]= h.[ID])
GROUP BY p.[ID]
ORDER BY MAX(h.[DATE]) DESC 

SQLFiddle の簡単なデモ

SELECT p.[SICIL] AS SICIL
FROM [RF_BIO].[dbo].[PERSONEL] p, [RF_BIO].[dbo].[HAREKETLER] h 
WHERE h.[ZAMAN_TRH] > '2013-05-27T00:00:00.000' AND h.[YON]= 2
  AND (p.[KARTNO] = h.[KARTNO] OR p.[SICIL]= h.[SICIL])
GROUP BY p.[SICIL]  
ORDER BY MAX(h.[ZAMAN_TRH]) DESC

平面図

ここに画像の説明を入力

于 2013-05-27T06:42:25.860 に答える