Відповіді:
LEFT(colName, 1)
також це зробимо. Це рівнозначно SUBSTRING(colName, 1, 1)
.
Мені це подобається LEFT
, оскільки я вважаю його трохи чистішим, але насправді, різниці немає.
LEFT(colName, length)
на SUBSTRING(colName, 1, length)
. Так що тут немає ніяких оптимізацій , це лише вподобання.
Я віддаю перевагу:
SUBSTRING (my_column, 1, 1)
тому що це стандартний синтаксис SQL-92 і тому більш портативний.
Строго кажучи, стандартна версія була б
SUBSTRING (my_column FROM 1 FOR 1)
Справа в тому, що перетворення від одного до іншого, отже, до будь-якого подібного варіанта постачальника є тривіальним.
ps Мене нещодавно вказували, що функції в стандартному SQL навмисно суперечать, маючи списки параметрів, які не є звичайними комуністами, щоб зробити їх легко ідентифікованими як стандартні!
SELECT SUBSTR(thatColumn, 1, 1) As NewColumn from student
Це легко досягти наступним чином
DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)
Або
SET @Result = SUBSTRING(@SomeString, 2, 3)
SELECT @Result
@Result = his
або
SET @Result = LEFT(@SomeString, 6)
SELECT @Result
@Result = This i
ВХОД
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