Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
   
 

Registered : 102,396




HOME > บทความจากสมาชิก > มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ

มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ

 
 
       
Bookmark.   
Share
       
มาใช้ OOP ในการจัดการกับ Database PHP กับ MySQL กันเถอะ ตอนนี้ผมกำลังทำ Project จบปี 4 อยู่ครับ เขียนโค้ดเชื่อมต่อกับ Database เยอะมาก เมื่อยมือหงิกเลย จึงนึกถึงวิชา JAVA+OOP ที่เคยเรียนมา ลองมา Adap ปรับใช้ดู ก็ได้ Class ที่จัดการเกี่ยวกับ Database มา 1 Class ทุกวันนี้ ขั้นตอนตั้งแต่ เชื่อมต่อ จนถึง ปิดการเชื่อมต่อ เสร็จสรรพภายใน 3-4 บรรทัดครับ แล้วบังเอิญได้ไปเห็น บทความของ คุณ nut_t02 >> http://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
   
Share





  By : Fluke
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2012-11-11
  Download : No files
Sponsored Links
 

Sponsored Links
ตอนที่ 7 : การใช้ Cursor บน Stored Procedure (SQL Server : Stored Procedure)
ตอนที่ 7 : การใช้ Cursor บน Stored Procedure (SQL Server : Stored Procedure)
สำหรับ Cursor เป็นการประกาศตัวแปร (Variable) ชนิด Cursor ซึ่งถ้าจะให้เข้าใจง่าย ๆ ก็คือ เป็นตัวแปรที่ได้จากค่าในขณะนั้น ๆ ที่ประกอบด้วยหลาย Column และ Index ในรูปแบบของ Recordset ที่สามารถกำหนด Block
Rating : Update : 2015-09-30 08:51:02
ตอนที่ 8 : การใช้ If ....Else If...Else สร้างเงื่อนไข (SQL Server : Stored Procedure)
ตอนที่ 8 : การใช้ If ....Else If...Else สร้างเงื่อนไข (SQL Server : Stored Procedure)
นหัวข้อนี้เราจะมาเรียนรู้การใช้งาน IF บน Stored Procedure เพราะคำสั่งนี้เป็นการสร้างเงื่อนไขในการทำงานที่ได้ค่ามาจาก Parameters และ Variable และมันค่อนข้างจะมีความจำเป็นและสำคัญมากในการเขียน Stored
Rating : Update : 2015-10-04 11:36:44
PDF กับสร้าง Header และ Footer บน PDF ไฟล์ ด้วย Library ของ FPDF
PDF กับสร้าง Header และ Footer บน PDF ไฟล์ ด้วย Library ของ FPDF
บทความ php กับการกำหนด header และ footer ของเอกสาร เพื่อให้แสดงผลไปยังทุก ๆ หน้าของเอกสาร pdf
Rating : Update : 2014-09-07 12:56:06
ติดตั้ง Zpanel (Control Panel) บน VM/Linux ของ Azure Virtual Machine
ติดตั้ง Zpanel (Control Panel) บน VM/Linux ของ Azure Virtual Machine
สำหรับ Zpanel เป็น Control Panel บน Web Hosting รองรับทั้ง Linux Server และ Windows Server ที่สามารถใช้งานได้แบบฟรี ๆ มาพร้อมกับ Package ที่รวบรวม Apache,MySQL และ PHP ที่สามารถใช้งานได้ทันที
Rating : Update : 2013-11-19 13:46:50
jQuery ตรวจสอบ Listbox n ตัวว่าซ้ำกันหรือไม่ด้วย jQuery
jQuery ตรวจสอบ Listbox n ตัวว่าซ้ำกันหรือไม่ด้วย jQuery
ตรวจสอบ listbox n ตัวว่าซ้ำกันหรือไม่ด้วย jQuery
Rating : Update : 2013-10-16 20:57:29
Codeigniter ประยุกต์ใช้ Hooks กับการทำ User Online
Codeigniter ประยุกต์ใช้ Hooks กับการทำ User Online
Codeigniter 2.2.6 กับการประยุกต์ใช้ Hooks ในการทำ User Online โดยใช้ MySQL Database
Rating : Update : 2016-06-02 14:56:39


Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน Struts การเขียนโปรแกรม Java Struts Framework
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน Yii  Framework การเขียนโปรแกรม ภาษา PHP กับ Yii
สอน .Net การเขียนโปรแกรม ภาษา .Net

Free Tutorial
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว

สุดยอด Source Code V2.0
 

แจ้งชำระเงิน/โอนเงิน
 

Hit Link
   




Acc : thaicreate@hotmail.com






Load balance : Server 02
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2015 All Rights Reserved.
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 084-715-5121 อัตราราคา คลิกที่นี่

Back to Top