데이타베이스 디자인을 어떻게 해야 될지 고민입니다.

jagalchee의 이미지

p2p서버를 짜는 중인데요. p2p 서버는 클라이언트들이 가지고 있는 파일 목록들을 데이타베이스를 이용해서 관리하려고 합니다.
우선 생각한 테이블 디자인은 다음과 같습니다.

첫째로, 접속한 클라이언트들의 목록을 저장하는 테이블을 만듭니다.
이 테이블의 애트리뷰트는 2개로 아이피주소와 소켓번호입니다.(한 컴퓨터내에서 다중접속을 허용하므로, 소켓번호도 포합시켰습니다.)

둘째로, 하나의 접속 클라이언트마다 그 클라이언트가 공유하고 있는 파일목록들을 저장하는 테이블을 만듭니다. 이 테이블의 애트리뷰트는 1개로, 파일이름입니다. 한 row에 파일명 1개씩이 저장됩니다. 그리고 테이블명은 해당 클라이언트의 소켓 번호로 할 생각입니다.

위와 같이 디자인을 해놓고 보면, 우선 클라이언트가 서버에 접속을 해서 파일 목록을 업로드 할때 접속 정보를 테이블에 저장하고, 새로운 파일목록 테이블을 만드는 것에서는 별 무리가 없습니다.그리고 클라이언트가 서버와의 접속을 끊을때에에도 접속 정보를 삭제하고, 해당하는 파일 목록 테이블을 삭제하는 것도 별 무리가 없습니다.

헌데 어떤 클라이언트가 특정 이름으로 된 파일을 검색할 때 약간의 애로 사항이 있습니다. 즉, 어떤 클라이언트가 검색을 해달라고 서버에 요청을 하면, 서버는 현재 자신이 가지고 있는 파일 목록 테이블 모두를 뒤져야 하는데요. 그럴려면, 테이블 이름을 모두 알고 있어야 합니다. 그래서 생각한 방식이 서버 프로그램에서 클라이언트가 접속할 때마다 그 클라이언트의 소켓 번호를 특정 어레이에 차곡차곡 저장을 하는 방식입니다. 그런데 이렇게 하는것 말고, 서버에서는 그 어떤 정보도 저장해 있지 않고 데이타베이스에만 의존해서 검색을 진행하고 싶습니다.

테이블 디자인을 어떻게 하면 이런것이 효율적으로 가능할까요? 이왕이면 검색할 때, 쿼리 한번에 검색이 되었으면 좋겠습니다만... 아니면 위 디자인말고 좀 더 효율적인 디자인이 있으면 한 수 알려주시기 부탁드립니다.

sjpark의 이미지

[하나의 접속 클라이언트마다 그 클라이언트가 공유하고 있는 파일목록들을 저장하는 테이블을 만듭니다]

테이블을 따로 만들지 말고.

특정 테이블에

클라이언트 구별 키와 파일 이름을 함께 두어 구분하는 것은 어떨까요?

그런데 왜 파일 목록을 서버가 관리해야 하죠?
(혹시..다른 흑심이..=_=?)

댓글 달기

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