Как получить первый символ строки в SQL? - PullRequest
203 голосов
/ 27 апреля 2009

У меня есть столбец SQL длиной 6. Теперь хочу взять только первый символ этого столбца. Есть ли строковые функции в SQL для этого?

Ответы [ 8 ]

363 голосов
/ 27 апреля 2009

LEFT(colName, 1) тоже сделает это. Это эквивалентно SUBSTRING(colName, 1, 1).

Мне нравится LEFT, так как я нахожу это немного чище, но на самом деле нет никакой разницы в любом случае.

33 голосов
/ 27 апреля 2009

Я предпочитаю:

SUBSTRING (my_column, 1, 1)

потому что это стандартный синтаксис SQL-92 и, следовательно, более переносимый.


Строго говоря, стандартная версия будет

SUBSTRING (my_column FROM 1 FOR 1)

Дело в том, что переход от одного к другому, следовательно, к любому подобному варианту вендора, тривиален.

p.s. Только недавно мне было указано, что функции в стандартном SQL намеренно противоречат тем, что имеют списки параметров, которые не являются обычными коммалистами, чтобы их можно было легко идентифицировать как стандартные!

13 голосов
/ 27 апреля 2009

SUBSTRING ( MyColumn, 1 , 1 ) для первого символа и SUBSTRING ( MyColumn, 1 , 2 ) для первых двух.

6 голосов
/ 19 июля 2016

Это легко сделать следующим образом:

DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)

и либо

SET @Result = SUBSTRING(@SomeString, 2, 3)
SELECT @Result

@ Результат: his

1010 * -ИЛИ- *

SET @Result = LEFT(@SomeString, 6)
SELECT @Result

@ Результат: This i

5 голосов
/ 19 ноября 2012
SELECT SUBSTR(thatColumn, 1, 1) As NewColumn from student
1 голос
/ 19 ноября 2012

ВХОД

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
0 голосов
/ 20 апреля 2019

Выберите первые два символа в выбранном поле с помощью Left(string,Number of Char in int)

SELECT LEFT(FName, 2) AS FirstName FROM dbo.NameMaster
0 голосов
/ 07 марта 2012

Если вы ищете первый символ строки в строке Sql

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

=> return 4
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...