PHP 와 MYSQL 연동

2015.08.11 22:02

졸리운_곰 조회 수:585

PHP 와 MYSQL 연동

 

PHP 와 MYSQL 연동

이번 강좌는 php와 mysql의 연동을 다루게 됩니다.
db 생성은 이전장에서 다루었습니다.
이젠 생성된 db에서 테이블을 생성하고, 삭제하고 데이타를 넣고 빼고 수정하는 것을 하겠습니다.
db와 table의 개념을 이해 못하시는 분들이 아직 있는가요?
폰돌이네집에는 엄마, 아빠, 형, 누나, 폰돌이 5명이 살고 있습니다.
여기서 폰돌이네집은 db이고 table은 엄마, 아빠, 형, 누나, 폰돌입니다. 폰돌이네 집에 가려면 열쇠가 있어야 겠죠? 이것이 db연결입니다.

즉, 열쇠를 가지고(db를 연결후) 엄마(table)를 만나서 얘기(insert, delete, update)하는 것이 이번 강좌의 목적이져. ㅎ

 

mysql과 연동

<?
$MYSQL_HOST = "호스트명, 주로 localhost";//호스트명 IP 혹은 localhost
$MYSQL_DB = test_db"";//DB 명
$MYSQL_ID = "userid";//아이디
$MYSQL_PASSWORD = "testpwd";//패스워드
$DB_CONNECT = mysql_connect($MYSQL_HOST, $MYSQL_ID, $MYSQL_PASSWORD);
mysql_select_db($MYSQL_DB, $DB_CONNECT);
if ( !$DB_CONNECT ) {echo "mysql 데이터 베이스에 연결할 수 없습니다."; exit;}
?>


상기 부분은 mysql 명령어를 한줄이라도 사용한다면 반드시 사용해야 하는 구문입니다. 워낙 많이 사용하는 구문이므로 대부분의 웹프로그래머들은 include 시켜 사용합니다. include가 뭐냐구여? 아직 설명을 드리지 않았네요... 아래 설명란에 간단히 설명드릴테니 성격이 급하신 분은 아래 설명란을 먼저 보세요.
 

TABLE 생성

<?
$MYSQL_HOST = "호스트명, 주로 localhost";//호스트명 IP 혹은 localhost
$MYSQL_DB = test_db"";//DB 명
$MYSQL_ID = "userid";//아이디
$MYSQL_PASSWORD = "testpwd";//패스워드
$DB_CONNECT = mysql_connect($MYSQL_HOST, $MYSQL_ID, $MYSQL_PASSWORD);
mysql_select_db($MYSQL_DB, $DB_CONNECT);
if ( !$DB_CONNECT ) {echo "mysql 데이터 베이스에 연결할 수 없습니다."; exit;}
?>
<?
$sqlstr = "CREATE TABLE testtable (
uid int(11) NOT NULL auto_increment,
id varchar(20) NOT NULL default '',
passwd varchar(10) NOT NULL default '',
name varchar(20) NOT NULL default '',
email varchar(20) NOT NULL default '',
wdate int(13) NOT NULL default '0',
PRIMARY KEY (uid)
)";
$result = mysql_query($sqlstr);
if($result) echo "생성이 완료 되었습니다.";
else echo mysql_error();
mysql_close();
?>


결과보기

 

■ CREATE TABLE table_name ( create_definition,... )
데이타베이스 상에 테이블을 생성시키는 명령이다. 자세한 옵션은 다음과 같다.

create_definition:
column_name type [NOT NULL | NULL] [DEFAULT default_value] [AUTO_INCREMENT]
[ PRIMARY KEY ] [reference_definition]
or PRIMARY KEY ( index_column_name,... )
or KEY [index_name] KEY( index_column_name,...)
or INDEX [index_name] ( index_column_name,...)
or UNIQUE [index_name] ( index_column_name,...)
or FOREIGN KEY index_name ( index_column_name,...) [reference_definition]
or CHECK (expr)

type:
TINYINT[(length)] [UNSIGNED] [ZEROFILL]
or SMALLINT[(length)] [UNSIGNED] [ZEROFILL]
or MEDIUMINT[(length)] [UNSIGNED] [ZEROFILL]
or INT[(length)] [UNSIGNED] [ZEROFILL]
or INTEGER[(length)] [UNSIGNED] [ZEROFILL]
or BIGINT[(length)] [UNSIGNED] [ZEROFILL]
or REAL[(length,decimals)] [UNSIGNED] [ZEROFILL]
or DOUBLE[(length,decimals)] [UNSIGNED] [ZEROFILL]
or FLOAT[(length,decimals)] [UNSIGNED] [ZEROFILL]
or DECIMAL[(length,decimals)] [UNSIGNED] [ZEROFILL]
or NUMERIC[(length,decimals)] [UNSIGNED] [ZEROFILL]
or CHAR(length) [BINARY],
or VARCHAR(length) [BINARY],
or DATE
or TIME
or TIMESTAMP
or DATETIME
or TINYBLOB
or BLOB
or MEDIUMBLOB
or LONGBLOB
or TINYTEXT
or TEXT
or MEDIUMTEXT
or ENUM(value1,value2,value3...)
or SET(value1,value2,value3...)

index_column_name:
column_name [ (length) ]

reference_definition:
REFERENCES table_name [( index_column_name,...)]
[ MATCH FULL | MATCH PARTIAL]
[ ON DELETE reference_option]
[ ON UPDATE reference_option]

reference_option:
RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT

 

TABLE 삭제

<?
$MYSQL_HOST = "호스트명, 주로 localhost";//호스트명 IP 혹은 localhost
$MYSQL_DB = test_db"";//DB 명
$MYSQL_ID = "userid";//아이디
$MYSQL_PASSWORD = "testpwd";//패스워드
$DB_CONNECT = mysql_connect($MYSQL_HOST, $MYSQL_ID, $MYSQL_PASSWORD);
mysql_select_db($MYSQL_DB, $DB_CONNECT);
if ( !$DB_CONNECT ) {echo "mysql 데이터 베이스에 연결할 수 없습니다."; exit;}
?>
<?
$sqlstr = "DROP TABLE `testtable`";
//$sqlstr = "DROP TABLE IF EXISTS `testtable`";
$result = mysql_query($sqlstr);
if($result) echo "테이블이 삭제되었습니다.";
else echo mysql_error();
mysql_close();
?>


결과보기

 

■ DROP TABLE table_name [, table_name...]
존재하는 테이블을 제거할 경우 사용되는 명령이다.

 

INSERT

<?
$MYSQL_HOST = "호스트명, 주로 localhost";//호스트명 IP 혹은 localhost
$MYSQL_DB = test_db"";//DB 명
$MYSQL_ID = "userid";//아이디
$MYSQL_PASSWORD = "testpwd";//패스워드
$DB_CONNECT = mysql_connect($MYSQL_HOST, $MYSQL_ID, $MYSQL_PASSWORD);
mysql_select_db($MYSQL_DB, $DB_CONNECT);
if ( !$DB_CONNECT ) {echo "mysql 데이터 베이스에 연결할 수 없습니다."; exit;}
?>
<?
$wdate = time();
$sqlstr = "insert into testtable (id, passwd, name, email, wdate)
values('pondole','1234567','폰돌','master_at_shop-wiz.com', '$wdate')";
$result = mysql_query($sqlstr);
if($result) echo "정상적으로 입력되었습니다.";
else echo mysql_error();
mysql_close();
?>


결과보기

 

■ INSERT 문
존재하는 테이블에 데이타를 입력할때 사용한다.

INSERT INTO table [ (column_name,...) ] VALUES (expression,...)
or INSERT INTO table [ (column_name,...) ] SELECT ...

 

UPDATE

<?
$MYSQL_HOST = "호스트명, 주로 localhost";//호스트명 IP 혹은 localhost
$MYSQL_DB = test_db"";//DB 명
$MYSQL_ID = "userid";//아이디
$MYSQL_PASSWORD = "testpwd";//패스워드
$DB_CONNECT = mysql_connect($MYSQL_HOST, $MYSQL_ID, $MYSQL_PASSWORD);
mysql_select_db($MYSQL_DB, $DB_CONNECT);
if ( !$DB_CONNECT ) {echo "mysql 데이터 베이스에 연결할 수 없습니다."; exit;}
?>
<?
$wdate = time();
$sqlstr = "update testtable set id='shop-wiz', passwd='987654' where id='pondole'";
$result = mysql_query($sqlstr);
if($result) echo "정상적으로 업데이팅되었습니다.";
else echo mysql_error();
mysql_close();
?>

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com


결과보기

 

■ UPDATE 문
테이블 상에 존재하는 데이타를 변경할 경우 사용한다.


UPDATE table SET column=expression,... WHERE where_definition

 

SELECT

<?
$MYSQL_HOST = "호스트명, 주로 localhost";//호스트명 IP 혹은 localhost
$MYSQL_DB = test_db"";//DB 명
$MYSQL_ID = "userid";//아이디
$MYSQL_PASSWORD = "testpwd";//패스워드
$DB_CONNECT = mysql_connect($MYSQL_HOST, $MYSQL_ID, $MYSQL_PASSWORD);
mysql_select_db($MYSQL_DB, $DB_CONNECT);
if ( !$DB_CONNECT ) {echo "mysql 데이터 베이스에 연결할 수 없습니다."; exit;}
?>
<?
$wdate = time();
$sqlstr = "select * from testtable";
$sqlqry = mysql_query($sqlstr);
$list = mysql_fetch_array($sqlqry);
echo "id = $list[id], passwd=$list[passwd], name=$list[name], email=$list[email], wdate=$list[wdate]";
echo mysql_error();
mysql_close();
?>


결과보기

 

■ SELECT 문
존재하는 테이블 상의 데이타를 조회할때 사용하는 명령이다.
기본적인 사용법은 다음과 같다.

SELECT [STRAIGHT_JOIN] [DISTINCT | ALL] select_expression,...
[INTO OUTFILE 'file_name' ...]
[ FROM table_references
[WHERE where_definition ]
[GROUP BY column,...]
[HAVING where_definition]
[ ORDER BY column [ASC | DESC] ,..] [LIMIT [offset,] rows]
[PROCEDURE procedure_name]]

 

DELETE

<?
$MYSQL_HOST = "호스트명, 주로 localhost";//호스트명 IP 혹은 localhost
$MYSQL_DB = test_db"";//DB 명
$MYSQL_ID = "userid";//아이디
$MYSQL_PASSWORD = "testpwd";//패스워드
$DB_CONNECT = mysql_connect($MYSQL_HOST, $MYSQL_ID, $MYSQL_PASSWORD);
mysql_select_db($MYSQL_DB, $DB_CONNECT);
if ( !$DB_CONNECT ) {echo "mysql 데이터 베이스에 연결할 수 없습니다."; exit;}
?>
<?
$sqlstr = "delete from testtable where id='pondole'";
$result = mysql_query($sqlstr);
if($result) echo "데이타가 삭제되었습니다.";
else echo mysql_error();
mysql_close();
?>


결과보기

 

■ DELETE FROM table_name WHERE where_definition
존재하는 테이블 상의 데이타를 삭제할때 사용하는 명령이다.

 

[설명]
include란 많이 사용되는 문서를 중복하여 사용하지 않고 하나를 사용하는 것입니다.

lecture13_result_inc.php

Powered by shop-wiz.com Since 2002, E-mail : master_at_shop-wiz.com

 

쇼핑몰 솔루션은 위즈몰입니다.<br>
<?
include "lecture13_result_inc.php";
?>


결과보기

include 를 사용할 경우 주의할점은 상대경로 혹은 서버절대경로입니다. (웹절대경로가 아님을 주의 하시기 바랍니다.)

 

 

[출처] http://www.shop-wiz.com/document/php_lecture/lecture13




테이블 사용에 있었어 예제 보기 아래로 사용법이 나와 있습니다. 걍 이런것이 있구나 라고 생각하시고 넘어가시기 바랍니다. 다음에 좀더 다양한 query를 할때 이곳에 다시 방문하셨어 기억을 다음으시기 바랍니다.

 

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
29 How to Call SWI-Prolog from PHP 5 졸리운_곰 2016.05.10 281
28 neural-network by php file 졸리운_곰 2016.03.16 152
27 Learning Library for PHP file 졸리운_곰 2016.03.16 371
26 php 전문가 시스템 php expert system file 졸리운_곰 2016.03.15 56
25 How to Insert JSON Data into MySQL using PHP file 졸리운_곰 2015.12.04 817
24 이클립스(Eclipse) PHP 개발환경 설정. file 졸리운_곰 2015.11.14 216
23 PHP로 만든 달력 file 졸리운_곰 2015.10.27 118
22 라이트 cms 다운로드 ritecms_2.2.1.zip file 졸리운_곰 2015.10.27 24
21 드루팔 다운로드 drupal-7.41.zip file 졸리운_곰 2015.10.27 11
20 도쿠위키 다운로드 dokuwiki-5422200921b.tgz file 졸리운_곰 2015.10.27 47
19 미디어위키 다운로드 mediawiki-1.25.3.tar.gz file 졸리운_곰 2015.10.27 34
18 워드프레스 다운로드 wordpress-4.3.1-ko_KR.zip file 졸리운_곰 2015.10.27 34
17 제로보드 다운로드 XE Core ver. 1.8.13 xe.zip file 졸리운_곰 2015.10.27 30
16 XE 스킨 제작 매뉴얼 v1.1 XE-Skin_Manual-ko(v1.1).pdf file 졸리운_곰 2015.10.26 21
15 제로보드 XE 개발자 가이드 file 졸리운_곰 2015.10.26 23
14 php로 웹 수집 : Basic PHP Web Scraping Script Tutorial 졸리운_곰 2015.09.20 64
» PHP 와 MYSQL 연동 졸리운_곰 2015.08.11 585
12 PHP 기반의 Micro Frameworks 정리 졸리운_곰 2015.05.15 276
11 PHP의 composer 란 무엇인가?, PHP 의존성 관리도구 졸리운_곰 2015.05.15 372
10 슬림(Slim): 마이크로 프레임워크 [모바일 restful 서버] 졸리운_곰 2015.05.15 243
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED