홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
mySQL자료수정
12년 전
수정은 삭제보다는 좀 골치아프죠...
하지만 원리는 간단합니다.....

수정버튼클릭 -> 수정폼보여주기 -> DB수정 -> 리스트로이동

일단 수정버튼을 만들어야 하는데....
방법은 삭제와 같습니다......

파일은 edit.php로 하기로 하죠........
링크를 걸때는 삭제와 마찬가지로 edit.php?no=$data[no] 로 해주시면 되겠죠...

링크만드는 소스는 삭제에서 했던것과 같구요...
파일명만 edit.php로 해주시면 됩니다......

이제 edit.php로 이동합니다.....

edit.php에서는 수정폼이 들어갑니다.....
일단 수정할 내용을 입력해서 그내용대로 수정을 가해줘야 하니까 사용자로부터 수정내용을 입력받아야 합니다.

<form method=post action=edit2.php>
이름 <input type=text name=name size=10 maxlength=10>
메모 <input type=text name=memo size=30 maxlength=50>
<input type=submit value=수정>
</form>

위와 같이 폼을 만들어 보았습니다.
action은 edit2.php로 했으니까 이 폼에서 수정을 한후에 submit을 하면 edit2.php로 이동하겠죠....
그리고 실질적으로 edit2.php에서 DB에 수정을 가해주는 것입니다.

그런데 이대로 사용할 수가 없습니다...
왜냐면.....그래도 명색이 수정인데........이전의 내용을 기본적으로 보여주고 그걸 바탕으로 수정을 해야겠죠?...
그래서 이전의 내용을 가져오는 부분을 넣어줘야 합니다...

가져오는 쿼리는 뭐였죠?
넹.......select입니다....

select * from [테이블이름] where [조건]

대입해보죠...select * from exam_memo where no=$no
맞죠?........no가 $no인 것만 가져옵니다.....

$query="select * from exam_memo where no=$no";
$data=mysql_fetch_array(mysql_query($query));

이렇게 하면 mysql_fetch_array()함수를 사용하여 $data에 연관배열형식으로 가져온 데이터가 저장됩니다.
지난번의 list.php에서처럼 while문을 사용하지않은 것은...
리턴되는 테이터가 단 1개이기 때문입니다.....(총갯수 셀때를 생각해보세요)

그럼 이제 $data[name]에는 선택한글의 글쓴이이름이 들어가고...
$data[memo]에는 글 내용이 들어갑니다....
폼에 기본값으로 넣어줘 볼까요?

<?
include"connect.php";

$query="select * from exam_memo where no=$no";
$data=mysql_fetch_array(mysql_query($query));

echo"
<form method=post action=edit2.php>
이름 <input type=text name=name size=10 maxlength=10 value='$data[name]'>
메모 <input type=text name=memo size=30 maxlength=50 value='$data[memo]'>
<input type=submit value=수정>
</form>";
?>

<input>태그 부분만 볼까요......
이름 부분에는 value='$data[name]'라고 넣어줬죠...
그래서 글입력부분에는 기본값으로 글쓴이이름이 들어가게 됩니다.
메모부분도 마찬가지죠...~

자 그럼 이제 사용자가 다 수정을 하고.....submit을 했습니다..
근데.....이대로라면 문제가 좀 생기죠...

왜죠?...........-_-????

잘 생각해 보세요.......
우리가 글을 수정하거나 삭제 하려면 어떤글인지를 알려주어야 하는데...
이대로 폼에 들어온 값을 넘겨주면 no값이 없습니다...
그래서 이럴때에는 hidden타입으로 값을 하나 넣어주어야 합니다.

<input type=hidden name=no value=$no>

이줄을 <form>태그안에 추가해줌으로써 edit2.php로 이동하면서 no라는 값이 계속 유지되게 됩니다....

처음부터 다시 생각해보죠...
list.php에서 22번글의 수정을 클릭하였습니다.
그럼 edit.php?no=22라는 링크로 이동하게 되죠...여기서 $no=22가 됩니다.
그다음에 edit.php에서 수정을 하고 submit을 하면서 edit2.php로 이동하게 되는데 이때 no값이 날라가 버립니다...
그래서 그 값을 지켜주기 위해서 hidden타입의 no값을 넣어서 폼으로 같이 내보내 주는 것입니다...

자 그럼 완성된 edit.php소스를 보시죠..

>>> edit.php 소스

<?
include"connect.php";

$query="select * from exam_memo where no=$no";
$data=mysql_fetch_array(mysql_query($query));

echo"
<form method=post action=edit2.php>
<input type=hidden name=no value=$no>
이름 <input type=text name=name size=10 maxlength=10 value='$data[name]'>
메모 <input type=text name=memo size=30 maxlength=50 value='$data[memo]'>
<input type=submit value=수정>
</form>";
?>

>>> edit.php 소스끝

자 이제 edit2.php로 이동합니다.....
edit2.php에서는 delete.php의 소스를 약간 수정해 주면 됩니다.

delete.php소스를 먼저 보죠;;;

<?
include"connect.php";//디비에접속
$input="delete from exam_memo where no=$no";//삭제쿼리문
mysql_query($input,$connect);//디비에 넣기
?>
<meta http-equiv='refresh' content='0;url=list.php'>

요거였죠?....여기서 쿼리문만 바꿔주면 되겠습니다 (__)
자...수정하는 쿼리문은 update라는 것입니다..형식은....

update [테이블이름] set [항목]=[바꿀값],[항목]=[바꿀값]... where [조건]

위와 같습니다.....
예를들어 name을 test로 바꾸려면 name='test' 라고 해주면 됩니다.
(숫자면 ''를 생략해도 되겠죠)

자 대입해 보죠......
edit.php로 부터 넘어온 변수는 $no와 $name과 $memo가 있습니다.
그래서 쿼리문은...

update exam_memo set name='$name',memo='$memo' where no=$no

해석해 볼까요....

update (바꿔라)
exam_memo (exam_memo테이블에서)
set (-_-a)
name='$name' (name에는 $name으로..)
memo='$memo' (memo에는 $memo로)
where (어느것을?)
no=$no (no가 $no인것을)

자 그럼 이문장을 $input에 넣어줍니다....

>>> edit2.php 소스

<?
include"connect.php";//디비에접속
$input="update exam_memo set name='$name',memo='$memo' where no=$no
";//수정쿼리문
mysql_query($input,$connect);//디비에 넣기
?>
<meta http-equiv='refresh' content='0;url=list.php'>

>>> edit2.php 소스끝

수정도 마찬가지 입니다.....
이렇게만 해놓으면 안되겠죠........-_-
비밀번호를 넣어서 하는 방법이 좋겠습니다;;
추천추천 : 315 추천 목록
번호 제목
3,035
 아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
3,034
 PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
3,033
 PHP 정규식 정리
3,032
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
3,031
 php 크롤링 또는 파싱 함수, 정규식 모음
3,030
 제이쿼리 기본 명령어
3,029
 웹페이지 가로 모드세로 모드 인식하기
3,028
 모바일 웹 화면 강제 회전(가로모드 고정)
3,027
 [HTML5]에서 frameset 대체 방법과 iframe 속성
3,026
 HTML <Audio> 사용법
3,025
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
3,024
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,023
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,022
 CSS Layout 수평 & 수직 정렬
3,021
 여러 도메인들 간 쿠키 공유하기
3,020
 태그 사이에 있는 텍스트를 추출
3,019
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,018
 쿠키 생성,가져오기,삭제
3,017
 사용자 함수 모음
3,016
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,015
 [HTML5] <video> - DOM으로 제어하기
3,014
 HTML5 video 태그에서 영상 좌우반전
3,013
 PHP - 특정 태그 및 문자열 추출, 제거
3,012
 [PHP] define과 defined의 차이
3,011
 우클릭 완벽차단 스크립트
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.