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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在SQL中获取字符串的第一个字符?相关的知识,希望对你有一定的参考价值。

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

答案

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

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

另一答案

我更喜欢:

SUBSTRING (my_column, 1, 1)

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


严格来说,标准版本将是

SUBSTRING (my_column FROM 1 FOR 1)

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

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

另一答案

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

另一答案

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
另一答案

如果在Sql字符串中搜索字符串的第一个字符串

SELECT CHARINDEX('char', 'my char')

=> return 4
另一答案

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

SELECT LEFT(FName, 2) AS FirstName FROM dbo.NameMaster

以上是关于如何在SQL中获取字符串的第一个字符?的主要内容,如果未能解决你的问题,请参考以下文章

sql 如何使用SQL在字符串中找到字符串的第一个位置?

Android - 如何显示包含从片段中获取的字符串的快餐栏

SQL查询中,如何判断一个字符串字段的内容的长度

Python姓名字段的第一个字符为姓,剩余字符为名

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

如何在 SQL 或 PL/SQL 中查找给定字符串(列数据)中的第 5 个字符? [关闭]