with - Como obter o primeiro caractere de uma string no SQL?




substring sql server w3 (5)

Eu tenho uma coluna SQL com um comprimento de 6. Agora quero levar apenas o primeiro caractere dessa coluna. Existe alguma função de string no SQL para fazer isso?


É simples conseguir isso seguindo:

DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)

e também

SET @Result = SUBSTRING(@SomeString, 2, 3)
SELECT @Result

@Result: his

-OU-

SET @Result = LEFT(@SomeString, 6)
SELECT @Result

@Result: This i


ENTRADA

STRMIDDLENAME
--------------
Aravind Chaterjee
Shivakumar
Robin Van Parsee

SELECT STRMIDDLENAME, 
CASE WHEN INSTR(STRMIDDLENAME,' ',1,2) != 0 THEN SUBSTR(STRMIDDLENAME,1,1) || SUBSTR(STRMIDDLENAME,INSTR(STRMIDDLENAME,' ',1,1)+1,1)||
SUBSTR(STRMIDDLENAME,INSTR(STRMIDDLENAME,' ',1,2)+1,1)
WHEN INSTR(STRMIDDLENAME,' ',1,1) != 0 THEN SUBSTR(STRMIDDLENAME,1,1) || SUBSTR(STRMIDDLENAME,INSTR(STRMIDDLENAME,' ',1,1)+1,1)
ELSE SUBSTR(STRMIDDLENAME,1,1)
END AS FIRSTLETTERS
FROM Dual;

OUTPUT
STRMIDDLENAME                    FIRSTLETTERS
---------                        -----------------
Aravind Chaterjee                AC           
Shivakumar                       S
Robin Van Parsee                 RVP

Se você procurar o primeiro caractere de string na string Sql

SELECT CHARINDEX('char', 'my char')

=> return 4

LEFT(colName, 1) também fará isso também. É equivalente a SUBSTRING(colName, 1, 1) .

Eu gosto de LEFT , pois acho um pouco mais limpo, mas na verdade não há diferença.


SELECT SUBSTR(thatColumn, 1, 1) As NewColumn from student




sql-server-2005