:: 게시판
:: 이전 게시판
|
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다. 통합 규정을 준수해 주십시오. (2015.12.25.)
통합규정 1.3 이용안내 인용"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
17/03/17 00:51
일단 "팀"을 제거하시고 그냥 1,2,3,QR만 넣으세요. 그리고 나서 그러면 replace는 제거할 수 있을 겁니다. 굳이 int로 하지 않아도 알파벳 순서대로 하면 1,2,3,QR이 될꺼에요.
그리고 distinct를 하는 이유를 알면 좋을 것 같습니다.. 집계를 하거나 할게 아니면 distinct는 앵간하면 불필요합니다. 정규화가 잘못되어 있다는 말이라서요. 전체 스키마를 볼 수 있으면 좀 더 시원한 답변을 드릴 수 있을 것 같네요.
17/03/17 09:00
아뇨.. 팀을 제거해도 해당 컬럼이 varchar형이라서 8,9 다음에 10이 안오고 14,15 다음에 1,2가 옵니다..ㅜㅜ
distinct 하려는 이유는 웹개발때문입니다. 어떤화면에서 조건 검색을 해야하는데 그럴려면 저 컬럼안에 어떠한 항목들이 있는지 중복제거해서 정렬해서 콤보박스에 보여줘야합니다. SQL 완전 쌩초보라서 위 댓글의 order by의 case문도 업렵고 아래댓글의 right함수나 group by도 어렵네요..OTL 일단 select a2 from test order by case when a2 like '%팀' then convert(int,replace(a2,'팀','')) end 이렇게해서 영문+팀 다음에 숫자+팀이 정렬되도록했어요~! 근데 앞에 select distinct a2 로 중복제거하면 여전히 [SELECT DISTINCT가 지정된 경우에는 ORDER BY 항목이 SELECT 목록에 나타나야 합니다.] 라는 에러가 뜨네요 으앙 미쳐 ㅜㅜ
17/03/24 13:27
아 이제야 댓글을 봤는데요. 드랍다운 용이라면
테이블을 하나더 만드세요. 여기서는 지금 검색 조건에 팀을 주기위한 드랍다운이잖아요. 그러면 이 결과를 distinct할게 아니라 create table dbo.tbl_team ( teamcode int primary key, teamname nvarchar(100) null) 이런식으로 만들고 저 테이블을 SELECT하는 SP를 그 드랍다운에 바인딩 하시는게 비교도 안되게 효율적입니다.
17/03/17 07:49
SQL을 만진지 오래되서 가물가물하네요. 숫자로 변환하는 것도 가능하지만 그냥 숫자 앞에 동일하게 0을 붙여서 정렬시키는 것도 가능합니다. 오류 메세지에 의하면,
SELECT distinct a2, RIGHT(CONCAT('00000', a2), 5) as zero_pad_a2 FROM test ORDER BY zero_pad_a2 등과 같이 해서 선택 결과에서 a2만 사용하면 되지 않을까 싶네요. 함수는 DBMS마다 다르니 MSSQL에 맞는 함수로 하시면 되지 않을까 싶네요. 위의 RIGHT(..., 5)의 두번째 인자는 a2의 최대 길이로 맞추면 됩니다. distinct가 잘 안 된다면 group by를 적절하게 쓰셔도 됩니다.
17/03/17 11:45
어떤 공부형태로 궁금하신거면 저라면 0을 붙이고 int로 안바꾼다... 즉 자리수 맞추는걸로 하겠습니다.
그런데, 실무라면 a2 컬럼 옆에 a3 만들어서 order sequence (중복 불가, int) 넣어 줄거 같습니다. order by a3 형태로...
|