|
มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ |
มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ ตอนนี้ผมกำลังทำ Project จบปี 4 อยู่ครับ เขียนโค้ดเชื่อมต่อกับ Database เยอะมาก เมื่อยมือหงิกเลย จึงนึกถึงวิชา JAVA+OOP ที่เคยเรียนมา ลองมา Adap ปรับใช้ดู ก็ได้ Class ที่จัดการเกี่ยวกับ Database มา 1 Class ทุกวันนี้ ขั้นตอนตั้งแต่ เชื่อมต่อ จนถึง ปิดการเชื่อมต่อ เสร็จสรรพภายใน 3-4 บรรทัดครับ แล้วบังเอิญได้ไปเห็น บทความของ คุณ nut_t02 >> https://www.thaicreate.com/php/forum/027334.html concept คล้ายๆกันจึงอยากจะเอา ความรู้ของผมมาแชร์ดูบ้างครับ ^^
การติดตั้ง
1. Copy Code function.php ด้านล่างไปครับ
2. เข้าไปตั้งค่า host, user, pass, ใน function.php ครับ
การใช้งาน
1. นำเข้าไฟล์เข้ามาก่อนครับ โดยใช้คำสั่งนี้ครับ
include("function.php"); //คำสั่งในการนำเข้าไฟล์ครับ
2. สร้างตัวแปร Object ของ Class database ก่อนครับ โดยใช้คำสั่งนี้ครับ
$db = new database;
3. เชื่อมต่อฐานข้อมูล โดยใช้คำสั่งนี้ครับ
$db->con_db();
4. ทำการ Query ข้อมูล โดยใช้คำสั่งนี้ครับ
$sql1 = "คำสั่ง sql command ...";
$rs = $db->sql_cmd_select($sql1);
//ใช้เฉพาะกับ SELECT ครับโดยคำสั่ง
//syntax : $db->sql_cmd_select("...sql command SELECT only..");
//return : ค่าที่ SELECT มาเป็นชนิด Array
//หลักจาก return แล้วก็ลงในตัวแปร $rs ครับ
$sql2 = "คำสั่ง sql command ...";
$rs = $db->sql_cmd($sql2);
//ใช้เฉพาะ INSERT, UPDATE, DELETE, ALTER ,ฯลฯ ครับ
//syntax : $db->sql_cmd("...sql command อื่นๆ นอกจาก SELECT..");
//return : ผลของการ Query เป็นชนิด boolean(true, false) ครับ
//หลักจาก return แล้วก็ลงในตัวแปร $rs ครับ
5. การนำค่าไปใช้และตรวจสอบ
5.1) กรณี sql_cmd_select()
$rs = $db->sql_cmd_select($sql1);
if($rs[0]!=""){
echo"ข้อมูล field ที่ 1 : ".$rs[0];
echo"ข้อมูล field ที่ 2 : ".$rs[1];
}
5.2) กรณี sql_cmd_select()
$rs = $db->sql_cmd($sql2);
if($rs){
echo "คำสั่งผ่าน";
}
else{
echo "คำสั่งไม่ผ่าน";
}
6. การปิดการเชื่อมต่อ โดยใช้คำสั่งนี้ครับ
$db->close_db();
ผมสร้าง Function เสริมให้อีก 2 ตัวครับ
1. get_count() ใช้ในการดึงข้อมูลจำนวน record ในตารางนั้นๆครับ
$count = $db->get_count("ชื่อ table ในฐานข้อมูล");
//syntax : $db->get_count("ชื่อ table ในฐานข้อมูล");
//return : ผลของการ Query เป็นชนิด int ครับ
//หลักจาก return แล้วก็ลงในตัวแปร $count ครับ
2. get_pk() ใช้ในการสร้าง PK key ตัวใหม่ โดยใช้ควบคู่กับ get_count()
$new_pk = $db->get_pk($count+1,"M");
//syntax : $db->get_pk(ค่าcount+1,"char");
//return : ผลของการ Query เป็นชนิด int ครับ
//หลักจาก return แล้วก็ลงในตัวแปร $count ครับ
//อาจ งง ไว้ดูตัวอย่างดีกว่าครับ
เช่นในฐานข้อมูลมีข้อมูล 3 ตัว PK มีดังนี้
ตาราง : human_table
--------------------------------
-- code | name | gender --
--------------------------------
-- M001 | นายA | ชาย --
-- M002 | นางB | หญิง --
-- M003 | นายC | ชาย --
--------------------------------
$count = $db->get_count("human_table");
$new_pk = $db->get_pk($count+1,"M") ;
echo $new_pk; //M004
// ถ้าในตารางมี 9 ตัว ก็จะได้ M010
// ถ้าในตารางมี 99 ตัว ก็จะได้ M100
// รองรับPKสูงสุด 1000 ตัวครับ (หมายเลข0-999)
// โดยมีข้อแม้ว่า PK ในฐานข้อมูลต้องอยู่ในรูปแบบ ตัวอักษร+ตัวเลข3หลัืก เช่น STU001, P078, h628 เป็นต้นครับ
function.php
<?php
class database
{
var $host = "..."; //ของผมใช้ localhost ครับ
var $user = "..."; //username phpmyadmin
var $pass = "..."; //password phpmyadmin
var $db = "..."; //ชื่อฐานข้อมูล
var $con;
function con_db()
{
$this->con = mysql_connect($this->host,$this->user,$this->pass)or die("Error : ไม่สามารถเชื่อมต่อฐานข้อมูลได้");
mysql_select_db($this->db,$this->con)or die("Error : ไม่สามารถเลือกฐานข้อมูลได้");
}
function sql_cmd($sqlCmd)
{
mysql_query("set character_set_results='utf8'");
mysql_query("set character_set_client='utf8'");
mysql_query("set character_set_connection='utf8'");
return $result = mysql_query($sqlCmd,$this->con) or die("Error : เกิดข้อผิดพลาด");
}
function sql_cmd_select($sqlCmd)
{
mysql_query("set character_set_results='utf8'");
mysql_query("set character_set_client='utf8'");
mysql_query("set character_set_connection='utf8'");
$result = mysql_query($sqlCmd,$this->con) or die("Error : เกิดข้อผิดพลาด ไม่เจอข้อมูลที่ต้องการ");
$rs = mysql_fetch_array($result);
return $rs;
}
function close_db()
{
mysql_close($this->con);
}
function get_count($table)
{
$this->con_db();
$count = $this->sql_cmd_select("select count(*) from ".$table);
return $count[0];
$this->close_db();
}
function get_pk($count,$key)
{
if($count<=9)
{
return $key."00".$count;
}
else if($count<=99)
{
return $key."0".$count;
}
else
{
return $key.$count;
}
}
}
?>
ถ้าใครสร้าง Function ใหม่ๆน่าใช้ ก็เอามาแบ่งกันด้วยนะครับ ผมไปทำ Project ต่อแล้วครับ ... ขอบคุณทุกท่านครับ
Reference : http://www.facebook.com/fluke.farlook
|
|
|
By : |
Fluke
|
|
Article : |
บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ |
|
Score Rating : |
|
|
Create Date : |
2012-11-11 |
|
Download : |
No files |
|
Sponsored Links |
|
|
|
|
|
|