Как получить первый символ строки в SQL?


262

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

Ответы:


436

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

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


2
Я не знаю, что такое сервер SQL, но логически сервер базы данных может оптимизировать LEFT лучше, чем SUBSTRING, когда он использует индекс.
Томасруттер

19
@thomasrutter, Глядя на план выполнения, SQL Server (по крайней мере, 2008R2) внутренне переводится LEFT(colName, length)в SUBSTRING(colName, 1, length). Так что здесь нет никаких оптимизаций , это просто предпочтение.
Александр Абакумов

44

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

SUBSTRING (my_column, 1, 1)

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


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

SUBSTRING (my_column FROM 1 FOR 1)

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

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


1
Спасибо, LEFT (str, n) не поддерживается многими форматами (включая тот, который я использую).
GreySage

1
Почему индекс начинается с 1, а не с 0? Это возвращает тот же результат: SUBSTRING (my_column, 1, 1) = SUBSTRING (my_column, 0, 2). Что это в позиции 0?
FrenkyB

19

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



13

Это легко достичь с помощью следующего

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


3

ВХОД

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

2

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

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

=> return 4

2

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

SELECT LEFT(FName, 2) AS FirstName FROM dbo.NameMaster
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.