생활코딩

Coding Everybody

코스 전체목록

닫기

데이터베이스(MySQL) 이론

데이터베이스 이론1

codeanywhere를 실습환경으로 이용하고 계신 분들은 codeanywhere로 터미널 이용하기 영상을 보시면 다음 영상의 실습을 따라할 수 있습니다.

데이터베이스 이론2

윈도우 

mysql -hlocalhost -uroot -p

리눅스, 맥

./mysql -hlocalhost -uroot -p

데이터베이스 보기

show databases;

데이터베이스 생성

CREATE DATABASE opentutorials CHARACTER SET utf8 COLLATE utf8_general_ci;

데이터베이스 선택

use opentutorials;

테이블 생성

CREATE TABLE `topic` (
`id` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(100) NOT NULL,
  `description` text NOT NULL,
  `author` varchar(30) NOT NULL,
  `created` datetime NOT NULL,
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

생성된 테이블 확인

show tables;

데이터 삽입

INSERT INTO `topic` (`id`, `title`, `description`, `author`, `created`) VALUES(1, 'About JavaScript', '<h3>Desctiption</h3>\r\n<p>JavaScript  is a dynamic computer programming language. It is most commonly used as part of web browsers, whose implementations allow client-side scripts to interact with the user, control the browser, communicate asynchronously, and alter the document content that is displayed.</p>\r\n<p>\r\nDespite some naming, syntactic, and standard library similarities, JavaScript and Java are otherwise unrelated and have very different semantics. The syntax of JavaScript is actually derived from C, while the semantics and design are influenced by the Self and Scheme programming languages.\r\n</p>\r\n<h3>See Also</h3>\r\n<ul>\r\n  <li><a href="http://en.wikipedia.org/wiki/Dynamic_HTML">Dynamic HTML and Ajax (programming)</a></li>\r\n  <li><a href="http://en.wikipedia.org/wiki/Web_interoperability">Web interoperability</a></li>\r\n  <li><a href="http://en.wikipedia.org/wiki/Web_accessibility">Web accessibility</a></li>\r\n</ul>\r\n', 'egoing', '2015-03-31 12:14:00');
INSERT INTO `topic` (`id`, `title`, `description`, `author`, `created`) VALUES(2, 'Variable and Constant', '<h3>Desciption</h3>\r\n\r\nIn computer programming, a variable or scalar is a storage location paired with an associated symbolic name (an identifier), which contains some known or unknown quantity or information referred to as a value. The variable name is the usual way to reference the stored value; this separation of name and content allows the name to be used independently of the exact information it represents. The identifier in computer source code can be bound to a value during run time, and the value of the variable may thus change during the course of program execution.\r\n\r\n<h3>See Also</h3>\r\n<ul>\r\n<li>Non-local variable</li>\r\n<li>Variable interpolation</li>\r\n</ul>\r\n', 'k8805', '2015-05-14 10:04:00');
INSERT INTO `topic` (`id`, `title`, `description`, `author`, `created`) VALUES(3, 'Opeartor', '<h2>Operator</h2>\r\n<h3>Description</h3>\r\n<p>Programming languages typically support a set of operators: constructs which behave generally like functions, but which differ syntactically or semantically from usual functions</p>\r\n<p>Common simple examples include arithmetic (addition with +, comparison with >) and logical operations (such as AND or &&). </p>\r\n', 'egoing', '2015-06-18 05:00:00');
INSERT INTO `topic` (`id`, `title`, `description`, `author`, `created`) VALUES(4, 'Conditional', '<h3>Description</h3>\r\n<p>In computer science, conditional statements, conditional expressions and conditional constructs are features of a programming language which perform different computations or actions depending on whether a programmer-specified boolean condition evaluates to true or false. Apart from the case of branch predication, this is always achieved by selectively altering the control flow based on some condition.</p>\r\n<p>In imperative programming languages, the term "conditional statement" is usually used, whereas in functional programming, the terms "conditional expression" or "conditional construct" are preferred, because these terms all have distinct meanings.</p>\r\n<h3>See Also</h3>\r\n<ul>\r\n<li><a href="http://en.wikipedia.org/wiki/Branch_(computer_science)" title="Branch (computer science)">Branch (computer science)</a></li>\r\n<li><a href="http://en.wikipedia.org/wiki/Conditional_compilation" title="Conditional compilation">Conditional compilation</a></li>\r\n<li><a href="http://en.wikipedia.org/wiki/Dynamic_dispatch" title="Dynamic dispatch">Dynamic dispatch</a> for another way to make execution choices</li>\r\n<li><a href="http://en.wikipedia.org/wiki/McCarthy_Formalism" title="McCarthy Formalism">McCarthy Formalism</a> for history and historical references</li>\r\n<li><a href="http://en.wikipedia.org/wiki/Named_condition" title="Named condition" class="mw-redirect">Named condition</a></li>\r\n<li><a href="http://en.wikipedia.org/wiki/Test_(Unix)" title="Test (Unix)">Test (Unix)</a></li>\r\n<li><a href="http://en.wikipedia.org/wiki/Yoda_conditions" title="Yoda conditions">Yoda conditions</a></li>\r\n</ul>', 'c2', '2015-07-25 00:00:00');

 

댓글

댓글 본문
  1. 허우룩
    2020.09.15
  2. 권오상
    어렵게 어렵게 여기까지 왔습니다.
    위에 INSERT 에서 id 값을 넣으니까 에러가 나서 id 값을 삭제하고 입력하니까 제대로 되네요.
    감사합니다. 많이 배우고 있습니다.^^
  3. Pleasure of Learning
    감사합니다.
  4. HyeonHui Jeong
    5/16 어려운 내용인데 쉽게 설명해주려 노력해주셔서 감사합니다ㅠㅠ
  5. 코딩영재
    There has been an error.
    Error running /Applications/mampstack-7.3.17-1/ctlscript.sh start: httpd.bin: Syntax error on line 139 of /Applications/mampstack-7.3.17-1/apache2/conf/httpd.conf: Cannot load modules/mod_ssl.so into server: dlopen(/Applications/mampstack-7.3.17-1/apache2/modules/mod_ssl.so, 10): Symbol not found: _syslog$DARWIN_EXTSN\n Referenced from: /Applications/mampstack-7.3.17-1/mysql/lib/libcrypto.1.1.dylib (which was built for Mac OS X 10.13)\n Expected in: /usr/lib/libSystem.B.dylib\n in /Applications/mampstack-7.3.17-1/mysql/lib/libcrypto.1.1.dylib
    The application will exit now.

    mac 사용자입니다 bitnami 재설치했더니 저런 에러가 뜨면서 MySQL이 설치되지않습니다 혹시 도와주실수 있나요??
  6. 열심히사는사람
    완료
  7. 산노을
    중딩씨 나도 재설치해봤는데 다른 경로로 하라는데 어째야 하죠?
    살려 주세요 !
  8. 산노을
    아무리해도 안됩니다.
    C::\Bitnami\wampstack-7.3.16-2\mysql\bin>해 놓고

    mysql -hlocalhost -uroot -p 붙이고
    enter하면

    "내부 또는 외부 명령,실행할 수 있는 프로그램, 또는 배치 파일이 아닙니다."
    라고 뜹니다. 거참!

    Help Me!
  9. 중딩
    완료...
    비밀번호 기억했어야 되는데 잘 까먹었습니다
    재설치 하느라 애먹었어여...
  10. wibette
    감사합니다. 정말루요. 눈이 뜨여지는 -쪼금씩 ^^- 느낌.
  11. 완료!!
  12. 아르하트
    감사합니다^^.
  13. 엄청잘될꺼야
    감사합니다. 완료
  14. 웹초보
    20191112 완료

    감사합니다.
  15. xiubin
    **mysql 서버 접속시 아래와 같은 에러뜨는 경우 (windows)

    " ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) "

    아래 링크 참조해서 해결했습니다. 비밀번호를 리셋하는 방법입니다. 도움이 되시길 바라며 댓글로 작성해둡니다.
    https://dev.mysql.com......tml
  16. 들국화
    잘봤습니다
  17. 김재원
    테이블 생성에서 막혔습니다. query ok가 안 나옵니다. 영상에서는 맥으로 하고 있는데, 윈도우 프롬프트로 하는거랑 코드가 다른가요?
  18. 야근요정
    왜 됬는지를 모르겠지만ㅠㅠ
    완료되썽요!!!! description을 discrip 으로 했더니 오케이쿼리뜸ㅎ
  19. 리마인더
    데이터베이스 이론2 중간 비밀번호 설정에서 막힘
    to be continue
  20. 셜리
    비번은 말씀해주시는 걸 못들었네요. ㅎㅎㅎ. 동일하게 설정했거든요. 암튼 완료!
  21. 셜리
    음... 처음으로 의문이 생기네요 ㅎㅎㅎ 비번은 멀 쓰죠? 제 컴은 비번이 설정이 안되어있는데요.^^;;
  22. 예로니
    감사합니다. 덕분에 해결했습니다.
    대화보기
    • 민턴쟁이
      server event 가 아래와 같습니다.
      진도를 못 나가고 있네요 도와주세요

      Starting MySQL Database...
      Exit code: 1
      Stdout:

      Stderr:
      Unknown error starting mysql
    • 민턴쟁이
      bitnami 를 깔때 이상하게 데이터베이스가 에러뜨더니
      역시 데이터베이스 에러가 드네요

      에러 1064
      ㅜㅜ
    • 에러는 그만
      Warning: mysqli_connect(): PHP was built without openssl extension, can't send password encrypted in E:\Bitnami\wampstack-7.1.21-0\apache2\htdocs\php\1.php on line 3라고 계속 뜹니다.

      구글에서는 php.ini에서 extension=php_openssl.dll과 extension=php_mysqli.dll을 주석해야 된다길래 그대로 따라해도 안됩니다. extension_dir="E:\Bitnami\wampstack-7.1.21-0\php\ext"로 바꿨는데도 안되네요...

      문제가 무엇인가요??
    • sung박
      mysql>select id,title,author,created FROM topic셀렉트와 프럼 사이에 컬럼들이 옴
    • HHHHHHHH
      이고잉님 덕분에 너무 잘 공부하고 있습니다

      앱개발에 관련되어있는부분의 지식이 부족하여
      분야가 조금다르지만 이고잉님이라면 어느정도 알고 계시지 않을까 싶어 질문을 드립니다.

      게임을 개발하고 있는데, 많은 게임들이 가지고 있는 기능인 Facebook같은 소셜네트워크와의 연동, 리더보드에 관한 기술적인 부분에 대해서 잘 몰라서 고민이 많습니다.

      이같은 플랫폼과 제 앱을 연동 하려면 API를 보아야 하는 것인가요?
      페이스북 개발자 홈페이지를 둘러보니까 로그인을 연동하려면 Android같은 환경에서 연동시키는 것 처럼 보여서 질문드립니다.

      그렇다면 게임개발은 개발대로하고 API연동을 할 때에는 android나 IOS의 언어를 꼭 알고있어야 하는 것인지 궁금합니다
    • egoing
      윈도우에선 ./ 없이 하셔야 합니다~
      대화보기
      • 초보코딩
        아래에 댓글 남겼다가 다시 씁니다.

        제가 새롭게 시도하면 또 똑같은 에러가 뜨더라구요.
        저는 우분투 사용자인데요

        지금 이고잉님께서 ./mysql -hlocalhost -uroot -p 라고 하셨는데 항상 ./ 를 치면 에러가 났네요

        그냥 /opt/lampstack-7.2.0-0/mysql/bin$ mysql -u root -p 치고 들어가면 잘 들어가집니다....

        문제 해결해서 기쁘네요
      • 초보코딩
        저 같은 분 있을지 모르겠네요.

        ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

        이 에러가 계속 나서 방법을 찾다가 https://help.ubuntu.com......set 여기서 위의 방법은 복잡해서 안 했고 아래 방법으로 purge를 하게 되었습니다. 그랬더니 hlocalhost 를 치지 않고 그냥
        mysql -uroot -p
        이렇게 했더니 들어가지네요 ...! 어떻게 된 건지는 모르겠습니다..

        제가 bitnami를 여러번 설치하게 되면서 localhost:8080을 사용중이었는데 이거랑 관계가 있나요 ?

        근데 hlocalhost, hlocalhost:8080 다 실패했습니다... 전 어디로 접속한걸까요?
      • 코딩잘하고싶어요 ㅎ
        예전에 SQL을 억지로 공부했던 적이 있었는데, 다시 재밌게 공부해보려 합니다.ㅎㅎ SQL에 대해 관심이 생기게 되었습니다.
      • 이현규
        항상 잘보고잇습니다. 궁금한점이 잇어서 질문해보겟습니다
        비트나민설치할때 mysql패스워드를 까먹엇는데 변경하거나 다시 찾는 방법은 어떻게 하나요 ㅠㅠ
      • 슝태
        20180117
      • Keanue
        94번 정리2 동영상을 보다 아래와 같이 mysql_fetch_assoc 오류를 만나신 분 혹시 계시나요?

        PHP Warning: mysqli_fetch_assoc() expects parameter 1 to be mysqli_result, boolean given in C:\\Bitnami\\wampstack-7.0.23-0\\apache2\\htdocs\\practice1\\index.php on line 6

        구글링을 하다가 우연히 답을 찾게 되었는데, 아래가 제가 무턱대고 따라했던 코드들의 원본입니다.
        <?php
        $conn=mysqli_connect('localhost','root','XXXXXX');
        mysqli_select_db($conn,'opentutorials2');
        $sql="SELECT*FROM 'topic'";
        $result=mysqli_query($conn,$sql);
        $row=mysqli_fetch_assoc($result);
        print_r($row);
        ?>
        6번째 라인 $row=mysqli_fetch_assoc($result); 는 해석에 따르면 boolean 은 결국 값이 참이냐 거짓이냐를 말하는 건데, 이 경우는 답이 거짓이라는 거구요. $result값이 거짓으로 나오는 이유는 그 위에 위에 $sql="SELECT*FROM 'topic'"; 에 있었습니다.

        제가 이 문장을 어떻게 수정했냐면 아래와 같이 싱글 quote, 즉 한개 따옴표를 제거했더니 제대로 돌아가기 시작했습니다.
        $sql="SELECT*FROM topic";

        세상에 quote 하나 때문에 며칠을 헤매다가 겨우 답을 찾았는데요... ㅠㅜ
        SQL문에서 ' 한개 따옴표 안에 있는 경우는 문자를 text로 인식해서 그렇다고 하는데요.
        왜 동영상에서는 문제 없이 돌아가던데.. 제가 했을 때는 안됬을까요?
        아무튼 혹시나 저와 동일한 문제로 고민하시는 분 계신다면 도움이 됬으면 합니다.
      • 쪼꼬우유
        끝에 세미콜론 붙이세요ㅋㅋ
        뭐 잘못 치고 엔터쳤다가 새로 입력할라면 \c 치고 엔터 친 다음에 입력하세요
        \c는 잘못입력했다고 친거 없애라고 하는 거예요
        대화보기
        • 1/10 -29일째
          감사합니다.^^
        • PassionOfStudy
          18-01-05 9일차 - 1번째 강의

          수강완료!


          DATABASE mysql 시작~!
        • ㅇㅇ
          저는 ./mysql -hlocalhost -uroot -p하고 비밀번호 제대로 입력했는데 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) 이 에러가 떳어요.
          그때 옛날에 따로 깔아둔 mysql다 지우니까 바로됐습니당...
        • mysql을 하려는데 어느순간부터 mysql이 실행이 안됩니다...어떻게 해결할 수 있을까요?
          비트나미 사용중이고 비트나미 매니저에서
          MySQL Database를 start하면 starting...이 뜨다가 응답 없음 상태가 됩니다.
          그러다가 다시 stopped로 돌아가집니다...어쩌면 좋을까요?
        • 황성찬
          D에 있던 bitnami를 삭제하고 C에 다시 깔았더니 변경이 됐습니다.
          cmd로는 드라이브간의 이동은 불가능한가 보군요
          대화보기
          • 황성찬
            혹시 cmd에서 cd를 할 때 cmd는 C드라이브에 있고 bitnami는 D드라이브에 있으면 디렉토리 변경이 불가한가요?
            똑같이 cd하고 위치 복사도 해보고 자동완성으로 해봐도 오류는 안뜨는데 디렉토리는 변경되지 않습니다.
            관리자 권한으로 실행해보기도 했구요. 저는 탭키로 자동완성을 하면 해당 텍스트에 "" 가 붙는데 혹시 해결 하는 방법이 있을까요?
          • 2017년 12월 21일 수강완료
            오랜만이네요
          • 문외한
            데이터 삽입 예시에 'id'는 없는 게 좋겠네요 강의에도 id는 뺐는데 id가 있으니 INSERT할 때 기존 내용과 충돌하네요.
          • 김현태
            아! 여기있어구나!!!
          • 헬프
            저도 안되었는데 cmd 관리자모드로 여닌까 성공했어요
            대화보기
            • ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ') ENGINE=InnoDB DEFAULT CHARSET=utf8' at line 2

              이런오류가 나는데 오타는 아닌거같은데 무슨이유죠??
            • 결국다시깔아서 다시 공부시작했어요. 제가 어리버리해서 결국해내진못했지만 답글주신분들께 감사드립니다ㅠ
            • 네 다시 까세요~~~ 그 땐 기억 잘하시구요~
              대화보기
              • 비번을 찾느라 링크해주신대로 이것저것 시도해봤는데 잘 안되네요..ㅠ 처음에는 그래도 Enter password라도 나왔는데.. 이것저것 건드린 이후로... mysql -hlocalhost -uroot -p 엔터해도 [ERROR] unknown option'--skip-grant-tables'만 뜨네요...ㅜ 지우고 다시 깔면 해결될까요?ㅜ
              • hanulsso
                비번을 찾았습니다.
                하루만에 다시 진도 나가겠습니다.
                감사합니다~~
              버전 관리
              egoing
              현재 버전
              선택 버전
              graphittie 자세히 보기