Kommentar
Å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 till höger med det antal bitar som anges 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 för 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 returneras 0resultatet .
RIGHT_SHIFT utför ett logiskt skifte. När bitar har flyttats fylls alla lediga tjänster av 0, oavsett om det ursprungliga värdet var positivt eller negativt.
Anmärkningar
I den första implementeringen stöds inte funktioner för distribuerad fråga för bitmanipuleringsfunktioner i länkad server eller ad hoc-frågor (OPENQUERY).
Metoden >> för RIGHT_SHIFT funktionen stöds för närvarande inte i Microsoft Fabric.
Examples
I följande exempel är heltalsvärdet 12 345 högerförskjutet med 5 bitar.
SELECT RIGHT_SHIFT(12345, 5);
Resultatet är 385. Om du konverterar 12 345 till binärt har 0011 0000 0011 1001du . Om du flyttar det här värdet åt höger med 5 bitar blir 0001 1000 0001det , vilket är 385 i decimaltal.
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 |