Respostas:
LEFT(colName, 1)
também fará isso também. É equivalente a SUBSTRING(colName, 1, 1)
.
Eu gosto LEFT
, já que acho um pouco mais limpo, mas, realmente, não há diferença de qualquer maneira.
LEFT(colName, length)
em SUBSTRING(colName, 1, length)
. Portanto, não há otimizações aqui, é apenas uma preferência.
Eu prefiro:
SUBSTRING (my_column, 1, 1)
porque é a sintaxe padrão do SQL-92 e, portanto, mais portátil.
A rigor, a versão padrão seria
SUBSTRING (my_column FROM 1 FOR 1)
A questão é que a transformação de uma para a outra, portanto, para qualquer variação similar de fornecedor, é trivial.
ps Foi recentemente apontado para mim que as funções no SQL padrão são deliberadamente contrárias, por ter listas de parâmetros que não são os commalistas convencionais, a fim de torná-los facilmente identificáveis como sendo do padrão!
SELECT SUBSTR(thatColumn, 1, 1) As NewColumn from student
É simples de conseguir através do seguinte
DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)
Ou
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