sql 한가지..

tombraid의 이미지

다음과 같이 들어있는 테이블이 있을때..
1 A
1 B
1 C
2 A
2 B
...

사용자가 A,B,C 를 입력하면 1을 리턴하고,
사용자가 A,B 를 입력하면 1, 2를 리턴하는 쿼리를 만들고 싶습니다.

단, 테이블에는 더 많은 값들이 들어있고, 사용자가 입력할 수 있는 개수도 제한이 없습니다.

어제 밤에 생각하다가 잠들었는데, 잘 안떠오르네요. :oops:

futari의 이미지

조금 더 조건과 상황을 확실하게 명시해 주시는게 좋을 듯 합니다.

저것만 봐서는 어디까지 쿼리에서 하겠다는 건지...

한줄 쿼리로 저걸 하시겠다는 건가요?

-------------------------
The universe is run by the complex interweaving of three elements: matter, energy, and enlightened self-interest.
- G'kar, Babylon 5

tombraid의 이미지

제가 질문을 모호하게 했나요?? 글적..

여러 집합이 표현되어 있을때, 주어진 집합을 포함하는 집합을 구하고 싶은 겁니다.

위의 예에서 보면 1 이라는 집합은 (A, B, C) 로 이루어 진것이고, 2 라는 집합은 (A, B)로 이루어 진것이죠..

대충 테이블은 set_name, entry 라는 두 필드를 가진것으로 생각한 것이구요.

만약 사용자가 (A,B,C) 라는 집합을 지정했을때, 이 집합을 포함할 수 있는 건 1번 집합 뿐일 것이구요, 사용자가 (A,B) 라는 집합을 지정했을때는 1, 2 집합이 모두 포함할 수 있게 되는것이죠..

이렇게 사용자가 지정한 집합을 포함하는 집합을 쉽게 찾아낼 수 있는 쿼리를 원한 것이었습니다.

아직 이렇게 하면 좋겠다라는게 떠오르지 않아서요.. ^^;;

익명 사용자의 이미지

select distinct(a.number) from table a, table b, table c
where a.number = b.number and b.number = c.number
and a.alpha in (입력한것) and b.alpha in (입력한것)
and b.alpha <> a.alpha and c.alpha in (입력한것)
and c.alpha <> a.alpha and c.alpha <> b.alpha

물론 입력한것이 더 많으면, 쿼리가 더 늘어나겠죠..
이보다 더 간단한 쿼리식이 존재할것 같긴 하지만,
일종의 통계쿼리인 관계로 느린건 어쩔수 없습니다.
alpha컬럼을 기준으로 새로운 테이블을 생성하고,
그 테이블을 이용하여, 쿼리하시는것이 좋다고 생각합니다.

tombraid의 이미지

우선 답변 감사합니다.

사용자가 지정한 집합의 크기만큼 테이블을 중복하여 값을 얻어내는 방식이군요.

이런식으론 생각해보지 못했는뎅.. 감사합니다.

동적인 sql 구성으로 어떻게든 만들어 볼 수 있겠지만, 집합의 크기가 늘어날수록 쿼리가 너무 길어지고 보기 안좋아지겠네용.. ^^;;; ;

alpha 컬럼을 기준으로 테이블을 생성하는게 좋을것 같다고 하셨는데, 어떤 스키마를 가진 테이블이 좋을까요?

tombraid의 이미지

괜찮은 쿼리 인지는 모르겠지만....

나름대로는 쓸만한 아이디어 인것 같아서 다음과 같이 하기로 했습니다.

select set_name from (
    select set_name, count(*) cnt from table 
        where entry in (사용자 지정 집합) group by set_name
    ) where cnt = (사용자 지정 집합의 원소 개수);

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.