[MSSQL] AAA~ZZZ 체번하기 (AAA,AAB,AAC,AAD...ZZZ)

2019. 5. 16. 19:58IT/MS-SQL

반응형

이걸 응용하면 AA~ZZ, AAAA~ZZZZ 도 가능하다.

 

Data 가 없이 시작하는 경우 isnull 조건을 추가하면된다.

isnull 은 Z 로 하면 바로 AAA 부터 시작이다.

 

그게 귀찮다면? 그냥 기본값으로 ZZZ를 하나 넣어두고 시작하면 된다.

---- AAA 에서 ZZZ 까지 순서대로 체번하기

select char(
case ASCII(substring(MAX(AAAZZZ),2,1))
when 90
then case ASCII(substring(MAX(AAAZZZ),3,1))
when 90
then case ASCII(substring(MAX(AAAZZZ),1,1))
when 90
then 65
else ASCII(substring(MAX(AAAZZZ),1,1))+1 end
else ASCII(substring(MAX(AAAZZZ),1,1))+1 end
else ASCII(substring(MAX(AAAZZZ),1,1)) end
)

+ char(
case ASCII(substring(MAX(AAAZZZ),3,1))
when 90
then case ASCII(substring(MAX(AAAZZZ),2,1))
when 90
then 65
else ASCII(substring(MAX(AAAZZZ),2,1))+1 end
else ASCII(substring(MAX(AAAZZZ),2,1)) end
)

+ char(
case ASCII(substring(MAX(AAAZZZ),3,1))
when 90
then 65
else ASCII(substring(MAX(AAAZZZ),3,1))+1 end
) as MARKING
from TEST_TABLE

 

반응형