Jak mogę zaktualizować top 100 rekordów w SQL server

Chcę zaktualizować top 100 rekordów w SQL Server. Mam tabelę T1 z polami F1 i F2. T1 mA 200 rekordów. Chcę zaktualizować pole F1 w top 100 records. Jak mogę zaktualizować na podstawie TOP 100 W Sql Server?

Author: gotqn, 2009-07-29

8 answers

Uwaga, w nawiasach wymagane są Instrukcje aktualizacji:

update top (100) table1 set field1 = 1
 718
Author: Umair Ahmed,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2014-05-23 22:26:33

Bez ORDER BY cała idea TOP nie ma większego sensu. Musisz mieć spójną definicję, który kierunek jest "w górę", a który jest "w dół", aby pojęcie góry było znaczące.

Mimo to SQL Server na to pozwala, ale nie gwarantuje deterministycznego wyniku .

Składnia UPDATE TOP w zaakceptowanej odpowiedzi nie obsługuje klauzuli ORDER BY, ale możliwe jest uzyskanie semantyki deterministycznej za pomocą CTE lub tabeli pochodnej do zdefiniowania pożądanego kolejność sortowania jak poniżej.

;WITH CTE AS 
( 
SELECT TOP 100 * 
FROM T1 
ORDER BY F2 
) 
UPDATE CTE SET F1='foo'
 317
Author: Martin Smith,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-02-15 21:56:18
update tb set  f1=1 where id in (select top 100 id from tb where f1=0)
 17
Author: hyyxing,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2012-07-17 17:17:41

Dla takich jak ja wciąż utkniętych z SQL Server 2000, SET ROWCOUNT {number}; może być używany przed UPDATE zapytanie

SET ROWCOUNT 100;
UPDATE Table SET ..;
SET ROWCOUNT 0;

Ograniczy aktualizację do 100 wierszy

Jest przestarzały co najmniej od SQL 2005, ale od SQL 2017 nadal działa. https://docs.microsoft.com/en-us/sql/t-sql/statements/set-rowcount-transact-sql?view=sql-server-2017

 16
Author: Claudio B,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-09-23 19:39:25

Co jest jeszcze fajniejsze, to fakt, że możesz użyć funkcji Wartościowanej w tabeli inline, aby wybrać, które (i ile wierszy za pomocą TOP) mają zostać zaktualizowane. Czyli:

UPDATE MyTable
SET Column1=@Value1
FROM tvfSelectLatestRowOfMyTableMatchingCriteria(@Param1,@Param2,@Param3)

Dla funkcji table valued masz coś ciekawego, aby wybrać wiersz do aktualizacji, jak:

CREATE FUNCTION tvfSelectLatestRowOfMyTableMatchingCriteria
(
    @Param1 INT,
    @Param2 INT,
    @Param3 INT
)
RETURNS TABLE AS RETURN
(
    SELECT TOP(1) MyTable.*
    FROM MyTable
    JOIN MyOtherTable
      ON ...
    JOIN WhoKnowsWhatElse
      ON ...
    WHERE MyTable.SomeColumn=@Param1 AND ...
    ORDER BY MyTable.SomeDate DESC
)

..., i leży (moim skromnym zdaniem) prawdziwa moc aktualizowania tylko wybranych wierszy deterministycznie przy jednoczesnym uproszczeniu składni UPDATE.

 4
Author: Michael Goldshteyn,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2015-04-23 18:25:11

Możesz również zaktualizować z select używając aliasu i dołączyć:

UPDATE  TOP (500) T
SET     T.SomeColumn = 'Value'
FROM    SomeTable T
        INNER JOIN OtherTable O ON O.OtherTableFK = T.SomeTablePK
WHERE   T.SomeOtherColumn = 1
 1
Author: Vanderlei Pires,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2019-05-09 13:55:02

Try:

UPDATE Dispatch_Post
SET isSync = 1
WHERE ChallanNo 
IN (SELECT TOP 1000 ChallanNo FROM dbo.Dispatch_Post ORDER BY 
CreatedDate DESC)
 0
Author: Shahin Al Kabir Mitul,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2019-01-08 09:33:30

Ten kawałek kodu może wykonać swoją pracę

UPDATE TOP (100) table_name set column_name = value;

Jeśli chcesz pokazać ostatnie 100 rekordów, możesz użyć tego, jeśli potrzebujesz.

With OrnekWith
as
(
Select Top(100) * from table_name Order By ID desc
)
Update table_name Set column_name = value;
 0
Author: BATUHAN TOKAN,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2021-01-12 13:23:52