【发布时间】:2010-10-21 23:51:47
【问题描述】:
我有一个长度为 6 的 SQL 列。现在只想获取该列的第一个字符。 SQL中是否有任何字符串函数可以做到这一点?
【问题讨论】:
标签: sql sql-server sql-server-2005
我有一个长度为 6 的 SQL 列。现在只想获取该列的第一个字符。 SQL中是否有任何字符串函数可以做到这一点?
【问题讨论】:
标签: sql sql-server sql-server-2005
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)
关键是,从一个转换到另一个,因此转换为任何类似的供应商变体,都是微不足道的。
附言直到最近才向我指出,标准 SQL 中的函数是故意相反的,其参数列表不是传统的 commalist,以便使它们易于识别为来自标准!
【讨论】:
SUBSTRING ( MyColumn, 1 , 1 ) 用于第一个字符,SUBSTRING ( MyColumn, 1 , 2 ) 用于前两个字符。
【讨论】:
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
【讨论】:
如果在Sql字符串中搜索字符串的第一个字符
SELECT CHARINDEX('char', 'my char')
=> return 4
【讨论】:
使用Left(string,Number of Char in int)选择选定字段中的前两个字符
SELECT LEFT(FName, 2) AS FirstName FROM dbo.NameMaster
【讨论】: