홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송 메인홈 1대1상담
운.영.자.1대1.상담
온라이브 음악방송
음악방송 앱 다운로드
OKTROT(무료음악채널)
뽕짝아가씨(무료음악채널)
아리랑가요(무료음악채널)
전통가요(무료음악채널)
보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
mySQL자료수정
9년 전
수정은 삭제보다는 좀 골치아프죠...
하지만 원리는 간단합니다.....

수정버튼클릭 -> 수정폼보여주기 -> 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 소스끝

수정도 마찬가지 입니다.....
이렇게만 해놓으면 안되겠죠........-_-
비밀번호를 넣어서 하는 방법이 좋겠습니다;;
추천추천 : 287 추천 목록
번호 제목
3,025
 여러 도메인들 간 쿠키 공유하기
3,024
 태그 사이에 있는 텍스트를 추출
3,023
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,022
 쿠키 생성,가져오기,삭제
3,021
 사용자 함수 모음
3,020
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,019
 [HTML5] <video> - DOM으로 제어하기
3,018
 HTML5 video 태그에서 영상 좌우반전
3,017
 PHP - 특정 태그 및 문자열 추출, 제거
3,016
 [PHP] define과 defined의 차이
3,015
 우클릭 완벽차단 스크립트
3,014
 iframe 높이 100% 맞추기
3,013
 curl 함수를 이용한 HTTP REFERER 변경
3,012
 윈도우10 시스템 파일 및 Dism 검사
3,011
 텍스트 줄바꿈, 글자자르기 CSS
3,010
 jQuery Mobile에서 유용한 코드 10가지.
3,009
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,008
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,007
 [jQuery] jQuery Quick API
3,006
 [ transition ] 링크 hover 색상 변화 속도 조절
3,005
 PHP 5.3.0 에서 사라진 함수들 대체
3,004
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,003
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,002
 jQuery Mobile에서 유용한 코드 10가지.
3,001
 값이 배열 안에 존재하는지 확인하는 in_array함수
목록
추억의가요방
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
세월따라노래따라
가슴시린트로트
7080추억속으로
CDN 추천곡
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
POP TOP BEST

최신인기가요특집
추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.