Not
Åtkomst till den här sidan kräver auktorisering. Du kan prova att logga in eller ändra kataloger.
Åtkomst till den här sidan kräver auktorisering. Du kan prova att ändra kataloger.
Gäller för: SQL Server 2022 (16.x)
Azure SQL Database
Azure SQL Managed Instance
SQL analytics endpoint in Microsoft Fabric
Warehouse in Microsoft Fabric SQL
database in Microsoft Fabric
RIGHT_SHIFT tar två parametrar och returnerar den första parametern bitförskjuten höger med antalet bitar specificerade i den andra parametern.
Funktionen RIGHT_SHIFT är också tillgänglig via operatorn >> .
Transact-SQL syntaxkonventioner
Syntax
RIGHT_SHIFT ( expression_value, shift_amount )
expression_value >> shift_amount
Arguments
expression_value
Alla heltals- eller binäruttryck som inte är ett stort objekt (LOB).
shift_amount
Antalet bitar med vilka expression_value ska flyttas. shift_amount måste vara av heltalstyp.
Returtyper
Returnerar samma typ som expression_value.
Den shift_amount parametern kastas till en bigint. Parametern kan vara positiv eller negativ, och kan också vara större än antalet bitar i datatypen expression_value. När shift_amount är negativ sker skiftet i motsatt riktning. Till exempel är LEFT_SHIFT (expr, -1) samma som RIGHT_SHIFT (expr, 1). När shift_amount är större än antalet bitar i expression_value, blir 0resultatet .
RIGHT_SHIFT utför en logisk förskjutning. Efter att bitar har flyttats kommer alla lediga positioner att fyllas av 0, oavsett om det ursprungliga värdet var positivt eller negativt.
Anmärkningar
I den initiala implementeringen kommer Distributed Query-funktionalitet för bitmanipulationsfunktioner inom länkade servrar eller ad hoc-frågor (OPENQUERY) inte att stödjas.
Metoden >> för funktionen RIGHT_SHIFT stöds för närvarande inte i Microsoft Fabric.
Examples
I följande exempel är heltalsvärdet 12345 högerförskjutet med 5 bitar.
SELECT RIGHT_SHIFT(12345, 5);
Resultatet är 385. Om du konverterar 12345 till binärt har 0011 0000 0011 1001du . Om man flyttar detta åt höger med 5 blir 0001 1000 0001det , vilket är 385 decimalt.
Följande tabell visar vad som händer under varje skift.
| Heltalsvärde | Binärt värde | Description |
|---|---|---|
| 12345 | 0011 0000 0011 1001 |
Startvärde |
| 6172 | 0001 1000 0001 1100 |
Flytta höger med 1 |
| 3086 | 0000 1100 0000 1110 |
Flytta höger med 2 |
| 1543 | 0000 0110 0000 0111 |
Flytta höger med 3 |
| 771 | 0000 0011 0000 0011 |
Flytta höger med 4 |
| 385 | 0000 0001 1000 0001 |
Flytta höger med 5 |