홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)

온라이브스토어(앱다운로드)
온라이브(방송등록및청취)

환상의뽕짝파티 무료음악
명작트로트메들리 무료음악
트로트메들리관광 무료음악
POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
mySQL자료넣기
7년 전
자...이제 테이블을 만들었으니까....
자료를 넣어야 겠죠~?

자료를 넣을때는 insert라는 쿼리문을 사용합니다...
형식은 아래와 같습니다....

insert into 테이블이름 (이름1,이름2,이름3...)
values (값1,값2,값3...)

이름은 테이블 항목의 이름이겠고...값은 거기에 해당하는 들어갈 값입니다.
우리가 만들었던 exam_memo 테이블의 항목은...

no 자료형(크기),
name 자료형(크기),
memo 자료형(크기),
date 자료형(크기),
ip 자료형(크기)

위와 같이 5개 입니다...그럼 insert쿼리에 대입해보죠...

insert into exam_memo (no,name,memo,date,ip)
values (값1,값2,값3,값4,값5)

테이블 이름은 exam_memo..맞죠?.....
no에는 값을 넣을 필요가 없습니다...
왜냐하면 우리가 애초에 테이블을 생성할때 auto_increment로 해줬기 때문에 아무런 값을 넣지 않아도 알아서 +1씩 해줍니다....
(전 시간에 설명을 드렸었죠?)
그리고 값을 넣을때 문자는 ''를 사용하고 숫자는 ''없이 입력해도 됩니다.
예를 들어볼까요?

name에는 navyism을, memo에는 안녕하세요를,date에는 92391238를 (유닉스타임스탬프이니까..),ip에는 211.23.312.54를 넣는다고 해보죠....
그럼 쿼리문은 아래와 같이 됩니다...

insert into exam_memo (no,name,memo,date,ip)
values ('','navyism','안녕하세요',92391238,'211.23.312.54')

''의 사용을 잘 살펴보세요....문자형과 숫자형의 차이입니다.
자 그럼 저 쿼리를 mysql에 보내려면....어떻게 해야죠?....

옙;;; 지난시간에 테이블을 생성할때 사용했던 mysql_query()함수를 쓰면 됩니다.....
예제 소스를 보시죠....

<?
include"connect.php";

$query="insert into exam_memo (no,name,memo,date,ip)
values ('','navyism','안녕하세요',92391238,'211.23.312.54')";

mysql_query($query,$connect);
?>

이 소스를 실행하면 exam_memo테이블에는 넣어준 값이 들어가게 됩니다.
이전까지는 아무런 데이터가 없었으니 no는 자동으로 1이 되겠죠?
phpMyAdmin에서 exam_memo테이블의 일반적리스트를 보시면 1행이 추가된 것을 보실수 있을 겁니다....

그럼 이제 사용자로부터 입력받은 값을 DB에 집어 넣도록 해볼까요?
먼저 뭘해야죠?....

네에 입력 폼을 만들어야 겠죠...
메모장은 글리스트와 입력폼이 함께 있어야 하니까....
list.php파일에 폼을 만들어 놓도록 하겠습니다...

list.php라는 파일을 만들고 아래 소스를 저장합니다.


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


일반적인 form소스 입니다....
지난번에 form에 대해서 다뤘던 부분이죠...

maxlength는 우리가 테이블을 만들때 사용했던 자료형 크기를 바탕으로 정한것입니다....
name은 varchar(10)이고 memo는 varchar(50)이었죠...
그래서 최대 크기(maxlength)는 10과 50입니다.

(# 미리보기-> http://navyism.yezzang.com/exam_memo/list.php )

method는 post이고 action은 write.php입니다...
즉, 글을 입력하면 write.php로 입력받은 값을 넘겨 준다는 거겠죠...

일단 이대로 저장을 하고.....
이젠 write.php의 소스를 작성해볼까요?

list.php에서 입력받은 값을 가져오기 때문에....input태그의 name인자로 쓰인 name과 memo를 각각 $name과 $memo이라는 변수로 가져옵니다.

그리고 위에서 다루었던 insert쿼리문의 값 부분에 $name,$memo식으로 변수를 넣어주면 입력받은 값이 DB로 들어가는거죠...

일단 write.php소스를 보겠습니다.

<?
include"connect.php";
?>

먼저 connect.php를 include하여 DB에 접속합니다.

<?
include"connect.php";

if(!$name){} //입력확인
if(!$memo){}
?>

if문 부분은 name과 memo에 아무런 값도 입력하지 않았을때에 에레메세지로 alert창을 띄워주는 부분입니다.
alert창을 띄우는 방법은...

echo"<script language=javascript>
alert('메세지');
history.go(-1);
</script>";

위와 같습니다....
javascript를 이용하여 alert()라는 함수로 메세지를 띄우고...
history.go(-1)은 이전 페이지로 돌아가라 라는 것입니다.

적용해 볼까요?

<?
include"connect.php";

if(!$name){
echo"<script language=javascript>
alert('이름을 입력하세요');
history.go(-1);
</script>";
exit;
} //입력확인

if(!$memo){
echo"<script language=javascript>
alert('내용을 입력하세요');
history.go(-1);
</script>";
exit;
}
?>

이런식이 됩니다.....
exit를 if문 마지막에 써준것은 에러가 발생했기 때문에 더이상 실행할 필요가 없기 때문입니다...
밑으로 가면 DB에 insert하는 부분이 있을 것인데...exit를 해주지 않으면 에러를 표시하고 DB에 까지 insert하게 됩니다...

그런데 소스를 가만보니...중복되는 부분이 많죠......;;;

예전에 배웠던 함수를 만들어 쓰기...기억나시나요?...
error()라는 함수를 만들어서 간단하게 사용해 보도록 하겠습니다.

function error($message) {}

error()라는 함수를 선언하고 매개변수로 $message라는 것을 받아 들입니다.

function error($message) {
echo"<script language=javascript>
alert('$message');
history.go(-1);
</script>";
exit;
}

에러 메세지 내용을 추가한 부분입니다...
error('이름을 입력하세요')와 같은 형식으로 함수를 호출하면...
$message="이름을 입력하세요"가 됩니다....
그래서 alert('이름을 입력하세요')와 같이 들어가기 때문에.....
정상적으로 에러를 표시하고 history.go(-1)로 앞페이지로 돌아가면서 exit를 만나면서 페이지 실행을 종료 합니다.

그럼 다시 write.php에 적용해 보도록 하겠습니다.


<?
include"connect.php";

function error($message) { //에러 함수 선언
echo"<script language=javascript>
alert('$message');
history.go(-1);
</script>";
exit;
}

if(!$name){error('이름을 입력하세요');} //입력확인
if(!$memo){error('메모를 입력하세요');}
?>

적용한 소스 입니다....
자 그럼......이제 폼에 입력된 항목의 검사는 끝났습니다....

이번엔 IP와 시간을 알아내야겠죠...
IP는 $ip에...시간은 $date에 넣도록 하겠습니다...

<?
include"connect.php";

function error($message) { //에러 함수 선언
echo"<script language=javascript>
alert('$message');
history.go(-1);
</script>";
exit;
}

if(!$name){error('이름을 입력하세요');} //입력확인
if(!$memo){error('메모를 입력하세요');}

$ip=$REMOTE_ADDR; //IP저장
$date=time(); //시간을 유닉스타임스탬프로 저장
?>

$REMOTE_ADDR이라는 것은 IP를 알려주는 변수입니다.
time()은 시간함수 시간에 다루었던 것이죠?

그럼 이제 DB에 집어넣을 준비가 다 되었습니다.....
쿼리문을 만들어 볼까요?

insert into exam_memo (no,name,memo,date,ip)
values ('','$name','$memo',$date,'$ip')

처음에 만들었었던 쿼리문에 변수를 사용하여 넣은 모습입니다.
다시한번 ''의 사용에 유의 하세요...

그런데 잠깐 문제가 있습니다...
예를들어......사용자가 memo에 ' 를 입력하면 어떻게 될까요?

$memo=" ' "; 가 되죠?
그래서 위 쿼리문에 들어가게 되면....

insert into exam_memo (no,name,memo,date,ip)
values ('','$name',' ' ',$date,'$ip')

이렇게 됩니다........뭔가 잘못된것 같죠?....

'$memo'부분이 ' ' ' 가 되어버립니다.
이렇게 되면 정상적으로 데이터가 들어갈 수 없겠죠...
그래서 '나 "등의 특수문자가 입력되면 ' "와 같이 앞에 역슬레쉬()를 붙여줘야 DB에 이상없이 들어갑니다...

이때 쓰이는 함수가 addslashes()라는 함수인데...
이 함수는 특수문자앞에 를 붙여줍니다.......
반대로 를 제거하는 함수는 stripslashes()입니다.....이건 데이터를 꺼내올때 사용하겠죠?

암튼 소스에 적용해 봅시다...

<?
include"connect.php";

function error($message) { //에러 함수 선언
echo"<script language=javascript>
alert('$message');
history.go(-1);
</script>";
exit;
}

if(!$name){error('이름을 입력하세요');} //입력확인
if(!$memo){error('메모를 입력하세요');}

$ip=$REMOTE_ADDR; //IP저장
$date=time(); //시간을 유닉스타임스탬프로 저장

$name=addslashes($name);
$memo=addslashes($memo);
?>

addslashes()함수에 $name과 $memo를 넣어서 다시 $name과 $memo에 저장을 했습니다....
이렇게 하면 이제 $name과 $memo에 있던 특수문제 앞에 모두 가 붙게 되겠죠?...

자 이제 진짜로 DB에 넣어봅시다....
아까 만들어 놓은 쿼리문을 mysql_query()함수로 DB에 넣어줍니다.

<?
include"connect.php";

function error($message) { //에러 함수 선언
echo"<script language=javascript>
alert('$message');
history.go(-1);
</script>";
exit;
}

if(!$name){error('이름을 입력하세요');} //입력확인
if(!$memo){error('메모를 입력하세요');}

$ip=$REMOTE_ADDR; //IP저장
$date=time(); //시간을 유닉스타임스탬프로 저장

$name=addslashes($name);
$memo=addslashes($memo);

$query="insert into exam_memo (no,name,memo,date,ip)
values ('','$name','$memo',$date,'$ip')";

mysql_query($query,$connect);
?>

$qeury라는 변수에 쿼리문을 넣고 mysql_query()함수를 호출하여 쿼리문을 DB에 보내주었습니다...
이로서 글이 DB에 입력된거죠.....

자 그럼......입력후엔 어떻게 될까요?...
다시 list.php로 되돌아 가야 겠죠?...
이동하는 구문을 마지막에 넣어줘 볼까요...

html에서 다른 페이지로 이동하는 문장입니다...
<meta http-equiv='refresh' content='0;url=경로'>

이 구문을 마지막줄에 넣어줍니다...

<?
include"connect.php";

function error($message) { //에러 함수 선언
echo"<script language=javascript>
alert('$message');
history.go(-1);
</script>";
exit;
}

if(!$name){error('이름을 입력하세요');} //입력확인
if(!$memo){error('메모를 입력하세요');}

$ip=$REMOTE_ADDR; //IP저장
$date=time(); //시간을 유닉스타임스탬프로 저장

$name=addslashes($name);
$memo=addslashes($memo);

$query="insert into exam_memo (no,name,memo,date,ip)
values ('','$name','$memo',$date,'$ip')";

mysql_query($query,$connect);
?>
<meta http-equiv='refresh' content='0;url=list.php'>


휴우우...
^^/ 끝입니다....

이제 이 소스를 write.php로 저장하시고 list.php를 실행하여서 글을 입력해 보세요........

-_-;; 아무 변화 없죠?......
아직 입력된 글을 보는 부분을 만들지 않았기 때문입니다...
추천추천 : 275 추천 목록
번호 제목
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.