RadarURL

웹 프로그래밍
2014.04.29 17:37

PHP MySQL 명령어 실행 함수 mysql_query

조회 수 2578 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

[PHP MySQL 명령어 실행 함수 mysql_query]

php에서 데이터베이스(MySQL)에게 SQL 명령어를 실행시키기 위해서는 mysql_query 함수가 사용됩니다.
sql 명령어라 두리뭉실하게 말씀드렸는데, 이것을 기능에 의해서 세분화 해보면 아래와 같습니다.

DDL(데이터정의어) - CREATE, ALTER, DROP
DML(데이터조작어) - SELECT, INSERT, UPDATE, DELETE
DCL(데이터제어어) - GRANT, REVOKE, CASECADE, RESTRICT

mysql_query 함수는 SQL 명령어라면 위의 세가지중 대부분(정확히 전부 테스트해 보지 못했슴)을 멋지게 실행시킵니다. 아래의 예제는 mysql_query 함수를 이용해서 어여쁜 테이블 하나를 만들고 있습니다.

<?php
include("dbcon.php");

$sql = "CREATE TABLE test_member ( ";
$sql = $sql . " seq int not null auto_increment, ";
$sql = $sql . " memuid varchar(20) NOT NULL, ";
$sql = $sql . " name varchar(20) NOT NULL, ";
$sql = $sql . " addr varchar(255) NOT NULL, ";
$sql = $sql . " PRIMARY KEY(seq), ";
$sql = $sql . " UNIQUE memuid (memuid) );";

$result = mysql_query($sql) or die("SQL문 제대로 쓴거 맞아???");

if($result) echo "테이블 Create 성공!!";
?>

다음은 위의 예제에서 생성된 test_member 테이블에 INSERT 문을 이용해서 하나의 레코드를 추가하는 예제입니다.

<?php
include("dbcon.php");

$memuid = "webmadang.net";
$name = "웹마당넷";
$addr = "어쩌시 어쩌구 어쩌동 111-11";

$sql = "INSERT INTO test_member SET ";
$sql = $sql . " memuid ='$memuid', ";
$sql = $sql . " name ='$name', ";
$sql = $sql . " addr ='$addr' ";

$result = mysql_query($sql) or die("또 틀리면 죽는다!!!");
$rows = mysql_affected_rows();

if($result) echo "INSERT로 입력된 레코드의 갯수는:$rows";
?>

MySQL에게 전달된 SQL 명령어가 INSERT, UPDATE, DELETE, DROP 등이라면 mysql_query 함수의 실행결과가 참일때 TRUE를 반환하게 되며 mysql_affected_rows 함수를 이용해서 변경된 레코드의 갯수를 알수 있습니다. 위의 예제가 성공하게 되면 "INSERT로 입력된 레코드의 갯수는:1" 이라는 문자열이 출력됩니다.

아래 예제는 SELECT 문을 이용해서 위의 예제에서 입력된 레코드를 화면에 출력하게 됩니다.

<?php
include("dbcon.php");

$sql = "SELECT memuid, name, addr FROM test_member ";

$result = mysql_query($sql) or die("제대로 좀 써봐!!!");
while($row = mysql_fetch_row($result))
echo"'$row[0]' '$row[1]' '$row[2]'<br>\n";
?>

select 문의 실행결과로 반환된 레코드셋(data set)을 가져오기 위해서는 mysql_fetch 시리즈로 시작되는 함수들중 하나를 사용해야 합니다. 위에 사용된 mysql_fetch_row 함수는 레코드셋을 배열로 반환하는데 개별 컬럼의 값을 가져오기 위해서는 위와 같이 컬럼의 순서를 나타내는 번호를 사용해야 합니다.

echo"'$row[0]' '$row[1]' '$row[2]'<br>\n";

반환된 레코드셋을 컬럼명을 이용해서 참조하기 위해서는 mysql_fetch_array 함수를 사용합니다.
아래 예제는 위의 예제에서 사용된 mysql_fetch_row 함수를 mysql_fetch_array 함수로 바꿔 사용했습니다.

<?php
include("dbcon.php");


$sql = "SELECT memuid, name, addr FROM test_member ";

$result = mysql_query($sql) or die("제대로 좀 써봐!!!");
while($row = mysql_fetch_array($result)){
echo"'$row[memuid]' '$row[name]' '$row[addr]'<br>\n";
echo"'$row[0]' '$row[1]' '$row[2]'<br>\n";
}
?>

위의 예제에서 보이듯이 mysql_fetch_array 함수는 컬럼의 값을 가져올때 컬럼명이든 컬럼의 번호든 상관없습니다.

마지막으로 MySQL 테이블에서 레코드셋이 아닌 단 한개의 데이터만 가져올수 있는 mysql_result 함수가 있습니다.
아래는 mysql_result 함수의 사용예제입니다.

<?php
include("dbcon.php");


$sql = "SELECT memuid, name, addr FROM test_member ";

$result = mysql_query($sql) or die("제대로 좀 써봐!!!");
echo mysql_result($result,0,0)."<br>\n";
echo mysql_result($result,0,1)."<br>\n";;
echo mysql_result($result,0,2)."<br>\n";;

?>

mysql_result 함수는 mysql_fetch_row 함수나 mysql_fetch_array 함수보다 두개의 인자를 더 취하는데 첫번째 인자는 레코드(행)번호이고, 두번째 인자는 컬럼의 번호입니다. 특이한 점은 레코드 번호나 컬럼의 번호가 1부터 시작하는게 아니고 0 부터 시작한다는 것입니다.

mysql_result($result,0,0) 은 첫번째 레코드, 첫번째 컬럼을 의미합니다.
mysql_result($result,0,1) 은 첫번째 레코드, 두번째 컬럼을 의미합니다.
mysql_result($result,0,2) 은 첫번째 레코드, 세번째 컬럼을 의미합니다.

mysql_result($result,1,1) 은 두번째 레코드, 두번째 컬럼을 의미합니다.
mysql_result($result,1,2) 은 두번째 레코드, 세번째 컬럼을 의미합니다.
mysql_result($result,1,3) 은 두번째 레코드, 네번째 컬럼을 의미합니다.


php4 이전버전에서는 mysql_fetch_row 함수가, mysql_fetch_array 함수보다 속도면에서 빠른것으로 소개되었으나, 현재는 속도차이가 거의 없다고 합니다.

위의 include("dbcon.php") 는 MySQL의 접속 명령어가 삽입되어 있는 dbcon.php 파일을 포함하라는
뜻입니다. dbcon.php 파일의 내용은 다음과 같을 것입니다.

<?php
$hostname = "localhost"; // 호스트를 식별할 수 있는 호스트명이나 ip
$user = "myuser"; // MySQL에서 사용할 데이터베이스 사용자명
$password = "********"; // MySQL에서 사용할 데이터베이스에 접속하기 비밀번호
$database = "testdb"; // MySQL에서 사용할 데이타베이스명
$connect = mysql_connect ($hostname, $user, $password) or die ("데이터베이스 접속실패");;
mysql_select_db ($database, $connect);
?>

 

출처 : http://www.webmadang.net/develop/develop.do?action=read&boardid=1003&page=2&seq=44

?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 950261
346 응용 프로그래밍 WIndows Application의 실행 속도 측정 file YooN 2023.09.06 3906
345 웹 프로그래밍 메모리 부족 현상 (allowed memory size of 134217728 bytes..) YooN 2023.08.01 2950
344 웹 프로그래밍 Guzzle - cURL error 60: SSL certificate problem: unable to get local issuer certificate 문제 해결 file YooN 2023.07.30 3126
343 웹 프로그래밍 XE 캐시파일 재성생후 404 Oops, Sorry. Page is not found! 나올때 YooN 2023.07.29 2847
342 응용 프로그래밍 [Apple] 엔터프라이즈 계정신청 (Enterprise Program) file YooN 2023.03.27 1386
341 웹 프로그래밍 XE - " Fatal error: Class 'Object' not found in " / class 낫파운드 오류 file YooN 2023.03.20 964
340 응용 프로그래밍 [MSA] MSA란 무엇인가? 개념 이해하기 file YooN 2023.01.26 986
339 웹 프로그래밍 iOS 앱 개발을 위한 인증서 생성 및 관리 file YooN 2023.01.18 1038
338 프로그래밍 [ iOS ] 앱 스토어 개인, 회사, 엔터프라이즈 차이점 file YooN 2023.01.09 778
337 웹 프로그래밍 PHP 파서 이해하기 (<?php의 php를 생략하고 간단히 <? 태그 와 ?> 태그를 사용하는 방법) YooN 2016.08.10 1173
336 프로그래밍 SVN의 cleanup 에러시 해결방법 YooN 2016.05.05 1590
335 프로그래밍 [오류해결] svn cleanup failed-previous operation has not finished; run cleanup if it was interrupted file YooN 2016.05.05 1446
334 프로그래밍 TortoiseSVN 계정변경 file YooN 2016.05.05 968
333 프로그래밍 SVN passwd 설정 : 계정 (users/passwd) file YooN 2016.05.04 1345
332 웹 프로그래밍 XE 비회원 글쓰기 항목 지우기 file YooN 2016.04.28 1335
331 응용 프로그래밍 메모리 영역 (code, data, stack, heap) file YooN 2016.03.23 1539
330 응용 프로그래밍 [SVN] Subversion 명령들 file YooN 2016.02.06 1757
329 응용 프로그래밍 IBM JDK 1.6 에서 Spring 2.5.2를 사용할 때 GenericTypeResolver 에서 NullPointerException이 발생하는 문제 YooN 2016.01.27 1589
328 웹 프로그래밍 오른쪽 마우스 금지 소스 / 드래그 금지 소스 YooN 2016.01.20 1168
327 응용 프로그래밍 [전자정부 표준프레임워크] 톰캣(Tomcat) 설치하기 file YooN 2016.01.02 1290
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 18 Next
/ 18


즐겨찾기 (가족)

JAESOO's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너