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?
8 answers
Uwaga, w nawiasach wymagane są Instrukcje aktualizacji:
update top (100) table1 set field1 = 1
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'
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)
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
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
.
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
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)
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;
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