Risposte:
LEFT(colName, 1)
farà anche questo. È equivalente a SUBSTRING(colName, 1, 1)
.
Mi piace LEFT
, dato che lo trovo un po 'più pulito, ma in realtà, non c'è differenza in entrambi i modi.
LEFT(colName, length)
in SUBSTRING(colName, 1, length)
. Quindi non ci sono ottimizzazioni qui, è solo una preferenza.
Preferisco:
SUBSTRING (my_column, 1, 1)
perché è sintassi SQL-92 standard e quindi più portabile.
A rigor di termini, la versione standard sarebbe
SUBSTRING (my_column FROM 1 FOR 1)
Il punto è che passare dall'una all'altra, quindi a qualsiasi variazione simile del venditore, è banale.
ps Mi è stato fatto notare solo di recente che le funzioni nello standard SQL sono deliberatamente contrarie, avendo elenchi di parametri che non sono i comunisti convenzionali, al fine di renderli facilmente identificabili come appartenenti allo standard!
SELECT SUBSTR(thatColumn, 1, 1) As NewColumn from student
È semplice ottenere quanto segue
DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)
O
SET @Result = SUBSTRING(@SomeString, 2, 3)
SELECT @Result
@Result = his
o
SET @Result = LEFT(@SomeString, 6)
SELECT @Result
@Result = This i
INGRESSO
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