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

Registered : 104,072

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
PHP สอนใช้งาน Tinymce + filemanager Text Editor PHP
PHP สอนใช้งาน Tinymce + filemanager Text Editor PHP
บทความนี้จะมาสอนการใช้งาน textarea editor กันนะครับ โดยจะใช้ Tinymce + Feature filemanager ไว้ใช้สำหรับจัดการ ไฟล์ต่าง ๆหรือรูปภาพต่าง ๆใช้สำหรับ ภายในเว็บไซต์ นั่นเอง ผู้เขียน : Prapat Polchan
Rating : Update : 2016-07-29 16:52:35
DataGridView / Image-Picture (DataGridViewImageColumn) สร้าง DataSource ให้กับ Image (VB.Net , C#)
DataGridView / Image-Picture (DataGridViewImageColumn) สร้าง DataSource ให้กับ Image (VB.Net , C#)
เราจะมาเรียนรู้วิธีการสร้าง image หรือรูปภาพ (Picture) ใน DataGridView ของ Windows Form Application ไว้สำหรับแสดงรุปภาพ ซึ่งรุปแบบของข้อมูลอาจจะมาจาก Column ของ Table
Rating : Update : 2017-03-18 23:37:30
PHP - ทำเว็บ 2 ภาษา (Multi language) ด้วย mod rewrite เช่น (/th/ และ /en/)
PHP - ทำเว็บ 2 ภาษา (Multi language) ด้วย mod rewrite เช่น (/th/ และ /en/)
เทคนิคการเขียน PHP หลายภาษา หรือทำเว็บให้แสดงได้ 2 ภาษา (multi language) แบบรองรับ SEO ให้อยู่ในรูปแบบ URL ที่สวยงาม เช่น /th/ หรือ /en/
Rating : Update : 2017-03-18 22:42:36
วิธีการอัพโหลดเว็บไซต์ หรือ โปรเจค/โปรแกรม php ขึ้นโฮส (Host) บน Server แบบ Step by step
วิธีการอัพโหลดเว็บไซต์ หรือ โปรเจค/โปรแกรม php ขึ้นโฮส (Host) บน Server แบบ Step by step
บทความมือใหม่กับการอัพโหลดไฟล์ php ขึ้นบนโฮส(host) หรือ server ซึ่งประกอบด้วยการ FTP ไฟล์ , การสร้าง MySQL Table ผ่าน phpMyAdmin และอื่นๆ ที่เกี่ยวข้อง
Rating : Update : 2017-03-30 10:56:13
PHP การทำระบบ login ด้วย mysqli และการเข้ารหัส md5
PHP การทำระบบ login ด้วย mysqli และการเข้ารหัส md5
การทำระบบ login ด้วย mysqli และการเข้ารหัส md5
Rating : Update : 2016-03-29 09:19:41
C# - DataGridView การเพิ่ม Parameter การค้นหาใน Wizard แบบ บ้านๆ
C# - DataGridView การเพิ่ม Parameter การค้นหาใน Wizard แบบ บ้านๆ
Csharp การเพิ่ม parameter การค้นหาใน wizard แบบ บ้านๆ บทความที่ผ่านมาผมได้ทำการ Add Join DataTable ใน DataSource Wizard แบบบ้าน ๆ ไปเรียบร้อยแล้ว
Rating : Update : 2015-10-02 20:39:17
HTML5 ใช้ JavaScript เก็บค่าตัวแปรที่ Client ด้วย localStorage และ sessionStorage (Web Storage)
HTML5 ใช้ JavaScript เก็บค่าตัวแปรที่ Client ด้วย localStorage และ sessionStorage (Web Storage)
เทคนิคการใช้ localStorage และ sessionStorage เก็บค่าตัวแปรที่ Client มาทดแทน Cookies เพื่อเพิ่มประสิทธิภาพการทำงานของ Client Scripts
Rating : Update : 2017-03-24 17:19:01
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 00
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 , 08-9968-0655 อัตราราคา คลิกที่นี่