MYSQL 채팅관련 DB 질문

qkrwncks593의 이미지

유저들이 카카오톡처럼 있고 유저마다 입장한 톡방이있는데 어떤방에 입장했는지 관리할때

유저테이블안에 들어간방 컬럼을 만들어서 구분자로 나눠 리스트로 저장하는게 좋을까요 아니면

유저가 들어간방 테이블을 따로 만들어서 관리하는게 좋을까요?

속도면에서 어떤게 좋을지몰라서 질문드립니다.

shint의 이미지

1개일때는 조금 더 빠릅니다.

글을 보니. AUTOINCREASE 를 사용했을때. 성능이 좋다고 하기도 하네요.
인덱스를 설정했을때의 성능향상도 있지만. 오류가 나는 경우도 있으니 주의해야 하구요.
테이블 오류가 나는경우도 있다고 하니 주의해야 합니다.

그렇지만.
한번에 여러개를 처리하는 경우에 대한 조건'이 관계가 있을거 같습니다.

이것저것 만들어서 테스트해보세요.
하드. SSD. 성능. 메모리. CPU. 사양. OS. 비트수. 드라이버. 네트워크. 최적화. 보안. 방법등등... 책...

-----------------------------
테이블 컬럼 n1
행(레코드) 보기 0 - 29 ( 99,999 합계, 질의 실행시간 0.0005 초)
SELECT * FROM `fast1` WHERE 1 LIMIT 0 , 30

-----------------------------
테이블 컬럼 n1 n2 n3 n4 n5 n6
행(레코드) 보기 0 - 29 (100,000 합계, 질의 실행시간 0.0009 초)
SELECT n1 FROM `fast2` WHERE 1 LIMIT 0 , 30

행(레코드) 보기 0 - 29 (100,000 합계, 질의 실행시간 0.0010 초)
SELECT * FROM `fast2` WHERE 1 LIMIT 0 , 30

-----------------------------
테스트 코드

< ?php
 
$mysqli = new mysqli('localhost','root','apmsetup','fast');
if (mysqli_connect_errno()) 
{
  printf("Connection failed: %s\n", mysqli_connect_error());
  exit();
}
 
 
$i=0;
for($i=0; $i<100000; $i++)
{
$query = <<< EOF
INSERT INTO `fast`.`fast2` (`n1`,`n2`,`n3`,`n4`,`n5`,`n6`)VALUES ('$i','$i','$i','$i','$i','$i');
EOF;
 
    $SQL = $query;
    echo $SQL . "<BR>";
    if ( ($result = $mysqli->query($SQL))===false )
    {
      printf("Invalid query: %s\nWhole query: %s\n", $mysqli->error, $SQL);
    }
}
 
 
 
$mysqli->close();
 
 
? >

-----------------------------
mysql 컬럼 갯수와 속도'로 검색

https://www.google.co.kr/search?q=mysql+%EC%BB%AC%EB%9F%BC+%EA%B0%AF%EC%88%98%EC%99%80+%EC%86%8D%EB%8F%84&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:ko:official&client=firefox-a&gfe_rd=cr&ei=ziqOVtq8O8bC8gfcv7zwDg&gws_rd=ssl

https://search.naver.com/search.naver?where=nexearch&frm=ff&sm=oss&ie=utf8&query=mysql+%EC%BB%AC%EB%9F%BC+%EA%B0%AF%EC%88%98%EC%99%80+%EC%86%8D%EB%8F%84

----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.

매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.

각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com

댓글 달기

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