Answers:
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