June 5, 2018 at 4:35 am
Hi I have one doubt in sql server .
how to get first position to right side specific character position.
table : empfiles
filename:
ab_re_uk_u_20101001
ax_by_us_19991001
abc_20181002
I want output like below:
filename
ab_re_uk_u
ax_by_us
abc
I tried like below :
select SUBSTRING(filename,1,CHARINDEX('2',filename) - 1) as filename from empfiles
above query is not given expected result please tell me how to write query to achive this task in sql server .
June 5, 2018 at 5:51 am
I wouldn't expect that value of give the correct result, your CHARINDEX would return the position of the first underscore after the 2nd character. As you're looking for the last one, you'd be better use using REVERSE, and then CHARINDEX:WITH VTE AS(
SELECT *
FROM (VALUES('ab_re_uk_u_20101001'),('ax_by_us_19991001'),('abc_20181002')) V([filename]))
SELECT LEFT([filename], LEN([filename]) - CHARINDEX('_',REVERSE([filename])))
FROM VTE;
Thom~
Excuse my typos and sometimes awful grammar. My fingers work faster than my brain does.
Larnu.uk
June 5, 2018 at 10:27 am
Thom A - Tuesday, June 5, 2018 5:51 AMI wouldn't expect that value of give the correct result, your CHARINDEX would return the position of the first underscore after the 2nd character. As you're looking for the last one, you'd be better use using REVERSE, and then CHARINDEX:WITH VTE AS(
SELECT *
FROM (VALUES('ab_re_uk_u_20101001'),('ax_by_us_19991001'),('abc_20181002')) V([filename]))
SELECT LEFT([filename], LEN([filename]) - CHARINDEX('_',REVERSE([filename])))
FROM VTE;
Or maybe even as simple as this, if the ending is always _YYYYMMDD:
WITH vte2
AS
(
SELECT *
FROM
(
VALUES
(
'ab_re_uk_u_20101001'
)
, (
'ax_by_us_19991001'
)
, (
'abc_20181002'
)
) V (filename)
)
SELECT LEFT(vte2.filename, LEN(vte2.filename)-9)
FROM vte2;
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
June 20, 2018 at 6:15 am
;with t(txt) as (
select 'ab_re_uk_u_20101001' union all
select 'ax_by_us_19991001' union all
select 'abc_20181002'
)
select txt,
REVERSE(txt) tmp1,
CHARINDEX('_',REVERSE(txt)) tmp2,
LEN(txt) tmp3,
right(REVERSE(txt), len(txt)-CHARINDEX('_',REVERSE(txt))) tmp4,
reverse(right(REVERSE(txt), len(txt)-CHARINDEX('_',REVERSE(txt)))) this_s_your_answer
from t
O/p -
txt | tmp1 | tmp2 | tmp3 | tmp4 | this_s_your_answer |
ab_re_uk_u_20101001 | 10010102_u_ku_er_ba | 9 | 19 | u_ku_er_ba | ab_re_uk_u |
ax_by_us_19991001 | 10019991_su_yb_xa | 9 | 17 | su_yb_xa | ax_by_us |
abc_20181002 | 20018102_cba | 9 | 12 | cba | abc |
June 20, 2018 at 6:23 am
create table Q (col varchar(20))
insert into q select 'ab_re_uk_u_20101001' union all
select 'ax_by_us_19991001' union all
select 'abc_20181002'
select *,substring(col,0,patindex('%[0-9]%',col)-1) from q
***The first step is always the hardest *******
June 20, 2018 at 6:30 am
ranitb - Wednesday, June 20, 2018 6:15 AMSomething like this ?;with t(txt) as (
select 'ab_re_uk_u_20101001' union all
select 'ax_by_us_19991001' union all
select 'abc_20181002'
)
select txt,
REVERSE(txt) tmp1,
CHARINDEX('_',REVERSE(txt)) tmp2,
LEN(txt) tmp3,
right(REVERSE(txt), len(txt)-CHARINDEX('_',REVERSE(txt))) tmp4,
reverse(right(REVERSE(txt), len(txt)-CHARINDEX('_',REVERSE(txt)))) this_s_your_answer
from tO/p -
txt tmp1 tmp2 tmp3 tmp4 this_s_your_answer ab_re_uk_u_20101001 10010102_u_ku_er_ba 9 19 u_ku_er_ba ab_re_uk_u ax_by_us_19991001 10019991_su_yb_xa 9 17 su_yb_xa ax_by_us abc_20181002 20018102_cba 9 12 cba abc
REVERSE() is an expensive operation and your code is way more complex than the other suggestions! Would be nice to hear back from the OP to see what they ended up using.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
June 20, 2018 at 6:48 am
Phil Parkin - Wednesday, June 20, 2018 6:30 AMREVERSE() is an expensive operation and your code is way more complex than the other suggestions! Would be nice to hear back from the OP to see what they ended up using.
Hi Phil,
Yes, that's true - it's lot expensive. I was just playing around, but found much better responses already posted. 🙂
Viewing 7 posts - 1 through 6 (of 6 total)
You must be logged in to reply to this topic. Login to reply