오라클 테이블2개 정렬문제;;

netizn82의 이미지

안녕하세요..
테이블2개를 이용한 정렬 문제입니다.;;

테이블1 에는

id , postion
1, 과장
2, 부장
3, 담당
4, 담당자
5, 기타

이렇게 되어있구요,

테이블2 에는

name, addr, postion
홍길동, 울산, 담당
아무개, 서울, 과장
테스트, 강원, 담당자
.
.

이런식으로 되어있습니다.

select 문을 이용하여 출력을 해야하는데, 테이블1을 참조해서 직위별(id 순서대로) 이름을 출력하는 방법이 있을까요?

출력문:
"아무개 - 홍길동 - 테스트"

join을 써야할꺼같은데, 도저히 안되네요;;

도움을 부탁드립니다. ㅠ_ㅠ

db는 오라클입니다;

익명 사용자의 이미지

순수 쿼리만 사용한다는 조건이니깐..

직급이 고정되어 있으면 직급별 서브쿼리를 만들어서 인라인 쿼리를 필드로 구성해서 하면 되겠네요.

select 서브쿼리1.직급, 서브쿼리2.직급, ... 서브쿼리5.직급
from 테이블1, 서브쿼리1, 서브쿼리2... 서브쿼리5
where 테이블1.id = 서브쿼리1.id (+)
and 테이블1.id = 서브쿼리2.id (+)
....
테이블1.id = 서브쿼리5.id (+)

서브쿼리는 각 직급별로 내부 정렬기준(이름이던, 지역이던)을 만들어서 필요한 필드만 추출하면 되겠죠.
서브쿼리의 직급이 없는 것은 필드가 없어지니 별 문제는 없겠죠

2줄요약
1. 직급별 서브쿼리를 각각 만든다
2. 그것을 가지고 테이블1을 기준으로 아웃터 조인 시킨다.

kalstein의 이미지

차라리 테이블2에 테이블1의 id값을 가지는게 더 나아보이네요.
id와 position(postion은 오타...신가요? 그런단어는 없어뵈는데;;)은 1:1매칭이 되고, 실제 어플리케이션에서 id기반으로 자주 order한 결과값이 필요하다면 table 설계를 그렇게 하는게 더 좋아보입니다.

어쨌든...저상황에서 결과물을 한다면...

select a.name
from table1 a, table2 b
where a.position = b.position
order by b.id

이렇게 하면 되지않을까 싶은데요...안되려나? =_=;;


------------------------------------------
Let`s Smart Move!!
http://kalstein.tistory.com/

익명 사용자의 이미지

kalstein님, 저건 세로(필드) 데이타를 가로(레코드)로 바꾸는 문제입니다.

select a.name이 아니고
한 레코드에 select a.name, a.name. a.name... 가 직급순으로 나와야 하는 거죠.

atie의 이미지

설령 위에 손님이 쓰신 것처럼 몇 차례의 서브 쿼리를 써서 SQL로 처리를 할 수 있다고 하더라도 저 같으면 그렇게는 하지 않겠습니다. kalstein님 답변처럼 두번째 테이블에는 직급의 ID가 들어가는 것이 올바르고 (현 상태라면 position으로 join을 해야겠지만), 몇 줄의 결과가 나오는 것을 행으로 표현되게 가공하는 것은 SQL로 처리할 것이 아니라 다른 방법으로 해야겠죠. 같은 테이블을 몇 차례씩 쿼리하는 것은 낭비라는 생각입니다.

----
I paint objects as I think them, not as I see them.
atie's minipage

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.