Как получить первый символ строки в SQL?
У меня есть столбец SQL с длиной 6. Теперь хочу взять только первый символ этой колонки. Есть ли какая-либо строковая функция в SQL для этого?
7 ответов
LEFT(colName, 1)
также сделает это, также. Это эквивалентно SUBSTRING(colName, 1, 1)
.
мне нравится LEFT
, так как я найти его немного чище, но на самом деле, нет никакой разницы в любом случае.
Я предпочитаю:
SUBSTRING (my_column, 1, 1)
потому что это стандартный синтаксис SQL-92 и, следовательно, более портативный.
строго говоря, стандартная версия будет
SUBSTRING (my_column FROM 1 FOR 1)
дело в том, что преобразование от одного к другому, следовательно, к любой подобной вариации поставщика, тривиально.
p.s. Только недавно мне было указано, что функции в стандартном SQL намеренно противоречат, имея списки параметров, которые не являются обычными коммалисты, чтобы их можно было легко идентифицировать как выходцев из стандарта!
это просто, чтобы достичь этого, следуя:
DECLARE @SomeString NVARCHAR(20) = 'This is some string'
DECLARE @Result NVARCHAR(20)
и
SET @Result = SUBSTRING(@SomeString, 2, 3)
SELECT @Result
@результат: his
или
SET @Result = LEFT(@SomeString, 6)
SELECT @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