SlideShare a Scribd company logo
MySQL을 이용한
데이터베이스 실습

웹데이터베이스 구축 및 실습
자료 관리


MySQL을 이용한 데이터베이스 실습
INSERT : 자료의 입력- PART I
만들어져 있는 Table에 자료를 저장한다.
http://dev.mysql.com/doc/refman/5.1/en/insert.html
  • 위 링크의 기본 형을 바탕으로 새롭게 다음과 같은 형태를 추천한다.


     INSERT INTO tbl_name [(col_name, … )]
                  VALUES (value, …), … , (value);
자료 입력
    > INSERT INTO major (mid, mname) VALUES (1, '통계학과');
    > INSERT INTO major (mname) VALUES ('수학과‘);
    > INSERT INTO dept_tab VALUES
   +> (3, '컴퓨터공학과'),
   +> (4, '전자공학과');
                                  > SET CHARATER SET euckr;

한림대학교 웹데이터베이스 - 이윤환
UPDATE : 자료의 변경
기존 데이터의 행을 선택해서 특정 열의 값 변경
  • 조건절이 없으면 전체 테이블의 지정한 열의 값을 하나로 변경한다.

행의 선택 (WHERE 문)
  • DB는 기본적으로 행단위로 데이터를 다룬다.
  • WHERE는 특정 조건을 주어 해당 조건에 맞는 행을 선택하도록 한다.
  • 조건들은 AND와 OR 에 의해 결합된다.
http://dev.mysql.com/doc/refman/5.1/en/update.html 을 바탕으로 다음과
같이 사용한다.
         UPDATE tbl_name SET
         col_name1={expr1|DEFAULT}
         [, col_name2={expr2|DEFAULT}] ...
         [WHERE where_condition]
         [ORDER BY ...]
         [LIMIT row_count]

한림대학교 웹데이터베이스 - 이윤환
UPDATE : 자료의 변경
예제
 • 학생정보에서 학과 코드 3을 2로 잘못 입력하여 변경
     • student 에서 smajor가 2인 행을 찾아 3으로 변경
  > UPDATE student SET smajor = 3 WHERE smajor = 2;

 • 컴퓨터 공학과의 이름이 둘리인 학생이 이름을 희동이로 개명하여
   바꾸고자 한다.
     • 둘리가 이름인 학생이 여러명 있을 수 있으므로 학과 코드가
       3이고 이름이 둘리인 학생의 이름을 희동이로 변경한다.
  > UPDATE student SET sname = '희동이'
 +> WHERE sname = '둘리' AND smajor = 3




한림대학교 웹데이터베이스 - 이윤환
DELETE : 자료 삭제
조건에 맞는(WHERE) 행을 선택하고 삭제
http://dev.mysql.com/doc/refman/5.1/en/delete.html 을 바탕으로 다
음과 같이 사용한다.

          DELETE   FROM tbl_name
          [WHERE   where_condition]
          [ORDER   BY ...]
          [LIMIT   row_count]
예제
  • 학번이 20121001번인 학생의 데이터를 삭제하라.
      > DELETE FROM student WHERE sid = ‘20121001’;
  • WHERE 이후가 생략되면 해당 테이블의 전체 데이터 삭제
      > DELETE FROM student_tab;



한림대학교 웹데이터베이스 - 이윤환
SELECT : 자료 검색
실제 DB에서 가장 많이 사용되는 기능
조건에 부합(WHERE) 하는 행을 선택하여 보여준다.
http://dev.mysql.com/doc/refman/5.1/en/select.html


SELECT select_expr [, select_expr ...]
  [FROM table_references
  [WHERE where_condition]
  [GROUP BY {col_name | expr | position}
    [ASC | DESC], ... [WITH ROLLUP]]
  [HAVING where_condition]
  [ORDER BY {col_name | expr | position}
    [ASC | DESC], ...]
  [LIMIT {[offset,] row_count | row_count OFFSET offset}]



한림대학교 웹데이터베이스 - 이윤환
SELECT : 자료 검색
예제
 • 원활한 실습을 위해 다음 입력
      INSERT INTO student VALUES
         (NULL, '20121001', '고길동', 51, ‘M’, 1),
         (NULL, '20121002', '둘리', 25, ‘M’, 2),
         (NULL, '20121003', '희동이', 5, ‘M’, 1),
         (NULL, '20121004', '도우너', 24, ‘M’, 3),
         (NULL, '20121005', '또치', 28, ‘M’, 4),
         (NULL, '20121006', '마이콜', 41, ‘M’, 1),
         (NULL, '20121007', '철수', 10, ‘M’, 3),
         (NULL, '20121008', '영희', 11, ‘F’, 2);




한림대학교 웹데이터베이스 - 이윤환
SELECT : 자료 검색
 • 학과 코드 1번에 해당하는 학생 검색
    SELECT * FROM student WHERE smajor = 1;

 • 학과 코드 1번에 해당하는 학생들의 학번과 이름 검색
    SELECT sid, same FROM student WHERE smajor = 1;

 • 학과별 학생수검색
    • count(열이름) : 열의 숫자 반환;
    SELECT smajor, count(smajor) as '명'
                 FROM student GROUP BY smajor;

 • 학과 코드가 1인 학과를 제외한 학과별 학생수 검색
    SELECT smajor, count(smajor) as '명'
                 FROM student GROUP BY smajor
                 HAVING smajor <> 1;



한림대학교 웹데이터베이스 - 이윤환
SELECT : 자료 검색
 • 과목코드 순으로 학번과 학생 이름 출력 (동일 학과 내에
   서는 학번의 역순)
    SELECT smajor, sid, same
                 FROM student
                 ORDER BY smajor ASC, sid DESC;


 • 학번이 가장 빠른 학생의 학번과 이름 출력
     • 학번의 오름차순으로 정렬하고 그중 첫번째 행 출
       력
    SELECT sid, sname FROM student
                        ORDER BY sid LIMIT 0, 1;




 한림대학교 금융정보통계
한림대학교 웹데이터베이스 - 이윤환              이   윤   환,
PHP와의 연동


MySQL을 이용한 데이터베이스 실습
MYSQL 과 연결
mysql_connect()
 • http://kr.php.net/manual/en/function.mysql-connect.php
 • resource mysql_connect (
         [ string $server = ini_get("mysql.default_host")
         [, string $username = ini_get("mysql.default_user")
         [, string $password = ini_get("mysql.default_password")
         [, bool $new_link = false
         [, int $client_flags = 0 ]]]]] )
       • $server : MySQL Server 명
       • $username : 접속할 MySQL 사용자명
       • $password : 접속할 사용자의 암호
mysql_close()
 • http://kr.php.net/manual/en/function.mysql-close.php
 • bool mysql_close ([ resource $link_identifier ] )
       • $link_identifier : 앞서 수립한 연결정보를 담고 있는 변수
Ex. mysql_connect.php

한림대학교 웹데이터베이스 - 이윤환
mysql_select_db()
 • http://kr.php.net/manual/en/function.mysql-select-db.php
 • bool mysql_select_db (
       string $database_name
       [, resource $link_identifier ] )
       • $database_name : 사용할 DB 명
       • $link_identifier : 연결 정보를 담고 있는 변수
 • Ex. mysql_select_db.php




한림대학교 웹데이터베이스 - 이윤환
쿼리 수행
mysql_query()
 • http://kr.php.net/manual/en/function.mysql-query.php
 • resource mysql_query (
       string $query [, resource $link_identifier ] )
       • $query : 수행할 SQL 문 혹은 MySQL 명령어
       • $link_identifier : 연결 정보를 담고 있는 변수
 • Ex.
    $result = mysql_query('SELECT mid, mname FROM major');
    if (!$result) {
        die('Could not query:' . mysql_error());
    }




한림대학교 웹데이터베이스 - 이윤환
쿼리 결과 처리 – 영향을 받은 행의 수
mysql_affected_rows
 • http://kr.php.net/manual/en/function.mysql-affected-rows.php
 • int mysql_affected_rows ([ resource $link_identifier ] )
        • $link_identifier : 연결 정보를 담고 있는 함수
 • Insert, update, delete의 결과로 영향을 받은 행의 수 반환
mysql_num_rows()
 • http://kr.php.net/manual/en/function.mysql-num-rows.php
 • int mysql_num_rows ( resource $result )
        • $result : mysql_query()를 통한 결과 집합
 • Select 문을 통해 선택된 행의 수 반환
Ex. mysql_counting.php



한림대학교 웹데이터베이스 - 이윤환
쿼리 결과 가져오기
mysql_result
 • http://kr.php.net/manual/en/function.mysql-result.php
 • string mysql_result ( resource $result ,
                 int $row
                 [, mixed $field = 0 ] )
        • $result : mysql_query의 결과 집합
        • $row : 가져올 행 선택 (0부터 시작)
        • $field : 가져올 열 순서(0부터 시작)
 • Ex. mysql_result.php
 • 별로 안 좋은 선택




한림대학교 웹데이터베이스 - 이윤환
쿼리 결과 가져오기
mysql_fetch_array
 • http://kr.php.net/manual/en/function.mysql-fetch-array.php
 • array mysql_fetch_array ( resource $result
                  [, int $result_type = MYSQL_BOTH ] )
        • $result : mysql_query의 결과 집합
        • $result_type
              • MYSQL_BOTH : 열의 결과를 열의 이름의 연관배열과 순서 인
                덱스 모두로 가져온다.
              • MYSQL_NUM : 열의 결과를 순서 인덱스로 가져온다.
              • MYSQL_ASSOC : 열의 결과를 열의 이름의 연관배열로 가져온
                다.
        • 한 번 수행할 때 결과 셋의 첫번째 행을 가져오고 그 다음 수행할 때
           다음 행을 가져온다.
        • 순환문과 함께 쓰인다
 • Ex. mysql_fetch_array.php


한림대학교 웹데이터베이스 - 이윤환

More Related Content

What's hot (20)

PDF
현대고등학교 PHP 강의 - 5차시 (설리번 프로젝트)
Ukjae Jeong
 
PDF
웹 개발 스터디 01 - MySQL
Yu Yongwoo
 
PPTX
Web vulnerability seminar4
Sakuya Izayoi
 
PPTX
Web vulnerability seminar2
Sakuya Izayoi
 
PDF
MySQL JOIN
Hoyoung Jung
 
PDF
웹 개발 스터디 01 - PHP, MySQL 연동
Yu Yongwoo
 
PDF
웹 개발 스터디 01 - PHP 파일 업로드, 다운로드
Yu Yongwoo
 
PPTX
Hacosa j query 4th
Seong Bong Ji
 
PDF
MySQL delete.update
Hoyoung Jung
 
PPTX
Web vulnerability seminar3
Sakuya Izayoi
 
PDF
12주차 간단한 방명록 제작 - 두번째
Yoonwhan Lee
 
PPTX
5-3. html5 device access
JinKyoungHeo
 
PDF
Ksug2015 jpa5 스프링과jpa
Younghan Kim
 
PPTX
HTML Form과 배열
Yoonwhan Lee
 
PDF
웹 개발 스터디 01 - PHP
Yu Yongwoo
 
PPTX
Mongo DB 완벽가이드 - 4장 쿼리하기
JangHyuk You
 
PDF
Jstl_GETCHA_HANJUNG
Jung Han
 
KEY
vine webdev
dcfc1997
 
PPT
자바야 놀자 PPT
JinKyoungHeo
 
PPTX
제2회 한글형태소분석기 기술 세니마 발표(solr 활용 입문) by 김지훈
jihoon kim
 
현대고등학교 PHP 강의 - 5차시 (설리번 프로젝트)
Ukjae Jeong
 
웹 개발 스터디 01 - MySQL
Yu Yongwoo
 
Web vulnerability seminar4
Sakuya Izayoi
 
Web vulnerability seminar2
Sakuya Izayoi
 
MySQL JOIN
Hoyoung Jung
 
웹 개발 스터디 01 - PHP, MySQL 연동
Yu Yongwoo
 
웹 개발 스터디 01 - PHP 파일 업로드, 다운로드
Yu Yongwoo
 
Hacosa j query 4th
Seong Bong Ji
 
MySQL delete.update
Hoyoung Jung
 
Web vulnerability seminar3
Sakuya Izayoi
 
12주차 간단한 방명록 제작 - 두번째
Yoonwhan Lee
 
5-3. html5 device access
JinKyoungHeo
 
Ksug2015 jpa5 스프링과jpa
Younghan Kim
 
HTML Form과 배열
Yoonwhan Lee
 
웹 개발 스터디 01 - PHP
Yu Yongwoo
 
Mongo DB 완벽가이드 - 4장 쿼리하기
JangHyuk You
 
Jstl_GETCHA_HANJUNG
Jung Han
 
vine webdev
dcfc1997
 
자바야 놀자 PPT
JinKyoungHeo
 
제2회 한글형태소분석기 기술 세니마 발표(solr 활용 입문) by 김지훈
jihoon kim
 

Viewers also liked (20)

PDF
PHP 사용하기
Yoonwhan Lee
 
PDF
php 시작하기
Yoonwhan Lee
 
PPTX
PHP 함수와 제어구조
Yoonwhan Lee
 
PPTX
PHP 기초 문법
Yoonwhan Lee
 
PDF
Resin.io
Andrea Ranieri
 
PPTX
Introducing resinOS: An Operating System Tailored for Containers and Built fo...
Balena
 
PDF
XECon2015 :: [1-1] 안정수 - XE3 구조 및 기본기
XpressEngine
 
PDF
현대고등학교 PHP 강의 - 1차시 (설리번 프로젝트)
Ukjae Jeong
 
PPTX
trello 사용법 및 좋은 팀대표란?
용현 정
 
PDF
Nodejs를 이용한 개발
WebFrameworks
 
PDF
읽기 좋은 코드가 좋은코드다
wonmin lee
 
PDF
깃헙으로 코드리뷰 하기
Ohgyun Ahn
 
PPT
Meteor를 통해서 개발하는 웹어플리케이션 서비스
WebFrameworks
 
PDF
MariaDB Optimization
JongJin Lee
 
PDF
R 기초 : R Basics
Yoonwhan Lee
 
PPTX
Trello
용환 전
 
PPTX
소스리딩워크샵 - NHN NEXT
Minsuk Lee
 
PDF
임영기님 - 코드 리뷰 시스템 도입하기
OnGameServer
 
PDF
개발자가 도전하는 MariaDB 서버구축
정해 이
 
PDF
Github 사용법
jong seok Kim
 
PHP 사용하기
Yoonwhan Lee
 
php 시작하기
Yoonwhan Lee
 
PHP 함수와 제어구조
Yoonwhan Lee
 
PHP 기초 문법
Yoonwhan Lee
 
Resin.io
Andrea Ranieri
 
Introducing resinOS: An Operating System Tailored for Containers and Built fo...
Balena
 
XECon2015 :: [1-1] 안정수 - XE3 구조 및 기본기
XpressEngine
 
현대고등학교 PHP 강의 - 1차시 (설리번 프로젝트)
Ukjae Jeong
 
trello 사용법 및 좋은 팀대표란?
용현 정
 
Nodejs를 이용한 개발
WebFrameworks
 
읽기 좋은 코드가 좋은코드다
wonmin lee
 
깃헙으로 코드리뷰 하기
Ohgyun Ahn
 
Meteor를 통해서 개발하는 웹어플리케이션 서비스
WebFrameworks
 
MariaDB Optimization
JongJin Lee
 
R 기초 : R Basics
Yoonwhan Lee
 
Trello
용환 전
 
소스리딩워크샵 - NHN NEXT
Minsuk Lee
 
임영기님 - 코드 리뷰 시스템 도입하기
OnGameServer
 
개발자가 도전하는 MariaDB 서버구축
정해 이
 
Github 사용법
jong seok Kim
 
Ad

Similar to MySQL과 PHP (20)

PPTX
10주차 php 사용하기-iii
Yoonwhan Lee
 
PDF
성공적인웹프로그래밍
dgmong
 
PPTX
Apache solr소개 20120629
Dosang Yoon
 
PDF
R 스터디 두번째
Jaeseok Park
 
PDF
집단지성 프로그래밍 03-군집발견-03
Kwang Woo NAM
 
PDF
My sql특징 정리
parktaesoon
 
PPTX
R 프로그래밍-향상된 데이타 조작
Terry Cho
 
PPTX
03주차 ddl- table을 만들자
Yoonwhan Lee
 
PDF
Laravel 로 배우는 서버사이드 #4
성일 한
 
PPTX
Data Mining with R CH1 요약
Sung Yub Kim
 
PDF
R 에서의 서브쿼리
yu yeon su
 
PDF
Fundamentals of Oracle SQL
JAEGEUN YU
 
PPTX
R 프로그램의 이해와 활용 v1.1
happychallenge
 
PPTX
R intro
주영 송
 
PDF
R을 이용한 데이터 분석
simon park
 
PPTX
02주차 ddl- db를 만들자
Yoonwhan Lee
 
PPTX
03주차 ddl- table을 만들자
Yoonwhan Lee
 
PPTX
04주차 ddl- table을 만들자-2
Yoonwhan Lee
 
PDF
제2장 데이터 조회하기
sang doc Lee
 
PDF
[Pgday.Seoul 2021] 1. 예제로 살펴보는 포스트그레스큐엘의 독특한 SQL
PgDay.Seoul
 
10주차 php 사용하기-iii
Yoonwhan Lee
 
성공적인웹프로그래밍
dgmong
 
Apache solr소개 20120629
Dosang Yoon
 
R 스터디 두번째
Jaeseok Park
 
집단지성 프로그래밍 03-군집발견-03
Kwang Woo NAM
 
My sql특징 정리
parktaesoon
 
R 프로그래밍-향상된 데이타 조작
Terry Cho
 
03주차 ddl- table을 만들자
Yoonwhan Lee
 
Laravel 로 배우는 서버사이드 #4
성일 한
 
Data Mining with R CH1 요약
Sung Yub Kim
 
R 에서의 서브쿼리
yu yeon su
 
Fundamentals of Oracle SQL
JAEGEUN YU
 
R 프로그램의 이해와 활용 v1.1
happychallenge
 
R intro
주영 송
 
R을 이용한 데이터 분석
simon park
 
02주차 ddl- db를 만들자
Yoonwhan Lee
 
03주차 ddl- table을 만들자
Yoonwhan Lee
 
04주차 ddl- table을 만들자-2
Yoonwhan Lee
 
제2장 데이터 조회하기
sang doc Lee
 
[Pgday.Seoul 2021] 1. 예제로 살펴보는 포스트그레스큐엘의 독특한 SQL
PgDay.Seoul
 
Ad

More from Yoonwhan Lee (20)

PDF
03.기술통계 자료의 중심과 퍼진정도
Yoonwhan Lee
 
PDF
02.자료다루기
Yoonwhan Lee
 
PDF
01.r 기초
Yoonwhan Lee
 
PDF
13.상관과 회귀
Yoonwhan Lee
 
PDF
12.세표본 이상의 평균비교
Yoonwhan Lee
 
PDF
11.두표본의 평균비교
Yoonwhan Lee
 
PDF
10.단일표본 평균 모비율
Yoonwhan Lee
 
PDF
09.통계적가설검정
Yoonwhan Lee
 
PDF
08.추정
Yoonwhan Lee
 
PDF
07.표본분포
Yoonwhan Lee
 
PDF
06.확률분포
Yoonwhan Lee
 
PDF
05.확률
Yoonwhan Lee
 
PDF
00.통계학입문
Yoonwhan Lee
 
PDF
14.범주형자료분석
Yoonwhan Lee
 
PPTX
Smart work 자료 1
Yoonwhan Lee
 
PPTX
통계자료 분석을 위한 R
Yoonwhan Lee
 
PDF
통계자료분석을 ㅇ
Yoonwhan Lee
 
PPTX
추정
Yoonwhan Lee
 
PPTX
쿠키를 통해 구현해보는 간단한 로그인 과정
Yoonwhan Lee
 
PPTX
에버노트와 드롭박스 설치
Yoonwhan Lee
 
03.기술통계 자료의 중심과 퍼진정도
Yoonwhan Lee
 
02.자료다루기
Yoonwhan Lee
 
01.r 기초
Yoonwhan Lee
 
13.상관과 회귀
Yoonwhan Lee
 
12.세표본 이상의 평균비교
Yoonwhan Lee
 
11.두표본의 평균비교
Yoonwhan Lee
 
10.단일표본 평균 모비율
Yoonwhan Lee
 
09.통계적가설검정
Yoonwhan Lee
 
08.추정
Yoonwhan Lee
 
07.표본분포
Yoonwhan Lee
 
06.확률분포
Yoonwhan Lee
 
05.확률
Yoonwhan Lee
 
00.통계학입문
Yoonwhan Lee
 
14.범주형자료분석
Yoonwhan Lee
 
Smart work 자료 1
Yoonwhan Lee
 
통계자료 분석을 위한 R
Yoonwhan Lee
 
통계자료분석을 ㅇ
Yoonwhan Lee
 
추정
Yoonwhan Lee
 
쿠키를 통해 구현해보는 간단한 로그인 과정
Yoonwhan Lee
 
에버노트와 드롭박스 설치
Yoonwhan Lee
 

MySQL과 PHP

  • 2. 자료 관리 MySQL을 이용한 데이터베이스 실습
  • 3. INSERT : 자료의 입력- PART I 만들어져 있는 Table에 자료를 저장한다. http://dev.mysql.com/doc/refman/5.1/en/insert.html • 위 링크의 기본 형을 바탕으로 새롭게 다음과 같은 형태를 추천한다. INSERT INTO tbl_name [(col_name, … )] VALUES (value, …), … , (value); 자료 입력 > INSERT INTO major (mid, mname) VALUES (1, '통계학과'); > INSERT INTO major (mname) VALUES ('수학과‘); > INSERT INTO dept_tab VALUES +> (3, '컴퓨터공학과'), +> (4, '전자공학과'); > SET CHARATER SET euckr; 한림대학교 웹데이터베이스 - 이윤환
  • 4. UPDATE : 자료의 변경 기존 데이터의 행을 선택해서 특정 열의 값 변경 • 조건절이 없으면 전체 테이블의 지정한 열의 값을 하나로 변경한다. 행의 선택 (WHERE 문) • DB는 기본적으로 행단위로 데이터를 다룬다. • WHERE는 특정 조건을 주어 해당 조건에 맞는 행을 선택하도록 한다. • 조건들은 AND와 OR 에 의해 결합된다. http://dev.mysql.com/doc/refman/5.1/en/update.html 을 바탕으로 다음과 같이 사용한다. UPDATE tbl_name SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ... [WHERE where_condition] [ORDER BY ...] [LIMIT row_count] 한림대학교 웹데이터베이스 - 이윤환
  • 5. UPDATE : 자료의 변경 예제 • 학생정보에서 학과 코드 3을 2로 잘못 입력하여 변경 • student 에서 smajor가 2인 행을 찾아 3으로 변경 > UPDATE student SET smajor = 3 WHERE smajor = 2; • 컴퓨터 공학과의 이름이 둘리인 학생이 이름을 희동이로 개명하여 바꾸고자 한다. • 둘리가 이름인 학생이 여러명 있을 수 있으므로 학과 코드가 3이고 이름이 둘리인 학생의 이름을 희동이로 변경한다. > UPDATE student SET sname = '희동이' +> WHERE sname = '둘리' AND smajor = 3 한림대학교 웹데이터베이스 - 이윤환
  • 6. DELETE : 자료 삭제 조건에 맞는(WHERE) 행을 선택하고 삭제 http://dev.mysql.com/doc/refman/5.1/en/delete.html 을 바탕으로 다 음과 같이 사용한다. DELETE FROM tbl_name [WHERE where_condition] [ORDER BY ...] [LIMIT row_count] 예제 • 학번이 20121001번인 학생의 데이터를 삭제하라. > DELETE FROM student WHERE sid = ‘20121001’; • WHERE 이후가 생략되면 해당 테이블의 전체 데이터 삭제 > DELETE FROM student_tab; 한림대학교 웹데이터베이스 - 이윤환
  • 7. SELECT : 자료 검색 실제 DB에서 가장 많이 사용되는 기능 조건에 부합(WHERE) 하는 행을 선택하여 보여준다. http://dev.mysql.com/doc/refman/5.1/en/select.html SELECT select_expr [, select_expr ...] [FROM table_references [WHERE where_condition] [GROUP BY {col_name | expr | position} [ASC | DESC], ... [WITH ROLLUP]] [HAVING where_condition] [ORDER BY {col_name | expr | position} [ASC | DESC], ...] [LIMIT {[offset,] row_count | row_count OFFSET offset}] 한림대학교 웹데이터베이스 - 이윤환
  • 8. SELECT : 자료 검색 예제 • 원활한 실습을 위해 다음 입력 INSERT INTO student VALUES (NULL, '20121001', '고길동', 51, ‘M’, 1), (NULL, '20121002', '둘리', 25, ‘M’, 2), (NULL, '20121003', '희동이', 5, ‘M’, 1), (NULL, '20121004', '도우너', 24, ‘M’, 3), (NULL, '20121005', '또치', 28, ‘M’, 4), (NULL, '20121006', '마이콜', 41, ‘M’, 1), (NULL, '20121007', '철수', 10, ‘M’, 3), (NULL, '20121008', '영희', 11, ‘F’, 2); 한림대학교 웹데이터베이스 - 이윤환
  • 9. SELECT : 자료 검색 • 학과 코드 1번에 해당하는 학생 검색 SELECT * FROM student WHERE smajor = 1; • 학과 코드 1번에 해당하는 학생들의 학번과 이름 검색 SELECT sid, same FROM student WHERE smajor = 1; • 학과별 학생수검색 • count(열이름) : 열의 숫자 반환; SELECT smajor, count(smajor) as '명' FROM student GROUP BY smajor; • 학과 코드가 1인 학과를 제외한 학과별 학생수 검색 SELECT smajor, count(smajor) as '명' FROM student GROUP BY smajor HAVING smajor <> 1; 한림대학교 웹데이터베이스 - 이윤환
  • 10. SELECT : 자료 검색 • 과목코드 순으로 학번과 학생 이름 출력 (동일 학과 내에 서는 학번의 역순) SELECT smajor, sid, same FROM student ORDER BY smajor ASC, sid DESC; • 학번이 가장 빠른 학생의 학번과 이름 출력 • 학번의 오름차순으로 정렬하고 그중 첫번째 행 출 력 SELECT sid, sname FROM student ORDER BY sid LIMIT 0, 1; 한림대학교 금융정보통계 한림대학교 웹데이터베이스 - 이윤환 이 윤 환,
  • 11. PHP와의 연동 MySQL을 이용한 데이터베이스 실습
  • 12. MYSQL 과 연결 mysql_connect() • http://kr.php.net/manual/en/function.mysql-connect.php • resource mysql_connect ( [ string $server = ini_get("mysql.default_host") [, string $username = ini_get("mysql.default_user") [, string $password = ini_get("mysql.default_password") [, bool $new_link = false [, int $client_flags = 0 ]]]]] ) • $server : MySQL Server 명 • $username : 접속할 MySQL 사용자명 • $password : 접속할 사용자의 암호 mysql_close() • http://kr.php.net/manual/en/function.mysql-close.php • bool mysql_close ([ resource $link_identifier ] ) • $link_identifier : 앞서 수립한 연결정보를 담고 있는 변수 Ex. mysql_connect.php 한림대학교 웹데이터베이스 - 이윤환
  • 13. mysql_select_db() • http://kr.php.net/manual/en/function.mysql-select-db.php • bool mysql_select_db ( string $database_name [, resource $link_identifier ] ) • $database_name : 사용할 DB 명 • $link_identifier : 연결 정보를 담고 있는 변수 • Ex. mysql_select_db.php 한림대학교 웹데이터베이스 - 이윤환
  • 14. 쿼리 수행 mysql_query() • http://kr.php.net/manual/en/function.mysql-query.php • resource mysql_query ( string $query [, resource $link_identifier ] ) • $query : 수행할 SQL 문 혹은 MySQL 명령어 • $link_identifier : 연결 정보를 담고 있는 변수 • Ex. $result = mysql_query('SELECT mid, mname FROM major'); if (!$result) { die('Could not query:' . mysql_error()); } 한림대학교 웹데이터베이스 - 이윤환
  • 15. 쿼리 결과 처리 – 영향을 받은 행의 수 mysql_affected_rows • http://kr.php.net/manual/en/function.mysql-affected-rows.php • int mysql_affected_rows ([ resource $link_identifier ] ) • $link_identifier : 연결 정보를 담고 있는 함수 • Insert, update, delete의 결과로 영향을 받은 행의 수 반환 mysql_num_rows() • http://kr.php.net/manual/en/function.mysql-num-rows.php • int mysql_num_rows ( resource $result ) • $result : mysql_query()를 통한 결과 집합 • Select 문을 통해 선택된 행의 수 반환 Ex. mysql_counting.php 한림대학교 웹데이터베이스 - 이윤환
  • 16. 쿼리 결과 가져오기 mysql_result • http://kr.php.net/manual/en/function.mysql-result.php • string mysql_result ( resource $result , int $row [, mixed $field = 0 ] ) • $result : mysql_query의 결과 집합 • $row : 가져올 행 선택 (0부터 시작) • $field : 가져올 열 순서(0부터 시작) • Ex. mysql_result.php • 별로 안 좋은 선택 한림대학교 웹데이터베이스 - 이윤환
  • 17. 쿼리 결과 가져오기 mysql_fetch_array • http://kr.php.net/manual/en/function.mysql-fetch-array.php • array mysql_fetch_array ( resource $result [, int $result_type = MYSQL_BOTH ] ) • $result : mysql_query의 결과 집합 • $result_type • MYSQL_BOTH : 열의 결과를 열의 이름의 연관배열과 순서 인 덱스 모두로 가져온다. • MYSQL_NUM : 열의 결과를 순서 인덱스로 가져온다. • MYSQL_ASSOC : 열의 결과를 열의 이름의 연관배열로 가져온 다. • 한 번 수행할 때 결과 셋의 첫번째 행을 가져오고 그 다음 수행할 때 다음 행을 가져온다. • 순환문과 함께 쓰인다 • Ex. mysql_fetch_array.php 한림대학교 웹데이터베이스 - 이윤환