1
長さ順はWITH句内では機能しません。WITH句内の長さによる注文方法SQL Server 2008?
;WITH Invalids AS
(
SELECT TOP 1 WITH TIES
GroupNumber,
RTRIM(Address1) Address1,
RTRIM(Postcode) Postcode
FROM dbo.LoadData WHERE GroupNumber NOT IN
(
'000','016','018','025','044','048','049','053','054','055','060','064','067','069','071','073'
)
ORDER BY ROW_NUMBER() OVER (PARTITION BY GroupNumber ORDER BY LEN(Address1) DESC, LEN(Postcode) DESC)
)
UPDATE dbo.LoadData
SET
Valid = 0,
Reason = Reason + 'Bad address; '
WHERE GroupNumber =
(
SELECT GroupNumber FROM Invalids WHERE LEN(Address1) = 0 OR LEN(Postcode) = 0
サンプルデータ、実際の出力、予想される出力を提供していれば、問題を理解するのに役立ちます。私はあなたの質問をテストしました。私が見ることができるところから、あなたの 'order by 'ステートメントは、それがすべきことをします。注意: 'len'は末尾の空白を数えないので、' 0'、 'select len( '')'となります。 –