如何在SQL中获取字符串的第一个字符?

Vin*_*nod 230 sql sql-server sql-server-2005

我有一个长度为6的SQL列.现在只想获取该列的第一个字符.SQL中是否有任何字符串函数可以执行此操作?

Eri*_*ric 394

LEFT(colName, 1)也会这样做.它相当于SUBSTRING(colName, 1, 1).

我喜欢LEFT,因为我发现它有点清洁,但实际上,两种方式都没有区别.

  • @thomasrutter,查看执行计划,SQL Server(至少2008R2)在内部将`LEFT(colName,length)`转换为`SUBSTRING(colName,1,length)`.所以**这里没有任何优化**,这只是一个偏好. (12认同)
  • 我不了解 SQL 服务器,但从逻辑上讲,数据库服务器在使用索引时可能能够比 SUBSTRING 更好地优化 LEFT。 (2认同)

one*_*hen 38

我更喜欢:

SUBSTRING (my_column, 1, 1)
Run Code Online (Sandbox Code Playgroud)

因为它是标准的SQL-92语法,因此更具可移植性.


严格来说,标准版本将是

SUBSTRING (my_column FROM 1 FOR 1)
Run Code Online (Sandbox Code Playgroud)

关键是,从一个转换到另一个,因此转变为任何类似的供应商变化,都是微不足道的.

ps最近才向我指出,标准SQL中的函数是故意相反的,通过使参数列表不是传统的commalists,以使它们易于识别为符合标准!


Dam*_*isa 15

SUBSTRING ( MyColumn, 1 , 1 )对于第一个角色和SUBSTRING ( MyColumn, 1 , 2 )前两个角色.


Dev*_*rma 7

SELECT SUBSTR(thatColumn, 1, 1) As NewColumn from student
Run Code Online (Sandbox Code Playgroud)


jet*_*ong 7

通过以下方式实现此目标很简单:

DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)
Run Code Online (Sandbox Code Playgroud)

或者

SET @Result = SUBSTRING(@SomeString, 2, 3)
SELECT @Result
Run Code Online (Sandbox Code Playgroud)

@结果: his

-要么-

SET @Result = LEFT(@SomeString, 6)
SELECT @Result
Run Code Online (Sandbox Code Playgroud)

@结果: This i


小智 5

选择所选字段中的前两个字符Left(string,Number of Char in int)

SELECT LEFT(FName, 2) AS FirstName FROM dbo.NameMaster
Run Code Online (Sandbox Code Playgroud)