我有一个长度为6的SQL列。现在只想获取该列的第一个字符。 SQL中是否有任何字符串函数可以执行此操作?
答案 0 :(得分:362)
LEFT(colName, 1)
也会这样做。它相当于SUBSTRING(colName, 1, 1)
。
我喜欢LEFT
,因为我发现它有点清洁,但实际上,两种方式都没有区别。
答案 1 :(得分:33)
我更喜欢:
SUBSTRING (my_column, 1, 1)
因为它是标准的SQL-92语法,因此更具可移植性。
严格来说,标准版本将是
SUBSTRING (my_column FROM 1 FOR 1)
关键是,从一个转换到另一个,因此转变为任何类似的供应商变化,都是微不足道的。
P.S。最近才向我指出,标准SQL中的函数是故意相反的,通过使参数列表不是传统的commalists,以便使它们易于识别为符合标准!
答案 2 :(得分:13)
SUBSTRING ( MyColumn, 1 , 1 )
,前两个字符为SUBSTRING ( MyColumn, 1 , 2 )
。
答案 3 :(得分:6)
通过以下方式实现这一目标很简单:
DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)
和
SET @Result = SUBSTRING(@SomeString, 2, 3)
SELECT @Result
@Result:his
-OR -
SET @Result = LEFT(@SomeString, 6)
SELECT @Result
@Result:This i
答案 4 :(得分:1)
INPUT
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
答案 5 :(得分:0)
如果在Sql string
中搜索字符串的第一个字符串SELECT CHARINDEX('char', 'my char')
=> return 4
答案 6 :(得分:0)
使用Left(string,Number of Char in int)
在所选字段中选择前两个字符
SELECT LEFT(FName, 2) AS FirstName FROM dbo.NameMaster