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

Registered : 103,223

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



 

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

มาใช้ 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
Bookmark.   

  By : Fluke
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2012-11-11
  Download : No files
Sponsored Links
แก้ไขปัญหา Notice: Undefined index บน PHP แสดง Error/Message  นี้เมื่อมีการเรียกตัวแปร (Variable)
แก้ไขปัญหา Notice: Undefined index บน PHP แสดง Error/Message นี้เมื่อมีการเรียกตัวแปร (Variable)
ใน PHP เวอร์ชั่นใหม่ๆ เราอาจจะพบ Message Warning นี้กันอยู่บ่อยมาก อันที่จริงมันไม่ใช่ Error ที่เพิ่งเกิดขึ้นมาใหม่ เป็นเพียงการเปลี่ยน Configuration ของ PHP ให้มีความปลอดภัยมากขึ้น
Rating : Update : 2017-04-16 21:28:57
รู้จัก Composer คืออะไร การติดตั้งบน PHP Composer  เช่น XAMPP , Appserv และอื่นๆ
รู้จัก Composer คืออะไร การติดตั้งบน PHP Composer เช่น XAMPP , Appserv และอื่นๆ
รู้จัก Composer คืออะไร การติดตั้งบน PHP Composer เช่น XAMPP , Appserv และอื่นๆ
Rating : Update : 2017-03-18 22:41:17
Bootstrap Themes SB Admin ของดีแนะนำต่อ ธีม Bootstrap กับ jQuery plugins
Bootstrap Themes SB Admin ของดีแนะนำต่อ ธีม Bootstrap กับ jQuery plugins
เป็นธีม Bootstrap ที่ผมได้ใช้กับหลายโปรเจคมาแล้ว มันมีรูปแบบที่ใช้งานง่าย มีความสวยงาม เรียบง่าย ไม่ซับซ้อน สามารถปรับแต่งได้ง่ายมาก สามารถดาวน์โหลดใช้งานได้ฟรี
Rating : Update : 2017-03-30 11:28:05
ตอนที่ 3 : การ Print และแสดงผลบน Stored Procedure (MySQL : Stored Procedure)
ตอนที่ 3 : การ Print และแสดงผลบน Stored Procedure (MySQL : Stored Procedure)
ในปัจจุบัน MySQL ยังไม่มีเครื่องมือที่สามารถทำการ Debug ตัว Stored Procedure ได้ ฉะนั้นในการเขียน อาจจะต้องทำการ SELECT ค่าเพื่อ Debug
Rating : Update : 2016-01-06 19:08:52
iOS 9 มาแล้ว : สาวก Apple ที่ใช้ iPhone , iPad อัพเดดกันได้แล้วครับ
iOS 9 มาแล้ว : สาวก Apple ที่ใช้ iPhone , iPad อัพเดดกันได้แล้วครับ
ในเดือนนี้ (Sep 2015) ทาง Apple ได้ทำการอัพเดดเวอร์ชั่นของ iOS โดยรุ่นใหม่ล่าสุดจะเป็น iOS 9.0 รองรับอุปรกรณ์ Devices ของ Apple เกือบทุกรุ่น
Rating : Update : 2017-03-25 13:06:34
ตอนที่ 2 : การสร้าง Database และ Instance ใหม่บน Oracle Database
ตอนที่ 2 : การสร้าง Database และ Instance ใหม่บน Oracle Database
ในหัวข้อนี้เราจะมาเริ่มต้นการใช้งาน Oracle Database แบบ Step by Step ตามแบบฉบับของไทยครีเอท และตามที่ได้ติดตั้ง Oracle Database
Rating : Update : 2016-02-07 15:44:24
C# การเข้ารหัส User และ Password จัดเก็บลงใน Database แบบบ้านๆ
C# การเข้ารหัส User และ Password จัดเก็บลงใน Database แบบบ้านๆ
Database การเข้ารหัส user Password แบบบ้านๆ
Rating : Update : 2015-10-22 16:16:05
ThaiCreate.Com Forum

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
สอน Google Maps Api
สอน Windows Service
สอน 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
VBScript Tutorial
VBScript Validation
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-2017 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 084-715-5121 อัตราราคา คลิกที่นี่