홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)
음악가사 검색
온라이브스토어(앱다운로드)
온라이브(방송등록및청취)
비디오 베스트 50
금영노래방
TJ노래방
유튜브 동영상 다운로드
POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
운.영.자.1대1.상담
FAQ\지원.프로그램
Q&A\고.객.지.원

자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
mySQL자료수정
7년 전
수정은 삭제보다는 좀 골치아프죠...
하지만 원리는 간단합니다.....

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

수정도 마찬가지 입니다.....
이렇게만 해놓으면 안되겠죠........-_-
비밀번호를 넣어서 하는 방법이 좋겠습니다;;
추천추천 : 269 추천 목록
번호 제목
3,015
 iframe 높이 100% 맞추기
3,014
 curl 함수를 이용한 HTTP REFERER 변경
3,013
 윈도우10 시스템 파일 및 Dism 검사
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
2,991
 [CSS] - Input clear `X ` 버튼 제거 ( IE, Chrome, Firefox )
2,990
 [Mobile] - 모바일웹 Href 태그속성들
2,989
 [JqueryMobile] - 현재화면의 가로세로 사이즈 구하기
2,988
 [JqueryMobile] - 화면의 가로, 세로 사이즈 구하는 방법
2,987
 jquery로 가로 넓이(width), 세로 높이(height) 자동 조절
2,986
 iframe 높이 jquery로 자동조절하기
2,985
 jQuery 오른쪽 영역의 높이를 왼쪽 영역의 높이와 동일하게 하기
2,984
 jquery에서 테이블 짝수, 홀수 번째 TR 배경색 변경하기
2,983
 jquery에서 테이블에 마우스 오버시 해당 행의 배경색상 변경하기
2,982
 jquery 스크립트내 특정값 확인하기 (디버깅)
2,981
 jquery cookie (jquery.cookie.js)
목록
인기절정뽕짝파티
트로트재생목록
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요1번지(종합)
뮤직하우스
동요\연변\반주\기타
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.