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,664

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
บทความใหม่ SVN (Subversion)  จัดกับการ Version Control และการทำงานเป็น Team
บทความใหม่ SVN (Subversion) จัดกับการ Version Control และการทำงานเป็น Team
SVN คือ โปรแกรมที่ทำหน้าที่จัดการกับ Version Control ของไฟล์ต่าง ๆ ไม่ว่าจะเป็นการจัดการกับเอกสารพวก Document , ไฟล์รูปภาพ และที่สำคัญที่สุดก็คือ จัดการเกี่ยวกับ Source Code ของโปรแกรม โดยหน้าที่ของ SVN คือจัดเก็บไฟล์ต่าง ๆ
Rating : Update : 2015-09-22 21:38:03
PHP การทำระบบ login ด้วย mysqli และการเข้ารหัส md5
PHP การทำระบบ login ด้วย mysqli และการเข้ารหัส md5
การทำระบบ login ด้วย mysqli และการเข้ารหัส md5
Rating : Update : 2016-03-29 09:19:41
FileZilla อัพโหลดไฟล์ด้วย FTP  ขึ้นบน Host และ Server ง่ายๆ อย่างปลอดภัย
FileZilla อัพโหลดไฟล์ด้วย FTP ขึ้นบน Host และ Server ง่ายๆ อย่างปลอดภัย
บทความสอนการติดตั้งและอัพโหลดไฟล์ขึ้น Host ผ่าน FTP ด้วยโปรแกรม FileZilla ซึ่งเป็นโปรแกรม FTP Client ที่ใช้งานง่าย ๆ และสามารถดาวน์โหลดใช้งานได้ฟรี
Rating : Update : 2017-03-30 09:00:38
Facebook Login Api ด้วย JavaScript SDK/PHP และการจัดเก็บใน MySQL (Update 2017)
Facebook Login Api ด้วย JavaScript SDK/PHP และการจัดเก็บใน MySQL (Update 2017)
บทความนี้จะเป็นการสอนการทำระบบ Login ด้วย Facebook Account ด้วย Facebook API ที่เขียนด้วย JavaScript และการทำงานร่วมกับ PHP รวมทั้งการจัดเก็บลงใน MySQL Database ด้วย
Rating : Update : 2017-04-08 09:01:30
ติดตั้ง (XAMPP) เวอร์ชั่น 5.x (for Windows) ไว้เขียน PHP กับ MySQL มีให้ครบ (Apache, PHP, MySQL)
ติดตั้ง (XAMPP) เวอร์ชั่น 5.x (for Windows) ไว้เขียน PHP กับ MySQL มีให้ครบ (Apache, PHP, MySQL)
ปัจจุบันหลาย ๆ คนหันมาใช้ XAMPP กันเยอะแล้ว สาเหตุหลัก ๆ ก็คือ XAMPP มีการอัพเดดเวอร์ชั่นรวมทั้งวิธีการ Config ให้ทันสมัย เป็นมาตรฐานและส่งเสริมให้โปรแกรมเมอร์ php เขียน php อย่างถูกต้องและปลอดภัย
Rating : Update : 2015-11-09 12:06:05
PHP Ajax&jQuery Signature DrawPad Insert&Select
PHP Ajax&jQuery Signature DrawPad Insert&Select
สร้างลายเซ็น ในรูปแบบ DrawPad พร้อมรูปแบบการดึงค่า ลายเซ็น
Rating : Update : 2016-06-30 11:57:00
การตัดเพลงซ้ำ MIDI Karaoke แบบบ้านๆ 1
การตัดเพลงซ้ำ MIDI Karaoke แบบบ้านๆ 1
การตัดเพลงซ้ำ MIDI Karaoke แบบบ้านๆ 1
Rating : Update : 2016-01-28 09:22:09
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
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน .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 05
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 อัตราราคา คลิกที่นี่