홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
운.영.자.1대1.상담

온라이브음악방송
온라이브스토어(앱다운로드)
아리랑가요(무료음악채널)
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)

환상의뽕짝파티 무료음악
명작트로트메들리 무료음악
트로트메들리관광 무료음악
동영상노래방
가사검색

POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
최신 인기가요

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

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

수정도 마찬가지 입니다.....
이렇게만 해놓으면 안되겠죠........-_-
비밀번호를 넣어서 하는 방법이 좋겠습니다;;
추천추천 : 284 추천 목록
번호 제목
3,026
 여러 도메인들 간 쿠키 공유하기
3,025
 태그 사이에 있는 텍스트를 추출
3,024
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,023
 쿠키 생성,가져오기,삭제
3,022
 사용자 함수 모음
3,021
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,020
 [HTML5] <video> - DOM으로 제어하기
3,019
 HTML5 video 태그에서 영상 좌우반전
3,018
 PHP - 특정 태그 및 문자열 추출, 제거
3,017
 [PHP] define과 defined의 차이
3,016
 우클릭 완벽차단 스크립트
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] 막강 기능 배열..
목록
추억의가요방(가사포함)
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
세월따라노래따라
가슴시린트로트
트로트쌍쌍파티
7080추억속으로
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
POP TOP BEST

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